【Java面试题】6 判断下面代码是否有问题

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",保证程序的简洁

posted @ 2018-03-14 17:03  十月围城小童鞋  阅读(214)  评论(0编辑  收藏  举报