1、类的无参方法
方法是个“黑匣子”,完成某个特定的应用程序功能,并返回结果
类的方法定义类的某种行为(或功能)
语法:
public 返回值类型 方法名() {
//这里编写方法的主体
}
方法名:使用驼峰命名法,命名要遵循规则且有意义
方法的返回值
如果方法具有返回值,方法中必须使用关键字return返回该值,返回值类型为该值的类型
其中:返回值只能有一个
没有返回值的方法,也可以使用return,作用是结束方法调用,返回方法调用处
方法调用
方法之间允许相互调用,不需要知道方法的具体实现,实现重用,提高效率
2、定义带参方法的语法:
<访问修饰符> 返回类型 <方法名>(<形参列表,多个参数逗号分隔>) {
//方法的主体
}
调用方法语法:
对象名.方法名(实参1, 实参2,……,实参n)
注意:
形参需要指定参数的类型,参数类型和参数名空格分隔,形参只在方法内部可见,不需要初始化,因为其作用是接收调用方法的实际参数
带参方法传递参数时候,参数的类型和顺序要跟定义的形参列表保持一致
实参要有实际的含义,如果相同类型的参数,值顺序传递错误,那对应的方法执行的结果就是错误的
3、方法参数传递:
1)值传递
基本数据类型,操作传递的是变量的值,改变一个变量的值不会影响另一个变量的值
2)引用传递(地址传递)
引用数据类型(类、数组、集合等),赋值是把原对象的引用(可理解为内存地址)传递给另一个引用
4、构造方法:
语法:
访问修饰符 构造方法名(){
//初始化代码
}
或者
访问修饰符 构造方法名(参数类型1 参数名1, 参数类型2 参数名2 。。。。){
//初始化代码
}
特点:
无返回值类型,方法名和类名相同,可以指定参数
作用:
创建对象初始化使用,系统会自动提供默认无参构造方法
5、构造方法重载
强调:
自定义的构造方法(方法名相同、参数项不同、与返回值、访问修饰符无关),那系统是不会提供默认无参构造,如果还需要用的话,要自己手动写一个。
6、this关键字的用法:
1)this关键字代表当前创建的对象
this.属性 操作当前对象的属性
this.方法 调用当前对象的方法。
2)封装对象的属性的时候,经常会使用this关键字。
3)构造方法中使用this必须遵守的规则:
(1)假如在一个构造方法中使用了this语句,那么它必须作为构造方法的第一条语句(不考虑注释语句)。
(2)只能在一个构造方法中使用this语句来调用类的其他构造方法,而不能在成员(实例)方法中用this语句来调用类的其他构造方法。
(3)只能用this语句来调用其他构造方法,而不能通过方法名来直接调用构造方法。
7、方法重载(overflow)
定义:同一个类中的多个方法可以有相同的方法名称,但是有不同的参数列表,这就称为方法重载
注意:
参数列表包括参数的类型、参数的个数、参数的顺序,只要有一个不同就叫做参数列表不同。
与修饰符和返回值没有关系
即:
同一个类中
方法名相同
参数个数或类型或顺序不同
与返回值、访问修饰符无关
8、成员变量和局部变量
变量声明的位置决定变量的作用域,变量的作用域是变量可在程序中按照变量名访问的范围
语法:
public class 类名{
变量1类型 变量1;
变量2类型 变量2;
变量3类型 变量3;
public 返回类型 方法1(){
变量4类型 变量4;
}
public 返回类型 方法2(){
变量5类型 变量5;
}
}
for循环举例,循环内定义的变量,在循环外是无法直接访问的
示例:
for(int a = 0; a < 4; a++) {
System.out.println ("hello" );
}
System.out.println ( a );// 编译报错
9、两种变量的区别:
作用域不同
成员变量作用域在整个类内,而局部变量仅限于方法内
初始值不同
成员变量有初始值,而局部变量不会赋予初始值
注意:
方法内不能有重名的局部变量,不同方法内可以定义同名的变量,同一个类中,成员和局部变量重名,那局部变量优先级高,使用this区分成员变量和局部变量,实现属性赋值操作