面向对象(中)
作者:互联网
面向对象(中)
方法的重载
重载:在同一个类中,方法名相同,参数列表不同,与返回值无关
例如下列代码:
public class MethodTest {
String name;
public static void main(String[] args) {
MethodTest m=new MethodTest();
m.eat();
m.eat("小明");
System.out.println(m.eat(2));
}
public void eat() {
System.out.println("这是吃的方法");
}
public void eat(String name) {
System.out.println(name+"吃的方法");
}
public String eat(int hour) {
String eats="吃东西吃了"+hour+"小时";
return ""+eats;
}
}
形参和实参
形参:方法定义时,声明在小括号里面的参数
实参:方法调用时,实际传递给形参的数据
值传递和引用传递
值传递:实参传递给形参的是实参的真实数据值,会创建一个副本
引用传递:实参传递给形参的是实参的地址值,不会创建副本
对象被值传递:意味着传递的并不是真正的对象,而是对象的副本,修改对象副本,并不会影响原对象的值
对象被引用传递:意味着传递的是对象的引用,因此就算改变对象引用,也会反馈到原对象
四种权限修饰符
修饰符的范围由大到小:public,protected,缺省,private
类的修饰符只能为缺省和public
构造器
package com.zx.oop;
public class GouZaoTest {
String name;
int age;
double state;
public static void main(String[] args) {
GouZaoTest g=new GouZaoTest();
/*
* 创建对象时,自动调用这个类的无参构造
* 每个类都有自己的一个默认无参构造
* 在创建一个有参构造器之后,默认无参构造则会被覆盖,需要重新创建
*/
}
}
所以得出结论,构造器默认是无参的,被有参的覆盖后,需要重新创建一个无参构造,否则出现编译异常
构造器的特点:
1.默认为无参构造
2.构造器名字必须与类名相同
3.构造器可以重载
4.必须创建对象的时候,才自动调用构造器
5.一般用来初始化数据的作用
this关键字
这个运行结果是1,是正常的,接下来就把形参改为和属性一样的名字
这时候的结果确为了,并没有把该有的值赋值到,是因为把方法体前面的age也当形参了,就近原则,因此就要用到this关键字了,下面的截图就是加了this
this关键字的使用:
1.this可以用来修饰:属性、方法、构适器
2.this修饰属性和方法:
3.this理解为:当前对象
在类的方法中,我们可以使用"this.属性或"this.方法"的方式,调用当前对象属性或方法。但是,通常情况下,我们都选择省略"this."。特殊情况下,如果方法的形参和类的属性同名时,我们必须显式的使用"this.变量"的方式,表明此变量是属性,而非形参。
package关键字的使用
1.使用package声明类或接口所属的包,声明在源文件的首行
2.包,属于标识符,遵循标识符的命名规则、规范(xxxyyyzzz)、“见名知意
3.每"."一次,就代表一层文件目录。
4.补充:同一个包下,不能命名同名的接口、类。
5.不同的包下,可以命名同名的接口、类。
import关键字的使用
1.在源文件中显式的使用import结构导入指定包下的类、接口声明在包的声明和类的声明之间
2.如果需要导入多个结构,则并列写出即可
3.可以使用"XXX.*"的方式,表示可以导入X×X包下的所有结构
4.如果使用的类或接口是java. lang包下定义的,则可以省略import结构如果使用的类或接口是本包下定义的,则可以省略import结构
5.如果在源文件中,使用了不同包下的同名的类,则必须至少有一个类需要以全类名的方式显示。
6.使用"xxx.*“方式表明可以调用xxx包下的所有结构。但是如果使用的是xxx子包下的结构,则仍需要显;
标签:String,形参,构造,传递,面向对象,实参,public 来源: https://www.cnblogs.com/zxyyds/p/16478868.html