更新时间:2022-03-21 11:39:05 来源:极悦 浏览1202次
我们在Java中有两个不同的类别,它们是原始类型和Java引用类型。
原始类型是byte、char、int、long 、 double、short和boolean。指定对象类型的类是引用类型,例如Integer、Double、Long等。
当涉及到原始类型的初始化时,它们默认初始化,例如boolean 初始化为 false,其他初始化为 0。它们还可以存储其声明类型的一个值。
引用类型变量是对象,因此它们将对象的位置存储在内存中,并且默认初始化为空值。
原始变量包含值。
在下面的内存视图中,“变量 i”的值为 23,其内存地址为 4567,而“变量 c”的值为“d”,其内存地址为 5234。
在引用类型中,变量包含值的地址。
在下面的内存视图中,变量 str值指向该值,其地址为 2675。当我们查看地址 2675 时,该值是“sw test academy”。这样,我们可以说变量str指向的是“sw test academy”这个值。
在下面的示例中,我们将同时查看内存中的原始类型和引用类型,以更好地理解这个概念。
根据上面的代码,如下图所示的 num1 和 num2 具有不同的地址并保存值 22 但 String 变量指向相同的值,它们的值是值“sw test academy”的地址,即900。
让我们做一些例子,看看它们在代码中的表现。
原始类型在 Java 中是按值传递的,我们将在下面的示例中看到这一点。变量a的值在我们在 modify 方法中修改后没有改变,因为我们发送的是变量 a的副本,而不是它的引用。这样,在modify()方法中,我们更改的是“副本 a 的值”,而不是“真正的 a ”或“ a 的引用”。在编程中,我们称这种行为为“按值传递”。
公共类PrimitiveTypeExample {<字体>< /font >
@Test <字体>< /font >
public void originalTypeExample () {<字体>< /font >
诠释a = 8 ; <字体>< /字体>
系统。出来。println ( "修改前:" + a ) ; <字体>< /字体>
修改(一);<字体>< /字体>
系统。出来。println ( "修改后:" + a ) ; <字体>< /字体>
}<字体>< /font >
<字体>< /字体>
私有静态无效修改(int a ){<字体>< /font >
- 一种; //在这里,a的值不会改变,因为a来这里不是作为参考。<font></font>
系统。出来。println ( "方法内部a的值:" + a ) ; <字体>< /字体>
}<字体>< /font >
}
输出
在下面的示例中,modifyAndSum()方法不会更改原始数组,因为在此方法中,我们正在创建数组的副本并对这个Java复制数组进行操作。这就是为什么在我们测试中的modifyAndSum()方法之前和之后,数组元素的总和是相同的。但是,我们将数组的引用发送给sum()方法,这就是为什么在sum()方法中我们要更改原始数组。这在编程中称为“按引用传递” 。
公共类ReferenceTypeExample {<字体>< /font >
@Test <字体>< /font >
public void referenceTypeExample () {<字体>< /font >
int [] myArr = new int [] { 4 , 5 } ; <字体>< /字体>
<字体>< /字体>
系统。出来。println ( "在 modifyAndSum 方法之前:" + ( myArr [ 0 ] + myArr [ 1 ])) ; //所有前数组中数字的总和。<font></font>
modifyAndSum ( myArr ) ; <字体>< /字体>
系统。出来。println ( "modifyAndSum方法后:" + ( myArr [ 0 ] +myArr [ 1 ])) ; //modifyAndSum 方法没有改变原始数组。<font></font>
总和(myArr );<字体>< /字体>
系统。出来。println ( "求和后的方法:" + ( myArr [ 0 ] + myArr [ 1 ])) ; //Sum 方法因为引用类型而改变了 myArr!<font></font>
}<字体>< /font >
<字体>< /字体>
private static void modifyAndSum ( int [] arr ) {< font >< /font >
arr = 数组。copyOf ( arr, arr.length ) ; //这里,我们正在创建一个新数组!修改不会影响原始数组。<font></font>
arr [ 0 ] --; <字体>< /字体>
系统。出来。println ( "内部 modifyAndSum 方法:" + ( arr [ 0 ] + arr [ 1 ])) ; <字体>< /字体>
}<字体>< /font >
<字体>< /字体>
private static void sum ( int [] arr ) {< font >< /font >
系统。出来。println ( "内部求和法:" + ( arr [ 0 ] + arr [ 1 ])) ; //这里我们添加原始数组的值。<font></font>
arr [ 0 ] --; //这里,我们正在修改原始数组,因为我们作为参考发送。<font></font>
}<字体>< /font >
}
输出
0基础 0学费 15天面授
Java就业班有基础 直达就业
业余时间 高薪转行
Java在职加薪班工作1~3年,加薪神器
工作3~5年,晋升架构
提交申请后,顾问老师会电话与您沟通安排学习