javajava静态成员变量量里 String a;和 String a = null;在内存中有区别吗

18:38 提问
null == a 和 a == null的区别
String a = "a"
请问null == a 和 a == null 的区别
按赞数排序
没什么区别
只是为了 防止将 == 错写成 =的一种手段
NULL=a 会报错的。
a=NULL 不会报错。
这样,当我们错写的时候,就能很好的得到提示了
防止将 == 错写成 =的一种
==具有三大性质
自反性 a==a永远成立
传递性 a==b b==c必然a==c
对称性 a==b,必然b==a
其实没区别,硬要说有那就是前者的主体是null,判断null是否等于a,后者主体是a,判断a是否等于null
原来如此,谢谢,终于明白了。
在网上找到说是NullPointException,后来自己测了发现不对啊,a.equals("")和"".equals(a)这个才是避免空指针
谢谢大哥!!!
效果是一样的,只不过null == a这种写法编译器会检查,防止错写成null = a,实际上这样编译不通过,会有错误提示。
通俗点就是判断的主体不同,但实际上功能都一样
可以防止将==写成=的错误发生
: 如果null写在前面,null=a编译不通过
: a=null确可以通过,但是错误的
没有什么区别,验证相等返回布尔值的时候前后是等价的~~
程序员一般都被要求这样写,因为有些人马虎大意,有时候会将==写错,写成=。本帖子已过去太久远了,不再提供回复功能。6062人阅读
java(35)
null和&&的区别
null和&&的区别
string.trim()就会抛出为空的exception &&
String s=&&; &&
string.trim()就不会抛,为什么?&
NULL代表声明了一个空对象,根本就不是一个字符串。 &&
&&代表声明了一个对象实例,这个对象实例的值是一个长度为0的空字符串。
NULL代表声明了一个空对象,对空对象做任何操作都不行的,除了=和== &&
&&是一个字符串了,只是这个字符串里面没有内容了
String s=只是定义了一个句柄,也就是说你有了个引用,但是这个引用未指向任何内存空间 &&
String s=&&;这个引用已经指向了一块是空字符串的内存空间,是一个实际的东东了,所以你可以对它操作,而不用担心什么了
你说数字0和没有是不是一种概念啊??道理一样的
而且,null可以赋值给任何对象.&&就不行了.
这里&&和NULL绝对是两个概念 &&
&&代表一个字符串存在,它的值就是“” &&
NULL代表字符串根本没有实际的值,你并不知道它是什么。。。
哦,我明白了,意思就是String & string & = & null & 跟String &是一回事儿
null是空对象 & & &&是空字符串
String s=//null是未分配堆内存空间 &&
String &//分配了一个内存空间,没存入任何对象 &&
String & a=&&;//分配了一个内存空间,存了一个字符串对象
S和String s=和String s=&a&;有什么区别? &&
针对这三种情况,使用out.println(s);的时候,第一个会出现异常,第二个会输出null.第三个则会输出a. &&
这是为什么呢?这三句声明语句,各自作了什么呢?
第一个只是定义了一个String类型变量s,并没有给它赋初值,在Java中,默认在使用一个变量的时候必须赋予它初值(降低风险)。&
第二个和第三个都定义了String类型变量s,并赋予它初值,只不过第二个赋予的值为null(空)罢了
主要要理解的是S s为一个引用~~它不是对象 &&
第一个是没有初始化的引用; &&
第二个为空引用;
第三个是在字符串池里写入一个字符'a',然后用s指向它。
String s=&a&和String s=new String(&a&);是有本质上的区别的 &&
前者是在字符串池里写入一个字符'a',然后用s指向它;
后者是在堆上创建一个内容为&a&的字符串对象。
String & str=&aaa&; & & & & & & & & & &//于栈上分配内存
String & str=new & String(&aaa&); & & &//于堆上分配内存
S 系统会自动赋值null
S只是给s分配一个内存空间 &&
String s=是分配的空间中存储的值为空值 &&
String s=&a&;这句就不用我多说了分配的空间的值为字符a
声明了一个变量 & &
在以后的判断中,a==&&和a==null有何不同? &&
如果没有给a赋过值,a==&&会导致异常。 & &&
在实际处理时,往往认为&&和null代表相同的含义,即都代表无值。 &&
此时建议用如下语法: &&
if(a==null & || & a==&&) &&
如果a为null,就不会执行后面的判断,直接返回true。 &&
null是用来判断引用类型是否分配了存储空间 &&
&&是针对字符串的; &&
string类型实际上是字符串指针,也即是一个引用类型 &&
所以如果没有给a赋过值,a==&&会导致异常 &&
所以if(a==null & || & a==&&){}这种写法也是正确的
String abc=String abc=&&;S三种写法有什么区别?&
1:创建一个空字符串对象, &&
2:创建一个字符串为空的字符串对象。 &&
3:声明一个字符串对象,但并没有分配内存,而1,2已经分配了内存 &&
对于最后一种表示,你不能if(abc==null),或者int & length & = & abc.length();编译的时候会提示可能没有初始化.
String & abc= &&
String & abc=&&; &&
一般推荐使用第二种 &&
第一种abc指向null,很多时候要判断字符串是否为空时,容易漏掉这种情况,在调用String的相关方法的时候就会出错 &&
第二种则相对简单,String的方法都可以用,判断的时候也不会出错
1) String & abc= &&
2) String & & &
3)String & a=&&; &&
4) String & b=&&; &&
5) String & c=new String(&&); &&
6) String & d=new String(&&);&
//1)等于2),和C语言不同,JAVA为安全原因不允许一个悬挂引用,没有赋值的引用地址一律自动赋值为NULL,以防止访问到任意内存 &&
//3)和4)中,变量a和b将会指向同一内存地址(&&的地址) &&
//5)和6)中,变量c和d不会指向同一地址,而是两个&&内容的地址,并且和a,b不同,实际上,3)和4)相当于new String(&&).intern(). &&
//String类维护着一个字符串池,对于像3)和4)这样的赋值方法,String会在这个池中查找字符串是否已经在池中,如果在,就直接指向该地址,
如果不在,生成一个实例放入池中再指向那个地址,可见对于同样内容的字符串多次引用时3)4)的方法要比5)6)的方法剩内存,之所以这样做,是
因为String是一个内容不可变的量,运用的是设计模式GOF.FlyWeight &&
但有个关键的一点,没有人说到,这就是: &&
S在什么情况下可以等同于String s=而在什么情况下又不等同?!
考虑下面的代码: &&
//StringTest.java &&
public & class & StringTest & { & & &
& & static & String & & & //* &&
& & public & static & void & main(String[] & args) & { &&
& & & & //String & & & & & //** &&
& & & & System.out.println(s); &&
编译并运行上面的代码,将打印null。
可见标有*号的行是自动初始化了的(s被自动初始化为null)。 &&
而如果把标有**号的行取消注释,代码将不能通过编译,这是因为这行定义的是本地变量,而本地变量是不会自动初始化的。
由此得出结论:
在成员变量的定义中,S等同于String s=
而在本地变量(方法变量)的定义中,S不等同于String s=,这时要使用s必须显式地赋值。
这些虽然是小知识点,但在实际应用中很重要,也很容易被一些人忽视,特此提出。
还有一点要说明的是:
只要是在方法在中定义变量都要显示赋初值,main()方法也不例外,而在方法之外编译器回自动赋初值。
&&相关文章推荐
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:268021次
积分:8917
积分:8917
排名:第2231名
原创:645篇
转载:67篇
(1)(1)(2)(1)(3)(2)(3)(2)(1)(1)(1)(8)(8)(2)(2)(3)(4)(4)(3)(4)(5)(1)(4)(9)(6)(1)(5)(3)(607)(4)(3)(3)(2)(3)
(window.slotbydup = window.slotbydup || []).push({
id: '4740881',
container: s,
size: '200,200',
display: 'inlay-fix'转载地址:/link?url=TiUvedxlF4YqktZl8shEigzYnSYA4hrixykEggfs7JbmSbl7bACBcpt2HpRiwA9c9GIv-62b-TAtqVQNkZWFbr9ldGNCYU65LqWgoAIygkm
首先明确的一点,String的equals方法默认是重写了Object类的方法,具体是实现是
public boolean equals(Object paramObject) {
if (this == paramObject) {
if (paramObject instanceof String) {
String str = (String) paramO
int i = this.
if (i == str.count) {
char[] arrayOfChar1 = this.
char[] arrayOfChar2 = str.
int j = this.
int k = str.
while (i-- != 0) {
if (arrayOfChar1[(j++)] != arrayOfChar2[(k++)])
}也就是说,对于a.equals(null)来说,第一步也会判断this == null,这里的this就是a。上面的代码已经说明,当equals传入的参数是null的时候,和a==null的效果是一样的。但是如果传入的参数不是null,那么a==b只能判断a和b是否指向同一个java对象,而a.equals(b)能判断a和b指向的java对象的字符串内容是否一样。
本文已收录于以下专栏:
相关文章推荐
他的最新文章
讲师:王哲涵
讲师:韦玮
您举报文章:
举报原因:
原文地址:
原因补充:
(最多只允许输入30个字)

我要回帖

更多关于 java 判断变量为null 的文章

 

随机推荐