Java中String判断值为null或空及地址是否相等的问题

时间:2022-04-06 16:04:34

String的null或空值的判断处理
笔者在开发过程中,常常碰到过下面这些错误的用法:
1,错误用法一:

?
1
2
3
if (name == "") {
//do something
}

2,错误用法二:

?
1
2
3
if (name.equals("")) {
//do something
}


3,错误用法三:

?
1
2
3
if (!name.equals("")) {
//do something
}


我们来解说一下:
上述错误用法1是初学者最容易犯,也最不容易被发现的错误,因为它们的语法本身没问题,Java编译器编译时不报错。但这种条件可能在运行时导致程序出现bug,永远也不会为true,也就是时说,if块里的语句永远也不会被执行。

上述用法二,用法三 的写法,是包括很多Java熟手也很容易犯的错误,为什么是错误的呢?也许你会感到纳闷。
对,它们的写法本身没错,但是,少了一个null判断的条件,试想,如果name=null的情况下,会发生什么后果呢?后果是,你的程序将抛出NullPointerException异常,系统将被挂起,不再提供正常服务。
当然,如果之前已经对name作了null判断的情况例外。

正确的写法应该先加上name != null的条件,如例:

?
1
2
3
if (name != null && !name.equals("")) {
//do something
}

或者

?
1
2
3
if (!"".equals(name)) {//将""写在前头,这样,不管name是否为null,都不会出错。
//do something
}


下面,我们举一个简单的例子:

TestNullOrEmpty.java

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
public class Test {
  public static void main (String args[]){
    String value = null;
    testNullOrEmpty(value);
 
    value = "";
    testNullOrEmpty(value);
 
    value = " ";
    testNullOrEmpty(value);
     
    value = "hello me";
    testNullOrEmpty(value);   
  }
     
  static void testNullOrEmpty(String value){
    if(value == null){
      System.out.println("value is null");
    } else if ("".equals(value)){
      System.out.println("value is blank but not null");
    } else {
      System.out.println("value is \"" + value + "\"");
    }
     
    if (value == "") { //NG 错误的写法
      //别用这种写法
    }
  }
}

编译执行:

?
1
2
3
c:\>javac TestNullOrEmpty.java
 
c:\>java TestNullOrEmpty
?
1
2
3
4
value is null.
value is blank but not null.
value is " "
value is "hello me!"


比较String地址相等

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
package com;
 
public class A
{
 
  /**
   * @param args
   */
  public static void main(String[] args)
  {
 
    String a = "hello";
    String b = "he";
    String c = a.substring(0, 2);
    System.out.println(b.equals(c));//true
    System.out.println(b==c);//false
     
    String d = new String("hello");
    System.out.println(d.equals(a));//true
    System.out.println(d==a);//false
     
    String e = new StringBuilder("hello").toString();
    System.out.println(e.equals(a));//true
    System.out.println(e==a);//false
     
    System.out.println(e.equals(d));//true
    System.out.println(e==d);//false
     
    String f = "hello";
    System.out.println(f.equals(a));//true
    System.out.println(f==a);//true
    System.out.println(f=="hello");//true
    System.out.println(f=="hell"+"o");//true
     
    String g = b+"llo";
    System.out.println(g==f);//false
     
    String h = "he"+"llo";
    System.out.println(h==f);//true
  }
 
}

总结:

1.new出来的String是重新分配内存,字符串不共享,new出来的多个之间也不共享。

2.通过字符串函数操作拼接或者截取到的字符串跟静态字符串变量也是不共享的。

3.通过加号得到的字符串有两种情况。

A   "he"+"llo"是静态字符串,是共享的
B   String a = "He";  a+"llo"不是静态字符串,是不共享的