Java中关于“=”和“==”的分析

Java中变量分为普通原始变量(int char float等)和对象

一“=”

(1)普通原始变量

普通原始变量的声明和赋值语句例如以下

            int a=3;
            int b=a;

此时a和b都为普通原始变量。这里的内存使用情况例如以下

第一行在内存中开辟一块内存(大小为int所占的大小)。并将这块内存用a标示。这时a的值的就是这块内存的内容。第二行b=a就是在内存中再开一块内存(大小为int所占的大小)可是这块内存的地址和第一行的地址是不一样的。可是软件人员也不知道所以不能直接使用内存。

此时将a中的内容拷贝一份然后填充在b所表示的内存块中。运行完这两行代码后结果就是

开辟两块不同的内存,可是这两块内存中的内容是同样的。

(2)包装器和对象

如果A是一个类。如今有例如以下代码

    A a;
    a=new A();
    A b=a;

这时候第一行代码就是在内存中开辟一块内存。并把这块内存标记为A类的引用,可是这块内存中的内容为null,表示这个A类的引用并不指向不论什么内存。

第二行代码就是先开辟一块内存。这块内存中的大小就是创造出A类一个默认对象的大小,然后创建一个A类的对象,将这个对象放入到这块内存中。然后再把这块内存的地址填充到引用变量a的内存中。

第三行代码就是先开辟一块内存。这块内存类型为A类对象引用并标记为b。然后将a内存中内容拷贝一份放到b内存中,所以b的引用也是第二行代码中创建的存放A类的对象的那块内存。

这三行代码运行完后。在内存中开辟了三块内存块。第一个内存块用a标示。类型为A类对象的引用,第二个内存块没有名字,类型为A类的对象,第三个内存块用b标示。类型也为A类对象的引用。

二 “==”

(1)普通原始变量

        int a=3;
        int b=3;
        System.out.println(a==b);

此时在内存中开辟了两块内存块,被标示为a和b,内容都是3。这时候a==b比較的就是两块内存中的内容。

输出为true

(2)包装器和对象

如果有A类

        A a=new A();
        A b=new A();
        A c=a;
        System.out.println(a==b);
        System.out.println(a==c);
        System.out.println(b==c);

第一行代码就是a为一块内存块,内容为还有一块A类对象内存块的地址(如果为x)。

第二行代码就是b为一块内存块,内容为还有一块A类对象内存块的地址(如果为y)。

第三行代码就是c为一块内存块,内容为和a所指向地址同样的内存块的地址(x)。

a==b推断的就是a内存块和b内存块中的内容,由于指向两块内存块的地址不同,所以第七行输出false

a==c推断的就是a内存块和c内存块中的内容,由于存放的都是第一行代码所产生的A类对象的内存块的地址。所以是同样的,输出true

b==c推断的是b内存块和c内存块中的内容,可是这两块的内存块中的内容是不同A类对象内存块的地址。所以输出false.

时间: 2024-08-10 14:07:10

Java中关于“=”和“==”的分析的相关文章

Eclipse中的快捷键快速生成常用代码(例如无参、带参构造,set、get方法),以及Java中重要的内存分析(栈、堆、方法区、常量池)

