1. if(username.equals(“zxx”){}
2. int x = 1;
return x==1?true:false;1.一个变量直接调用equals方法会给程序带来安全隐患,直接调用equals方法可能会抛出NullPointerException异常。为了防止程序抛出异常在调用equals方法之前要先判断一下是否为空。
if( username!=null && username.equals(“zxx”){}这样写才完整。
public class Test12 {
public static String username;
public static void main(String[] args) {
/*if(username.equals("zxx")){
System.out.println("haha"); false Exception in thread "main" java.lang.NullPointerException
}*/ at zhongqiu.test.Test12.main(Test12.java:6)
/*if( username!=null && username.equals("zxx")){
System.out.println("haha"); true
}*/
if( "ss".equals(username)){
System.out.println("haha"); true
}
}
}username有可能为null,就会抛出空指针异常,
更好的写法是: if("zxx".equals(username){} ,
username.equals();如果username是空的话,系统就不认他是一个string,此时调用equals就报错了。
但是把string作为参数的话,是没有问题的
2,第二个 return x==1?true:false 这样写纯属多余
因为 x==1已经是个布尔值了。所以去掉"?true:false",保证程序的简洁
本文探讨了Java编程中常见的安全问题,特别是对字符串进行比较时如何避免NullPointerException。通过具体示例展示了正确的equals方法使用方式,并强调了代码简洁的重要性。

被折叠的 条评论
为什么被折叠?



