ホームページ  >  記事  >  Java  >  リストが原因で例外が発生しました すべての要素が null

リストが原因で例外が発生しました すべての要素が null

巴扎黑
巴扎黑オリジナル
2017-06-26 10:22:048115ブラウズ

ArrayList では null 値を追加できます。これにより、リスト内のオブジェクトを変換するときに java.lang.NullPointerException 例外が発生しやすくなります。

シナリオ:

データベースは、1=2 のユーザーからの id として min(id)、名前として min(name) を選択します。

クエリ結果はレコードがないのではなく、null、null レコードとなり、結果は次のようになります。ユーザーオブジェクトはnullです

List users = useDao.find(xxx); //size=1,すべての要素はnullです

このとき、ユーザーオブジェクトを操作するとエラーが報告されます。

解決策

方法 1: null 要素を削除する

例:

 List<User> users = new ArrayList<User>();
        users.add(null);
        users.add(null);
        users.add(null);
        System.out.println("size:"+users.size()); //size:3for(User user:users){try {
                System.out.println("id:" + user.getId() + ",name:" + user.getName());
            }catch (Exception ex){
                System.out.println(ex); //java.lang.NullPointerException            }
        }users.remove(null); //移除第一个nullSystem.out.println("size:"+users.size()); //size:2    users.removeAll(Collections.singleton(null)); //移除所有的null元素System.out.println("size:"+users.size()); //size:0//不会进入循环for(User user:users){try {
                System.out.println("id:" + user.getId() + ",name:" + user.getName());
            }catch (Exception ex){
                System.out.println(ex);
            }
        }

<span style="font-size: 14px">法二:保证数据库查询出来没有null值,即遇null值转换为默认值<br><br><br></span><span style='font-family: "Microsoft YaHei"'>mysql下使用ifnull/case when均可实现</span><br><span style='font-family: "Microsoft YaHei"'>select  ifnull(min(id),-1) as id,ifnull(min(name),'defaultName') as name from user where 1=2;</span>
(有group by是分组统计,找不到记录就是没有记录)
rree
 <br>

以上がリストが原因で例外が発生しました すべての要素が nullの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。