Java内存分配+方法

本文详细解释了Java中的内存分配机制,包括堆内存和栈内存的区别,以及数组的内存图。还介绍了方法的概念、定义、调用,包括无参、有参、带返回值的方法,并探讨了重载、参数传递、数组操作和方法调用的内存原理。
摘要由CSDN通过智能技术生成

day07-Java内存分配+方法

1.内存分配

main文件在代码运行完后会出栈,  new创建的(如存储对象/数组)会存储在堆内存,在堆内存中会产生地址 

2.数组内存图

两个数组指向不同空间

静态、动态初始化的数组,通过地址传给数组名,所以直接打印数组名打印出来是地址 

两个数组指向同一空间

arr1与arr2是一个位置,改变其中一个索引值,两个数组都会改变。

总结:

对于两个数组指向不同空间:

对于两个数组指向同一空间

3.方法

3.1 方法的概念

方法(method)是程序中最小的执行单元

  • 注意:

    • 方法必须先创建才可以使用,该过程成为方法定义

    • 方法创建后并不是直接可以运行的,需要手动调用后才能行,该过程成为方法调用

    • 代码执行过程,看到方法进入方法,执行完毕后回到调用处

3.2 方法的定义和调用

如何选择不同定义方法?:三个问题问自己

1.我要干嘛?

2.需要什么?

3.方法调用处是否需要继续使用方法的结果?

4.如果不用。方法可以不写返回值

3.2.1 无参数方法定义和调用

定义:

调用:

3.2.2 带参数方法定义和调用

定义:

调用:

  • 方法调用时,参数的数量与类型必须与方法定义中的设置相匹配,否则程序将报错

例子:

3.2.3 形参和实参

3.2.4 带返回值方法定义和调用

需要的原因:

定义:

调用:方法的返回值返回给调用处

三种调用格式示例:

练习1:

定义一个方法,求一家商场每个季度的营业额。根据方法结果再计算出全年营业额。

代码示例:

练习2:

键盘录入两个圆的半径(整数),比较两个圆的面积。

3.3方法注意事项

3.3.1 return作用

3.4 方法的重载

  • 方法重载概念

Java虚拟机会通过参数不同来区分同名的方法

如何判断方法是否重载?

1、看是否在同一个类中且名字相同

2、看是否参数不同(这里的参数指形参。任意满足一条不同即可,顺序不同可以构成重载但不建议)

以下示例属于重载:参数个数不同

重载练习:

  • 需求:使用方法重载的思想,设计比较两个整数是否相同的方法,兼容全整数类型(byte,short,int,long)

4.方法的练习

1.数组遍历

  • 需求:设计一个方法用于数组遍历,要求遍历的结果是在一行上的。例如:[11, 22, 33, 44, 55]

  • 思路:

    • ①因为要求结果在一行上输出,所以这里需要在学习一个新的输出语句System.out.print(“内容”);

      System.out.println(“内容”); 输出内容并换行

      System.out.print(“内容”); 输出内容不换行

      System.out.println(); 起到换行的作用

    • ②定义一个数组,用静态初始化完成数组元素初始化

    • ③定义一个方法,用数组遍历通用格式对数组进行遍历

    • ④用新的输出语句修改遍历操作

    • ⑤调用遍历方法

2.数组最大值

  • 需求:设计一个方法用于获取数组中元素的最大值

  • 思路:

    • ①定义一个数组,用静态初始化完成数组元素初始化

    • ②定义一个方法,用来获取数组中的最大值,最值的认知和讲解我们在数组中已经讲解过了

    • ③调用获取最大值方法,用变量接收返回结果

    • ④把结果输出在控制台

public class practice2 {
    public static void main(String[] args) {
        //定义一个数组,用静态初始化完成数组元素初始化
          int []arr ={1,4,6,2,6,7};
        //调用获取最大值方法,用变量接收返回结果
          int max=maxNumber(arr);
        System.out.println("最大值为"+max);
    }
    //定义一个方法,用来获取数组中的最大值
    /*
        两个明确:
            返回值类型:int
            参数:int[] arr
     */
    public static int maxNumber(int []arr){
        int max=arr[0];
        for (int i = 1; i < arr.length; i++) {
            if(arr[i]>max){
                max=arr[i];
            }
        }
        return max;
    }
}

3 获取索引

需求1:

定义一个方法获取数字在数组中的索引位置,将结果返回给调用处,如果有重复的,只要获取第一个即可。

代码示例:

需求2:

定义一个方法获取数字在数组中的索引位置,将结果返回给调用处,如果有重复的,都打印出来。

思路启示:

这里要知道5的索引位置,但是有两个位置都有5,所以注定return不止一个,这时候需要考虑利用return数组:

public static int[] ,并建立了伪造索引来讲原数组对应数字的索引值传入新数组中。

4. 拷贝数组

需求:定义一个方法copy0fRange(int [] arr,int from ,int to)

功能: 将数组arr中从索引from到to结束(不包含to)的元素复制到新数组中,将新数组值返回

5.方法调用的内存原理

 1.基本数据类型

变量中存储的是真实的数据

 2.引用数据类型

 变量中存储的不是真实的数据, 而是其他空间地址值的时候,该数据位引用数据类型。

3.小结1

4.方法传递基本数据类型的内存原理

传递基本数据类型时,传递的是真实的数据,形参的改变,不影响实际参数的值。 

如下例:在chang()方法中,将形参改为200,但在栈中,main方法先进入栈内存,一句一句执行,执行change改变形参后,只是改变了change中number的值,change()方法就出栈,main中number仍为100.

传递引用数据类型时,传递的是地址值,形参的改变,影响实际参数的值

5.小结2

  • 10
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值