e.getMessage 為空NULL

e.getMessage 為空NULL

在日常代碼中免不了要try catch

切忌用try catch 去try 整個方法。

在對象操作之前盡量寫上if 空判斷。

反例:

public void send(){

  try{

    代碼1:獲取對象

    代碼2:操作代碼1

    代碼3:操作代碼2

    代碼4:操作代碼3

  } catch(Exception e){

    log.error("異常信息:,{}",e.getMessage());

   // 這里會打一個null 誤以為沒有抓到錯誤信息。其實是你某一條代碼中出現了空對象 。進行了對象操作。

  //如果在代碼 2,3,4任何一個地方出現一個空對象并不進行空處理。就會出來這樣的情況

  }

}

正例:

public Object send(){

    代碼1:獲取對象

    if(代碼1 == null ){

      代碼1 = new 代碼1();

    }

    代碼2:操作代碼1

    代碼3:操作代碼2

 ? ?try{

    代碼4:操作代碼3

    retrun 代碼4;

  } catch(Exception e){

    log.error("代碼4異常:,{}",e.getMessage());

  }

  return null;

}

在try catch 的時候 。盡量的縮小范圍。好定位問題。對象一定要做空判斷 。

不要一上來就全部try .

這種排錯。直接把try catch 去掉。直接讓錯誤拋控制臺。就知道是哪一行了。

再改成代碼 再補上try catch 加上日志記錄就行了。?

posted on 2018-09-24 22:02 zhouixi 閱讀(...) 評論(...) 編輯 收藏

轉載于:https://www.cnblogs.com/1-Admin/p/9696917.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/250607.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/250607.shtml
英文地址,請注明出處:http://en.pswp.cn/news/250607.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Linux:客戶端的實現

寫了一個簡單的服務器軟件,但是沒有寫客戶端。現在我將客戶端實現了,其實昨天已經說了客戶端的實現步驟了。 步驟: socket() 初始化 connet()鏈接 從標準輸入讀數據fgets() 傳數據到服務器write() 讀從服務器返回的數據read() 寫數據到屏幕上…

vue --- http攔截,登錄登出的邏輯設計

設計 在src目錄下創建一個interceptor.js登錄邏輯 設置攔截,在發起請求前,先判斷用戶是否登錄(在本栗中,即是否能夠在瀏覽器緩存中找到token). 登出邏輯 對服務端傳過來的數據進行攔截,判斷其狀態碼是否為401(未登錄或token過期)清空瀏覽器緩存中的token重定向到登入頁面 inte…

循環分支循環語句

# 三大結構 - 循環 - 分支 - 循環 . . .In [ ]:# 分支 - 分支的基本語法 - if 條件表達式: 語句1 語句2 語句3 ..... - 條件表達式就是計算結果必須是布爾值的表達式 - 表達式后面的冒號覺對不能少 - 注意 if 后面出現的語句,如果屬于 if 語句塊&…

HTTP 1.1與HTTP 1.0的比較

HTTP 1.1與HTTP 1.0的比較 一個WEB站點每天可能要接收到上百萬的用戶請求,為了提高系統的效率,HTTP 1.0規定瀏覽器與服務器只保持短暫的連接,瀏覽器的每次請求都需要與服務器建立一個TCP連接,服務器完成請求處理后立即斷開TCP連接…

vue --- 前端代理發送http請求

后端 端口在3000使用jsonwebtoken和koa-jwt生成令牌并返回對’/api/userinfo’端口,先驗證令牌是否通過,若通過返回數據 const Koa require(koa); const Router require(koa-router); // 生成令牌、驗證令牌 const jwt require(jsonwebtoken); const jwtAuth require(koa…

python全棧開發-json和pickle模塊(數據的序列化)

一、什么是序列化? 我們把對象(變量)從內存中變成可存儲或傳輸的過程稱之為序列化,在Python中叫pickling,在其他語言中也被稱之為serialization,marshalling,flattening等等,都是一個意思。 為什么要序列化…

Gale-Shapley---婚姻匹配算法算法

