專案中遇到的NullPointerException 分兩種情況:
1. 引用空對象,即呼叫空對象的方法或引用空對象的屬性。
2. 將8中基礎型別的封裝類別賦值給對應的基礎類別。
1.對於別人介面的回傳對像要做非空判斷,因為我們不清楚得到的對象會不會為空,對於Collection Map 我通常會呼叫CollectionUtils MapUtils ,對於傳回的String對象,我會調StringUtils.isNotEmpty( )進行非空判斷。他們中isNotEmpty不僅判斷了NULL 還判斷了空集合和空串。例如從資料中查詢的結果。工作流程中傳回的定價URL
2. 對於自己創建的對象,要留心對象進行哪些操作,中間會不會造成對象為空,如果可能加非空判斷,尤其是對於集合的操作,很容易就報空指針! ! !所以每次對操作集合時,我都會非常的留心。
3. 對於前台的領域物件要非常的留心,因為這些物件是框架創建的,假如我沒有在前台的文字方塊內輸入值,雖然提交時後台獲得的是空串,但發生NullPointerException的機率很高。
4. 對於String 的操作盡量使用apache 的StringUtils類,與String相比這個是非常的安全。對於集合的操作使用apache的CollectionUtils 、MapUtils, 相比apache工具類別的執行效率也非常的高,例如StringUtils.split();
有人說過多的判斷會影響效能,我個人認為這裡的效能犧牲和系統的安全相比是微不足道的。