Java基础学习
一 方法
1.1 方法定义
定义
方法(method)是最小的执行单元
用法:
重复的代码、具有独立功能的代码可以抽取到方法中
好处:
- 可以提高代码的复用性
- 可以提高代码的可维护性
定义格式:
注意:方法调用时,参数的数量与类型必须与方法定义中小括号里面的变量一一对应,否则程序将报错。
- 如果在调用处要根据方法的结果,去编写另外一段代码逻辑
- 为了在调用处拿到方法产生的结果,就需要 定义带有返回值的方法
调用方式
public class test {
public static void main(String[]args){
//计算公司四年的销售总额度
int a =test(15,5,46);
int d =test(15,25,346);
int c =test(153,53,463);
int b =test(1533,5222,4226);
System.out.println(a+b+c+d);
}
public static int test(int num1, int num2 , int num3){
int result = num1+num2+num3;
return result;
}
}
注意:
- 方法不调用就不执行
- 方法与方法之间是平级关系,不能互相嵌套定义
- 方法的编写顺序和执行顺序无关方法的返回值类型为void,表示该方法没有返回值没有返回值的方法可以省略return语句不写如果要编写return,后面不能跟具体的数据
- return语句下面,不能编写代码,因为永远执行不到,属于无效的代码
1.2 方法的重载
- 在同一个类中,定义了多个同名的方法,这些同名的方法具有同种的功能
- 每个方法具有不同的参数类型或参数个数,这些同名的方法,就构成了重载关系
- 简单记:同一个类中,方法名相同,参数不同的方法。与返回值无关
参数不同:个数不同、类型不同、顺序不同
以下为一些判断重载的案列:
案列:利用重载的思想,设计比较两个整数是否相同的方法
注意重载的条件
public class chongzai {
//利用重载的思想,设计比较两个整数是否相同的方法
//要求:兼容全整数类型 (byte,short,int,long)
public static void main(String[]args){
compare(10,20);
}
public static void compare( int num1,int num2){
System.out.println(num1 == num2);
}
public static void compare( byte num1,byte num2){
System.out.println(num1 == num2);
}
public static void compare( short num1,short num2){
System.out.println(num1 == num2);
}
public static void compare( long num1,long num2){
System.out.println(num1 == num2);
}
}
案列 (复制数组区间)
需求:定义一个方法copyofRange(int[] arr,int from,int to)功能:
将数组arr中从索引from (包含from) 开始。
到索引to结束 (不包含to) 的元素复制到新数组中,
将新数组返回。
public class copeArr {
public static void main(String[]args){
/*需求:定义一个方法copyofRange(int[] arr,int from,int to)功能:
将数组arr中从索引from (包含from) 开始。
到索引to结束 (不包含to) 的元素复制到新数组中,
将新数组返回。*/
//先定义一个原数组
int arr[] = {1,2,3,4,5,6,7,8,9};
//调用和赋值
int CopyArr[] = copyofRange(arr, 3, 7);
for(int i = 0;i<CopyArr.length;i++){
System.out.println(CopyArr[i]);
}
}
public static int [] copyofRange(int[] arr,int from,int to){
//定义一个数,来将copy的数组进行赋值
int findArr = 0 ;
//定义一个copy数组
int[] newArr = new int [to - from];
//利用遍历来实现复制
for(int i = from;i<to;i++){
newArr[findArr] = arr[i];
findArr++;
}
return newArr;
}
}
这道案列主要是看重的是思考问题的方向,只有拆分了问题,才能更好的解决问题
1.3 方法的内存
1.3.1 基本数据类型
数据值是存储在自己的空间里面(栈区)
特点:
赋值给其他变量,赋的值也是真实的值
1.3.2 引用数据类型
数据值是存储在其他空间中(堆区)
``自己空间中存储的是地址值
1.3.3 方法的值传递
- 传递引用数据类型时,传递的是地址值,形参的改变,影响实际参数的值