日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

好难!打个日志还能打出一个bug,语塞...

發(fā)布時(shí)間:2024/8/26 编程问答 46 豆豆
生活随笔 收集整理的這篇文章主要介紹了 好难!打个日志还能打出一个bug,语塞... 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

某日中午,收到告警,有一筆訂單下單失敗了。趕緊去Cat看了下錯(cuò)誤信息,如下:
Web應(yīng)用調(diào)用訂單服務(wù)的RPC接口報(bào)錯(cuò)了,一看錯(cuò)誤很自主的認(rèn)為這是一個(gè)序列化的問題。后面排查下來發(fā)現(xiàn)壓根就不是,這個(gè)錯(cuò)誤報(bào)的有點(diǎn)。。。

想著是不是參數(shù)中有什么特別的東西,然后發(fā)現(xiàn)也沒有什么特別的。這個(gè)錯(cuò)誤是某個(gè)商品下單才會出現(xiàn),不是所有的商品都會出現(xiàn)這個(gè)問題。

然后嘗試在本地復(fù)現(xiàn),有這么一行關(guān)鍵的代碼,貼了一部分,完整的作用是埋點(diǎn)打日志。

String.format("UnifiedOrderServiceImpl.makeOrder創(chuàng)建訂單, make order, request: MakeOrderRequest= "+ request)

說實(shí)話我是沒看懂這里用String.format的原因在哪里,不就是想拼接個(gè)字符串么?還搞個(gè)format,搞就搞嘛,還沒用占位符,騷操作。

真正Bug的原因是request對象中有個(gè)String類型的字段,字段里面的內(nèi)容有%\,format內(nèi)部就報(bào)錯(cuò)了,大家可以用下面這段代碼復(fù)現(xiàn)錯(cuò)誤:

public static void main(String[] args) {String.format("dsdsdsd"+"%\\sdsd"); }

錯(cuò)誤信息:

Exception in thread "main" java.util.UnknownFormatConversionException: Conversion = '\'

原因是在format中會校驗(yàn)參數(shù),然后觸發(fā)了異常。

好難!打個(gè)日志還能打出一個(gè)bug,語塞…


雖然是很小的改動,就記錄個(gè)日志而已,但也不要輕視,往往就是不夠仔細(xì),然后才會出這種問題。

總結(jié):

  • 認(rèn)真對待每一行代碼
  • 做好code review

總結(jié)

以上是生活随笔為你收集整理的好难!打个日志还能打出一个bug,语塞...的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。