Rumah Java javaTutorial list All elements are null引起的异常

list All elements are null引起的异常

Jun 26, 2017 am 10:22 AM
list null tidak normal sebab

ArrayList允许添加null值,就容易造成了list内的对象转换出现java.lang.NullPointerException异常。

 

场景:

数据库 select  min(id) as id,min(name) as name from user where 1=2;

查询出的不是没有记录,而是一条 null,null这样的记录,导致User对象为null

List users = useDao.find(xxx); //size=1,All elements are null

这时候对user对象操作就会报错!

 

解决办法

法一:移除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);
            }
        }
Salin selepas log masuk

 

<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>
Salin selepas log masuk
(有group by是分组统计,找不到记录就是没有记录)
Salin selepas log masuk
 <br>
Salin selepas log masuk
<span style="font-size: 14px"><em><br><br></em></span>
Salin selepas log masuk

Atas ialah kandungan terperinci list All elements are null引起的异常. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk menyelesaikan pengecualian tamat masa gangguan thread Java (ThreadInterruptedTimeoutExceotion) Bagaimana untuk menyelesaikan pengecualian tamat masa gangguan thread Java (ThreadInterruptedTimeoutExceotion) Aug 18, 2023 pm 01:57 PM

Cara menyelesaikan pengecualian tamat masa gangguan benang Java (ThreadInterruptedTimeoutException Dalam pengaturcaraan berbilang benang Java, kita sering menghadapi situasi di mana masa pelaksanaan benang terlalu lama. Untuk mengelakkan utas daripada menduduki terlalu banyak sumber sistem, kami biasanya menetapkan tamat masa Apabila masa pelaksanaan utas melebihi tamat masa, kami berharap dapat mengganggu pelaksanaan utas. Java menyediakan mekanisme gangguan benang Dengan memanggil kaedah interrupt() benang, anda boleh

Kaedah untuk menyelesaikan pengecualian refleksi Java (ReflectiveOperationException) Kaedah untuk menyelesaikan pengecualian refleksi Java (ReflectiveOperationException) Aug 26, 2023 am 09:55 AM

Kaedah untuk menyelesaikan pengecualian pantulan Java (ReflectiveOperationException) Dalam pembangunan Java, pantulan (Refleksi) ialah mekanisme berkuasa yang membolehkan atur cara memperoleh dan mengendalikan kelas secara dinamik, objek, kaedah, sifat, dsb. pada masa jalan. Melalui refleksi, kita boleh melaksanakan beberapa fungsi fleksibel, seperti mencipta objek secara dinamik, memanggil kaedah persendirian, mendapatkan anotasi kelas, dsb. Walau bagaimanapun, menggunakan refleksi juga membawa beberapa potensi risiko dan masalah, salah satunya adalah anomali refleksi (

Panduan misi luar biasa Ronin Rise Pool Panduan misi luar biasa Ronin Rise Pool Mar 26, 2024 pm 08:06 PM

Keabnormalan dalam kolam adalah tugas sampingan dalam permainan tugasan dan siasat punca bau busuk Kemudian, kami dapati Ternyata terdapat banyak mayat di bawah kolam. Panduan untuk misi luar biasa dalam Kolam Bangkit Ronin: 1. Bercakap dengan Iizuka dan pelajari teknik menembak di dalam air. 2. Pergi ke lokasi dalam gambar di bawah untuk menerima tugas yang tidak normal di kolam. 3. Pergi ke lokasi misi dan bercakap dengan NPC, dan ketahui bahawa terdapat bau busuk di kolam berdekatan. 4. Pergi ke kolam untuk menyiasat. 5. Berenang ke lokasi dalam gambar di bawah, menyelam dalam air, dan anda akan menemui banyak mayat. 6. Gunakan kamera untuk mengambil gambar mayat. 7

Karya terbaharu MIT: menggunakan GPT-3.5 untuk menyelesaikan masalah pengesanan anomali siri masa Karya terbaharu MIT: menggunakan GPT-3.5 untuk menyelesaikan masalah pengesanan anomali siri masa Jun 08, 2024 pm 06:09 PM

Hari ini saya ingin memperkenalkan kepada anda artikel yang diterbitkan oleh MIT minggu lepas, menggunakan GPT-3.5-turbo untuk menyelesaikan masalah pengesanan anomali siri masa, dan pada mulanya mengesahkan keberkesanan LLM dalam pengesanan anomali siri masa. Tiada penalaan dalam keseluruhan proses, dan GPT-3.5-turbo digunakan secara langsung untuk pengesanan anomali Inti artikel ini ialah cara menukar siri masa kepada input yang boleh dikenali oleh GPT-3.5-turbo, dan cara mereka bentuk. gesaan atau saluran paip untuk membenarkan LLM menyelesaikan tugas pengesanan anomali. Izinkan saya memperkenalkan karya ini kepada anda secara terperinci. Tajuk kertas imej: Largelanguagemodelscanbezero-shotanomalydete

Petua praktikal untuk menyelesaikan pengecualian pembacaan fail besar Java dengan cekap Petua praktikal untuk menyelesaikan pengecualian pembacaan fail besar Java dengan cekap Feb 21, 2024 am 10:54 AM

Petua praktikal untuk menyelesaikan pengecualian bacaan fail besar dengan cekap dalam Java memerlukan contoh kod khusus: Apabila memproses fail besar, Java mungkin menghadapi masalah seperti limpahan memori dan kemerosotan prestasi. Artikel ini akan memperkenalkan beberapa teknik praktikal untuk menyelesaikan pengecualian pembacaan fail besar Java dengan berkesan dan memberikan contoh kod khusus. Latar Belakang: Apabila memproses fail besar, kita mungkin perlu membaca kandungan fail ke dalam memori untuk diproses, seperti carian, analisis, pengekstrakan dan operasi lain. Walau bagaimanapun, apabila fail besar, masalah berikut sering dihadapi: Limpahan memori: cuba menyalin keseluruhan fail sekaligus

Bagaimana untuk menyelesaikan pengecualian tetapan semula sambungan rangkaian Java (ConnectionResetException) Bagaimana untuk menyelesaikan pengecualian tetapan semula sambungan rangkaian Java (ConnectionResetException) Aug 26, 2023 pm 07:57 PM

Cara menyelesaikan pengecualian tetapan semula sambungan rangkaian Java (ConnectionResetException) Apabila melakukan pengaturcaraan rangkaian Java, anda sering menghadapi pengecualian tetapan semula sambungan rangkaian (ConnectionResetException Pengecualian ini bermakna selepas sambungan diwujudkan, hos yang lain secara tidak sengaja menutup sambungan). Ini mungkin disebabkan oleh ranap sistem hos pihak lain, gangguan rangkaian atau konfigurasi tembok api. Apabila menulis aplikasi rangkaian, kita perlu mengendalikan pengecualian ini untuk memastikan program boleh berjalan seperti biasa

Pengecualian fungsi C++ dan ujian tunggal: memastikan kekukuhan kod Pengecualian fungsi C++ dan ujian tunggal: memastikan kekukuhan kod May 03, 2024 am 09:18 AM

Pengendalian pengecualian dan ujian unit adalah amalan penting untuk memastikan keteguhan kod C++. Pengecualian dikendalikan melalui blok cuba-tangkap, dan apabila kod melemparkan pengecualian, ia melompat ke blok tangkapan. Ujian unit mengasingkan ujian kod untuk mengesahkan bahawa pengendalian pengecualian berfungsi seperti yang diharapkan dalam keadaan yang berbeza. Kes praktikal: Fungsi sumArray mengira jumlah elemen tatasusunan dan membuang pengecualian untuk mengendalikan tatasusunan input kosong. Ujian unit mengesahkan kelakuan yang dijangkakan bagi fungsi dalam keadaan tidak normal, seperti membuang pengecualian std::invalid_argument apabila tatasusunan kosong. Kesimpulan: Dengan memanfaatkan pengendalian pengecualian dan ujian unit, kami boleh mengendalikan pengecualian, menghalang kod daripada ranap dan memastikan bahawa kod berkelakuan seperti yang diharapkan dalam keadaan tidak normal.

Apakah perbezaan antara null dan NULL dalam bahasa c Apakah perbezaan antara null dan NULL dalam bahasa c Sep 22, 2023 am 11:48 AM

Perbezaan antara null dan NULL dalam bahasa C ialah: null ialah definisi makro dalam bahasa C, biasanya digunakan untuk mewakili penunjuk nol, yang boleh digunakan untuk memulakan pembolehubah penunjuk, atau untuk menentukan sama ada penuding adalah nol dalam pernyataan bersyarat; NULL ialah definisi makro dalam bahasa C Pemalar yang dipratentukan dalam , biasanya digunakan untuk mewakili nilai nol, digunakan untuk mewakili penunjuk nol, tatasusunan penunjuk nol atau penunjuk struktur nol.

See all articles