java.lang.NullPointerException異常的幾種原因及解決方案
java.lang.NullPointerException是java編程中最常見的異常之一。任何使用java的人都有在java程序以及java web應(yīng)用程序中看到java.lang.NullPointerException異常。

NullPointerException是一個(gè)運(yùn)行時(shí)異常,因此不需要在程序中捕獲它。
當(dāng)嘗試在null對象上執(zhí)行某些操作時(shí),會在應(yīng)用程序中引發(fā)NullPointerException異常。以下是在java程序中發(fā)生NullPointerException異常的一些常見原因 -
- 在對象實(shí)例上調(diào)用方法,但在運(yùn)行時(shí)對象為
null。 - 訪問在運(yùn)行時(shí)為
null的對象實(shí)例的變量。 - 在程序中拋出
null。 - 訪問索引或修改索引的數(shù)組為
null。 - 檢查在運(yùn)行時(shí)為
null的數(shù)組的長度。
該文主要介紹了 java.lang.NullPointerException 出現(xiàn)的幾種原因及解決方案 , 本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
在Java編程中,NullPointerException是一個(gè)常見的運(yùn)行時(shí)異常,其發(fā)生原因可能包括:
避免Java編程中NullPointerException異常的方法包括:
1. 初始化字符串變量。
2. 使用具體的類對接口類型的對象進(jìn)行初始化。
3. 在對象為空時(shí)進(jìn)行判空處理。
4. 避免將null值用于字符串比較。
5. 使用String.valueOf()方法代替toString()方法以避免引用為null時(shí)拋出NullPointerException異常。
6. 實(shí)例化class類型對象后再進(jìn)行調(diào)用。
7. 返回值可以定義為數(shù)組,以避免返回null值引起NullPointerException異常。
因此,我們在編程中應(yīng)該盡量避免出現(xiàn)以上的情況,保證程序的健壯性和穩(wěn)定性。對于不可避免的情況,我們應(yīng)該進(jìn)行判空處理,或者采用安全的編程習(xí)慣,以確保代碼的正確性和穩(wěn)定性。
NullPointerException是Java中的一個(gè)運(yùn)行時(shí)異常,它通常發(fā)生在嘗試訪問空引用(即未分配內(nèi)存空間的變量)的情況下。當(dāng)你嘗試對一個(gè)空對象進(jìn)行操作時(shí),程序就會拋出NullPointerException異常。
為了避免這種異常的發(fā)生,我們可以在使用之前先進(jìn)行null值檢查(即判空),或者給變量分配好內(nèi)存空間并賦予初值。
比如在判斷一個(gè)String類型的實(shí)例s是否等于“a”時(shí),應(yīng)該寫成"a".equals(s),而不是s.equals("a"),因?yàn)榍罢吣軌虮苊鈙為空的情況,從而避免NullPointerException的發(fā)生。
同樣地,在方法的返回值中,可以將返回類型定義為數(shù)組,以避免返回null值的情況。如果需要返回空值,則可以返回一個(gè)空數(shù)組。
綜上所述,避免NullPointerException的關(guān)鍵是要對變量進(jìn)行充分的判空和初始化處理,盡量避免使用null值,以及采用安全的編程習(xí)慣來規(guī)避這種異常。
java程序中NullPointerException異常的一些例子。
1. 調(diào)用實(shí)例方法時(shí)出現(xiàn)NullPointerException
示例代碼如下
public class Temp {
public static void main(String[] args) {
Temp t = initT();
t.foo("Hi");
}
private static Temp initT() {
return null;
}
public void foo(String s) {
System.out.println(s.toLowerCase());
}
}當(dāng)運(yùn)行上面的程序時(shí),它會拋出NullPointerException異常錯(cuò)誤消息。
Exception in thread "main" java.lang.NullPointerException
at Temp.main(Temp.java:7)
在語句t.foo("Hi")中拋出NullPointerException異常; 因?yàn)?code>t在這里為null。
2. 訪問/修改null對象的字段時(shí)出現(xiàn)NullPointerException
示例代碼 -
public class Temp {
public int x = 10;
public static void main(String[] args) {
Temp t = initT();
int i = t.x;
}
private static Temp initT() {
return null;
}
}執(zhí)行上面示例代碼,得到以下結(jié)果 -
Exception in thread "main" java.lang.NullPointerException
at Temp.main(Temp.java:9)
語句int i = t.x中拋出NullPointerException異常; 因?yàn)?t在這里為null。
3. 在方法參數(shù)中傳遞null時(shí)NullPointerException
示例代碼 -
public class Temp {
public static void main(String[] args) {
foo(null);
}
public static void foo(String s) {
System.out.println(s.toLowerCase());
}
}這是java.lang.NullPointerException最常見的情況之一,因?yàn)樗鼈鬟fnull參數(shù)給調(diào)用者。
4. 拋出null時(shí)拋出java.lang.NullPointerException
示例代碼
public class Temp {
public static void main(String[] args) {
throw null;
}
}下面是上面程序的異常堆棧跟蹤,由于throw null所以拋出NullPointerException異常。
Exception in thread "main" java.lang.NullPointerException
at Temp.main(Temp.java:5)
5. 獲取null數(shù)組的長度時(shí)拋出java.lang.NullPointerException
public class Temp {
public static void main(String[] args) {
int[] data = null;
int len = data.length;
}
}執(zhí)行上面示例代碼,得到以下結(jié)果 -
Exception in thread "main" java.lang.NullPointerException
at Temp.main(Temp.java:7)
6. 訪問null數(shù)組的索引值時(shí)出現(xiàn)NullPointerException
示例代碼 -
public class Temp {
public static void main(String[] args) {
int[] data = null;
int len = data[2];
}
}執(zhí)行上面示例代碼,得到以下結(jié)果 -
Exception in thread "main" java.lang.NullPointerException
at Temp.main(Temp.java:7)
7. 在null對象上同步時(shí)出現(xiàn)java.lang.NullPointerException
public class Temp {
public static String mutex = null;
public static void main(String[] args) {
synchronized(mutex) {
System.out.println("synchronized block");
}
}
}synchronized(mutex)將拋出NullPointerException,因?yàn)?code>mutex對象為null。
8. java.lang.NullPointerException引發(fā)HTTP狀態(tài)500
有時(shí)會將錯(cuò)誤頁面作為java Web應(yīng)用程序響應(yīng)發(fā)送,錯(cuò)誤消息為“HTTP狀態(tài)500 - 內(nèi)部服務(wù)器錯(cuò)誤”,根本原因就是java.lang.NullPointerException異常。
下面是一段編輯了Spring MVC Example項(xiàng)目并更改了HomeController方法,如下所示。
@RequestMapping(value = "/user", method = RequestMethod.POST)
public String user(@Validated User user, Model model) {
System.out.println("User Page Requested");
System.out.println("User Name: "+user.getUserName().toLowerCase());
System.out.println("User ID: "+user.getUserId().toLowerCase());
model.addAttribute("userName", user.getUserName());
return "user";
}下圖顯示了Web應(yīng)用程序響應(yīng)引發(fā)的錯(cuò)誤消息。

