JAVA基础:值传递和址传递

2024-09-08 14:36
文章标签 java 基础 传递 和址

本文主要是介绍JAVA基础:值传递和址传递,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1 值传递和址传递

值传递

  • 方法调用时,传递的实参是一个基本类型的数据

  • 形参改变,实参不变

public static void doSum(int num1,int num2){}
main(){doSum(10,20);int i = 10 ;int j = 20 ;doSum(i,j) ;
}

 

public static void t1(int num){num = 20 ;System.out.println(num) ; //20
}main(){int i = 10 ;t1(i) ; //值传递System.out.println(i); //10
}

址传递

  • 又称为地址传递,或引用传递

  • 方法调用时,传递的实参是一个引用类型的数据

    • 基本类型的数据,比较简单,可以直接存储在变量中

    • 引用类型的数据比较复杂,包含了一堆子数据,不能直接存储在变量中,存储在堆区,会为其分配一个内存地址

    • 我们在使用引用类型数据时,都是通过地址间接引用类型的数据

    • 所谓的地址传递,就是在方法调用时,传递的是引用类型的地址。

  • 形参(内容)改变,实参(内容)改变

public static void t1(int[] nums){System.out.println(nums[1]); //20nums[1] = 200 ;System.out.println(nums[1]); //200
}main(){int[] nums = {10,20,30} ;t1( nums ) ;  //址传递System.out.println(nums[1]); //
}

 

类似于值传递的址传递

public static void t1(int[] nums){System.out.println(nums[1]); //20nums = new int[]{100,200,300}System.out.println(nums[1]); //200
}main(){int[] nums = {10,20,30} ;t1( nums ) ;  //址传递System.out.println(nums[1]); //20
}//main方法调用t1方法时,就相当于将t1方法中的代码拿到主方法中
main(){int[] nums1 = {10,20,30} ;{nums = nums1 ;System.out.println(nums[1]); //20nums = new int[]{100,200,300}System.out.println(nums[1]); //200}System.out.println(nums1[1]) ;//20
}

 

2 主方法传参

  • 主方法是Java程序的入口

  • 是由 jvm自动调用。

  • 在程序执行的过程中,我们也可以调用主方法(都看需求)

  • 在运行java程序时,我们通过命令行指定jvm调用主方法时要传递的参数。

    • 默认情况下,jvm调用主方法时,传递的是一个0长度的数组。

java Test1 zs ls在执行Test1程序时,告诉jvm,将zs和ls作为参数,传递个main方法。
jvm内部会将zs和ls组成一个String[],将这个String[]传递给main方法

 

public static void main(String[] args){for(int i=0;i<args.length;i++){String s = args[i] ;System.out.println(s);}}

3 合并两个有序数组

  • 有两个各自有序的数组 {10,20,30,40,50} , {5,15,25,35}

  • 将两个数组合并成一个大数组,同时使得内容依然有序

    • 定义双指针, 一个记录数组1的下标位置, 一个记录数组2的下标位置

    • 从头开始, 依次对两个数组指针位置的元素进行比较

    • 将小的数装入新数组,同时对应数组的指针++

    • 循环进行下依次比较移动

    • 注意:需要考虑一个数组提前移动完成的情况。 接下来不需要比较,只移动第二个数组即可

4 归并排序

  • 有一个无序的数列,需要排序

  • 我不会直接排序

    • 但我可以将一个数组等分成2个小数组 10个长度的数组,分成2个5长度的数组。

    • 我还会将两个有序数组合并成一个有序数组

  • 如果有人可以将的两个小数组变成有序数组,我就可以将其合并成一个完整的有序数组。

  • 如何将小序列排序呢? 递归调用。

 

这篇关于JAVA基础:值传递和址传递的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1148377

相关文章

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

SpringBoot中使用 ThreadLocal 进行多线程上下文管理及注意事项小结

《SpringBoot中使用ThreadLocal进行多线程上下文管理及注意事项小结》本文详细介绍了ThreadLocal的原理、使用场景和示例代码,并在SpringBoot中使用ThreadLo... 目录前言技术积累1.什么是 ThreadLocal2. ThreadLocal 的原理2.1 线程隔离2

springboot将lib和jar分离的操作方法

《springboot将lib和jar分离的操作方法》本文介绍了如何通过优化pom.xml配置来减小SpringBoot项目的jar包大小,主要通过使用spring-boot-maven-plugin... 遇到一个问题,就是每次maven package或者maven install后target中的ja

Java中八大包装类举例详解(通俗易懂)

《Java中八大包装类举例详解(通俗易懂)》:本文主要介绍Java中的包装类,包括它们的作用、特点、用途以及如何进行装箱和拆箱,包装类还提供了许多实用方法,如转换、获取基本类型值、比较和类型检测,... 目录一、包装类(Wrapper Class)1、简要介绍2、包装类特点3、包装类用途二、装箱和拆箱1、装

如何利用Java获取当天的开始和结束时间

《如何利用Java获取当天的开始和结束时间》:本文主要介绍如何使用Java8的LocalDate和LocalDateTime类获取指定日期的开始和结束时间,展示了如何通过这些类进行日期和时间的处... 目录前言1. Java日期时间API概述2. 获取当天的开始和结束时间代码解析运行结果3. 总结前言在J

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

Java多线程父线程向子线程传值问题及解决

《Java多线程父线程向子线程传值问题及解决》文章总结了5种解决父子之间数据传递困扰的解决方案,包括ThreadLocal+TaskDecorator、UserUtils、CustomTaskDeco... 目录1 背景2 ThreadLocal+TaskDecorator3 RequestContextH

关于Spring @Bean 相同加载顺序不同结果不同的问题记录

《关于Spring@Bean相同加载顺序不同结果不同的问题记录》本文主要探讨了在Spring5.1.3.RELEASE版本下,当有两个全注解类定义相同类型的Bean时,由于加载顺序不同,最终生成的... 目录问题说明测试输出1测试输出2@Bean注解的BeanDefiChina编程nition加入时机总结问题说明