原文鏈接:http://blog.csdn.net/cscmaker/article/details/8291131 (一)問題的引出: 有N男N女,每個人都按照他對異性的喜歡程度排名。現在需要寫出一個算法安排這N個男的、N個女的結婚,要求兩個人的婚姻應該…

大數據排重

注意用來排重的那個集合放到Set中, 可以是HashSet,或者其他Set(推薦使用HashSet),因為Set的contains效率更高,比list高很多 -----------------------------------------------------------------------------------------------------------------------…

大前端成長路徑

路徑(持續更新): 以下是我不同時期的博客鏈接可以和我的GitHub共同食用大家可以對比一下,我學的過程是緩慢型的… learning: 0個月 2018年09月開始接觸前端,前端三劍客一個不知道一個不懂,于是對著W3C、菜鳥教程.一個一個敲開始啃紅寶書《JavaScript高級程序設計》(第3版) le…

工具:meson+ninja(安裝問題解決)

問題1:Python版本問題 報錯信息: NOTICE: You are using Python 3.6 which is EOL. Starting with v0.62.0, Meson will require Python 3.7 or newer ubuntu 18默認的python3是3.6. 解決方案1:從源碼安裝python 3.7 wget https://www.pyth…

ListMapSet的操作和遍歷

List&Map&Set的操作和遍歷 Java的三大集合即:Set、List、Map。 Set:代表無序、不可重復的集合,常用的有HashSet(哈希表實現)、TreeSet(紅黑樹實現);List:代表有序…

PHP中的魔術方法

概述 在面向對象編程中,PHP提供了一系列的魔術方法,這些魔術方法為編程提供了很多便利。PHP中的魔術方法通常以__(兩個下劃線)開始,并且不需要顯示的調用而是由某種特定的條件出發。這篇文章簡單總結了PHP中提供的魔術方法。 開始之前 在總結…

執行caffe的draw_net.py出現“GraphViz's executable dot not found”的解決方法

執行caffe的draw_net.py出現“GraphVizs executable "dot" not found”的解決方法 控制臺輸入如下指令畫網絡圖:python ../../../python/draw_net.py train.prototxt train.png --rankdirTB (Top-Bottom形式,縱向圖)pyt…

配置 --- vscode自定義代碼段Snippets

目標 在vscode中輸入vbs-vue 然后產生一個自己想要的模板 寫好模板 在線上寫好模板傳送門: https://snippet-generator.app/ 1是標題,對應 2是前綴.對應在vue中使用的快捷鍵 vbs-vue3就是需要顯示的代碼段了 在vscode中配置 1.ctrlshiftp2.選擇 Preferences: Configure U…

centos6安裝composer

需要使用到curl,沒有的話需要 yum -y install curl ###安裝一、下載:curl -sS https://getcomposer.org/installer | php (如果是網絡原因多試幾次) 二、移動composer.phar移動到環境下讓其變成可執行:mv compose…

透明圖與元素居中

1,定位讓元素居中 1. 透明度 opacity 默認值是1 不透明 0是全透明轉載于:https://www.cnblogs.com/Shinigami/p/9709382.html

配置 --- vscode中react格式化解決方案

選擇右下角的語言 在彈出框搜react選擇 JavaScript React(或者根據需求選擇 TypeScript React) 快捷鍵, windows下 Alt SHIFT F

【商城購物車】購物車邏輯

轉載于:https://www.cnblogs.com/xuzhengzong/p/8746677.html

PHP遞歸實現無限極分類

PHP遞歸實現無限極分類 摘要 今天在編碼的時候要用到二級的欄目分類,所以順便就把無限極分類給整理了一下,采用的是遞歸方法 //實現無限級分類public function getTree(){$categorys Category::all();return $this->makeTree($categorys, cate_id,…

IO NIO

1,Java NIO Java non-blocking IO 即 非阻塞IO,線程在等待的時候,可以做其他的事情。 2,IO 對比NIO IO 是面向流,NIO 是面向緩沖 面向流是指每次從流中讀出一個或者多個字節,直到全部讀出為止 面向緩沖區是指將數據先存到一個緩存區 IO 是阻…