異常堆棧跟蹤
HTTP Status 500 – Internal Server Error
Type Exception Report
Message Request processing failed; nested exception is java.lang.NullPointerException
Description The server encountered an unexpected condition that prevented it from fulfilling the request.
Exception
org.springframework.web.util.NestedServletException: Request processing failed; nested exception is java.lang.NullPointerException
org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:982)
org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:872)
javax.servlet.http.HttpServlet.service(HttpServlet.java:661)
org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846)
javax.servlet.http.HttpServlet.service(HttpServlet.java:742)
org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
Root Cause
java.lang.NullPointerException
com.journaldev.spring.controller.HomeController.user(HomeController.java:38)
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
java.lang.reflect.Method.invoke(Method.java:498)根本原因是語句user.getUserId().toLowerCase()中引發(fā)了NullPointerException,因?yàn)?code>user.getUserId()返回null。
如何檢測java.lang.NullPointerException?
檢測NullPointerException非常簡單,只需查看異常跟蹤,它將顯示異常的類名和行號。然后查看代碼并查看可能為null。只要看一下上面的所有例子,從堆棧跟蹤中可以清楚地看出是什么導(dǎo)致了null指針異常。
如何修復(fù)java.lang.NullPointerException異常
java.lang.NullPointerException是一個(gè)未經(jīng)檢查的異常,因此不必捕獲它。通常可以使用空檢查和預(yù)防性編碼技術(shù)來防止空指針異常。請看下面的代碼示例,演示如何避免java.lang.NullPointerException異常。
示例1
if(mutex ==null) mutex =""; //preventive coding
synchronized(mutex) {
System.out.println("synchronized block");
}示例2
//using null checks
if(user!=null && user.getUserName() !=null) {
System.out.println("User Name: "+user.getUserName().toLowerCase());
}
if(user!=null && user.getUserName() !=null) {
System.out.println("User ID: "+user.getUserId().toLowerCase());
}避免java.lang.NullPointerException的最佳編碼實(shí)踐
1 . 考慮下面的代碼示例。
public void foo(String s) {
if(s.equals("Test")) {
System.out.println("test");
}
}2 . 現(xiàn)在,如果將null作為s參數(shù)的值傳遞,則會發(fā)生NullPointerException異常??梢匀缦戮帉懴嗤姆椒ㄒ员苊?code>NullPointerException。
public void foo(String s) {
if ("Test".equals(s)) {
System.out.println("test");
}
}3 . 需要為參數(shù)添加null檢查,并在需要時(shí)拋出IllegalArgumentException異常。
public int getArrayLength(Object[] array) {
if(array == null) throw new IllegalArgumentException("array is null");
return array.length;
}4 . 使用三元運(yùn)算符,如下面的示例代碼所示。
String msg = (str == null) ? "" : str.substring(0, str.length()-1);
5 . 使用String.valueOf()而不是toString()方法。例如,檢查PrintStream println()方法代碼定義如下。
public void println(Object x) {
String s = String.valueOf(x);
synchronized (this) {
print(s);
newLine();
}
}6 . 下面顯示了使用valueOf()方法而非toString()的示例。
Object mutex = null;//prints nullSystem.out.println(String.valueOf(mutex));//will throw java.lang.NullPointerExceptionSystem.out.println(mutex.toString());
7 . 寫入方法盡可能返回空對象而不是null,例如空列表,空字符串等。
8 . 應(yīng)該使用在集合類中定義了一些用來避免NullPointerException的方法。例如
contains(),containsKey()和containsValue()。
這是關(guān)于java中的NullPointerException異常的所有情況。希望它能幫助您編寫更好的代碼,以盡可能避免java.lang.NullPointerException異常。
到此這篇關(guān)于java.lang.NullPointerException異常的幾種原因及解決方案的文章就介紹到這了,更多相關(guān)java.lang.NullPointerException異常內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
idea手動(dòng)導(dǎo)入了包但編譯運(yùn)行還是報(bào)找不到xxx.jar包的解決方案
這篇文章主要介紹了idea手動(dòng)導(dǎo)入了包但編譯運(yùn)行還是報(bào)找不到xxx.jar包的解決方案,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-03-03
為什么程序中突然多了 200 個(gè) Dubbo-thread 線程的說明
這篇文章主要介紹了為什么程序中突然多了 200 個(gè) Dubbo-thread 線程的說明,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09
Springboot使用redis實(shí)現(xiàn)接口Api限流的實(shí)例
本文介紹的內(nèi)容如題,就是利用redis實(shí)現(xiàn)接口的限流(某時(shí)間范圍內(nèi),最大的訪問次數(shù)),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07
Java foreach循環(huán)是否可以修改數(shù)據(jù)的值問題解決方法
最近在做項(xiàng)目的時(shí)候,需要修改一個(gè)數(shù)組里面各個(gè)元素的值,foreach循環(huán)迭代數(shù)組元素時(shí),不能改變數(shù)組元素的值,這篇文章給大家介紹Java foreach循環(huán)是否可以修改數(shù)據(jù)的值的問題及解決方法,感興趣的朋友一起看看吧2024-02-02
springboot3環(huán)境隔離的實(shí)現(xiàn)
在開發(fā)中,環(huán)境很多,本文主要介紹了springboot3環(huán)境隔離的實(shí)現(xiàn),能夠快速切換開發(fā)、測試、生產(chǎn)環(huán)境,具有一定的參考價(jià)值,感興趣的可以了解一下2024-03-03
詳細(xì)聊聊SpringBoot中動(dòng)態(tài)切換數(shù)據(jù)源的方法
在大型分布式項(xiàng)目中,經(jīng)常會出現(xiàn)多數(shù)據(jù)源的情況,下面這篇文章主要給大家介紹了關(guān)于SpringBoot中動(dòng)態(tài)切換數(shù)據(jù)源的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2021-09-09

