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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

c语言中如何让诊断代码右移_如何检测和诊断生产中的慢代码

發布時間:2023/12/3 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 c语言中如何让诊断代码右移_如何检测和诊断生产中的慢代码 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

c語言中如何讓診斷代碼右移

開發人員面臨的更困難的任務之一是查找和診斷生產中運行緩慢的代碼。

首先,您如何監控生產代碼而不放慢速度? 當然,您無法通過分析器運行生產代碼。 即使您有計時代碼的機制,那么如何診斷問題呢? 如果您無法在開發環境中重現問題,則尤其如此。 理想情況下,您希望在生產中發生問題時得到通知,并向其提供足夠的信息,以便有合理的機會修復或至少診斷問題。

這是我的同事彼得·勞瑞 ( Peter Lawrey)建議的一種機制,您可以用來精確地做到這一點。 (完整的代碼清單可在此處找到)。

您要做的是創建一個Monitor類,如下所示:

public class Monitor implements Runnable{private final Thread thread;private final AtomicLong startTime = new AtomicLong(Long.MAX_VALUE);private final int thresholdMS;public Monitor(Thread thread, int thresholdMS){this.thread = thread;this.thresholdMS = thresholdMS;}public void reset(){startTime.set(System.currentTimeMillis());}@Overridepublic void run(){while(thread.isAlive()){long timeTaken = System.currentTimeMillis()-startTime.get();if(timeTaken > thresholdMS){System.out.println(timeTaken + "-------------------------");Stream.of(thread.getStackTrace()).forEach(System.out::println);}try {Thread.sleep(thresholdMS/2);} catch (InterruptedException e) {break;}}} }

如果線程無法在閾值時間內重置,則此類將轉儲正在運行的線程的堆棧跟蹤。

這是一些示例程序,演示如何調用Monitor。

Monitor monitor = new Monitor(Thread.currentThread(), 8); Thread thread = new Thread(monitor, "MonitorThread"); thread.setDaemon(true); thread.start();while(true) {monitor.reset();double x=0;for (int i = 0; i < 10_000; i++) {x += Math.sqrt(i);Logger.getLogger(getClass().getName()).fine("x=" + x);} }

Monitor觀察到了這一“關鍵”代碼。 如果在8毫秒內未重置監視器,它將轉儲代碼的堆棧跟蹤。

如果您有一個Monitor監視您的關鍵代碼段,則可以確保它們在給定的約束范圍內執行。 如果代碼確實違反了約束,則可以通過檢查堆棧跟蹤來很好地了解問題所在。 您還可以使用它來查看關鍵代碼在其運行期間未執行多少次。

如果沒有專用的備用CPU進行監視,則可以更改等待時間。 另外,您可能想更改等待策略以允許GC暫停,這會影響所有線程。 您可能想通過使用System.nanoTime()來細化計時,而不是以毫秒為單位。

翻譯自: https://www.javacodegeeks.com/2015/02/detect-diagnose-slow-code-production.html

c語言中如何讓診斷代碼右移

總結

以上是生活随笔為你收集整理的c语言中如何让诊断代码右移_如何检测和诊断生产中的慢代码的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。