Eclipse中的快捷键快速生成常用代码(例如无参.带参构造,set.get方法),以及Java中重要的内存分析(栈.堆.方法区.常量池) 以上就是Eclipse中的快捷键快速生成常用代码(例如无参.带参构造,set.get方法),以及Java中重要的内存分析(栈.堆.方法区.常量池)的全部内容了,更多内容请关注:CPP学习网_CPP大学 本文固定链接:CPP学习网_CPP大学-Eclipse中的快捷键快速生成常用代码(例如无参.带参构造,set.get方法),以及Java中重要的内存分析(栈.

大杂烩 -- Java中Iterator的fast-fail分析

基础大杂烩 -- 目录 Java中的Iterator非常方便地为所有的数据源提供了一个统一的数据读取(删除)的接口,但是新手通常在使用的时候容易报如下错误ConcurrentModificationException,原因是在使用迭代器时候底层数据被修改,最常见于数据源不是线程安全的类,如HashMap & ArrayList等. 为什么要有fast-fail 一个案例 来一个新手容易犯错的例子: String[] stringArray = {"a","b"

Java中ArrayList源码分析

一.简介 ArrayList是一个数组队列,相当于动态数组.每个ArrayList实例都有自己的容量,该容量至少和所存储数据的个数一样大小,在每次添加数据时,它会使用ensureCapacity()保证容量能容纳所有数据. 1.1.ArrayList 的继承与实现接口 ArrayList继承于AbstractList,实现了List, RandomAccess, Cloneable, java.io.Serializable这些接口. public class  ArrayList<E> ex

Java中json工具对比分析

Java中几个json工具分析 1, 环境 JDK1.6+IDE(IntelliJ IDEA)+windowsXP+GBK编码 2,分析对象 jackson1.8.2 http://jackson.codehaus.org/ gson1.7.1 http://code.google.com/p/google-gson/ jsob_lib2.4 http://json-lib.sourceforge.NET/ 3,使用实例          用两个bean进行测试,两个bean都嵌套有数组和对象,

Java中I/O的分析

学习Java的同学注意了!!! 学习过程中遇到什么问题或者想获取学习资源的话,欢迎加入Java学习交流群,群号码:618528494  我们一起学Java! Java中I/O的原理: 在java程序中,对于数据的输入/输出操作以"流"的方式进行的. 流是内存中一组有序数据序列 Java将数据从源读入到内存当中,形成了流,然后这些流可以写到目的地. Java中流按功能分为:节点流(原始流)和处理流(包裹流) 处理流是在节点流的基础上提供了更加强大的读写功能 Java中流按处理数据的不同分

JAVA中负数转二进制分析

最近在看集合源码,发现ArrayDeque里面用到了大量的&运算,这牵扯到了二进制.突然发现自己对负数的二进制有点模糊了,对此进行了一些支持补充. 首先我们要对原码.反码和补码有个了解: 1.所谓原码就是二进制定点表示法,即最高位为符号位,"0"表示正,"1"表示负,其余位表示数值的大小. 2.反码表示法规定:正数的反码与其原码相同:负数的反码是对其原码逐位取反,但符号位除外. 原码10010= 反码11101 (10010,1为符号码,故为负) (1110

java中i=i++问题分析

http://www.ticmy.com/?p=43 重点:局部变量表 和 操作数栈的执行过程. 使用javac编译后再使用javap -c Test反编译这个类查看它的字节码,如下(只摘取main方法): public static void main(java.lang.String[]); Code: 0: iconst_0 1: istore_1 2: iload_1 3: iinc 1, 1 6: istore_1 7: getstatic #2; //Field java/lang/

Java中的递归原理分析

解释:程序调用自身的编程技巧叫做递归. 程序调用自身的编程技巧称为递归( recursion).递归做为一种算法在程序设计语言中广泛应用. 一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量.递归的能力在于用有限的语句来定义对象的无限集合. 递归的三个条件: 边界条件 递归前进段 递归返回段 当边界条件不满足时,递归前进:当

java中的==与equals()分析与源码分析

1.关于== 首先要知道==用于匹配内存单元上的内容,其实就是一个数字,计算机内部也只有数字,而在java语言中,当==匹配时,就是比对两个单元内存的内容是否一样. 如果是原始类型,byte,boolean,short,char,int,long,float,double,就是直接比较他们的值. 如果是引用,比较的就是引用的值,引用的值可以被认为是对象的逻辑地址,如果两个引用发生==操作,就是比较两个相应的对象的地址值是否一样,换句话说,如果两个引用保存的是同一个对象,则返回true,否则返回f