Stopwatch + C#列印日誌方法

来源:http://www.cnblogs.com/xiaoxiaoqiye/archive/2016/10/28/6009298.html
-Advertisement-
Play Games

列印一個介面、方法的運行時間在程式中是很容易遇到的一件事情;現在,我就分享一個我在工作中使用的臨時列印日誌的方法和結合 Stopwatch 列印測量某個時間間隔的運行時間的方法。 Stopwatch 實例可以很好的測量一個時間間隔的運行時間;以下例子是比較常用到的: 引用命名空間: using Sy ...


 

列印一個介面、方法的運行時間在程式中是很容易遇到的一件事情;現在,我就分享一個我在工作中使用的臨時列印日誌的方法和結合 Stopwatch 列印測量某個時間間隔的運行時間的方法。

Stopwatch 實例可以很好的測量一個時間間隔的運行時間;以下例子是比較常用到的:

引用命名空間: using System.Diagnostics;

Stopwatch//Stopwatch 實例

Start;//開始或繼續測量某個時間間隔的運行時間

Elapsed;//獲取當前實例測量得出的總運行時間(以時分秒為單位)

ElapsedMilliseconds;//獲取當前實例測量得出的總運行時間(以毫秒為單位)

Reset;//停止時間間隔測量,並將運行時間重置為零

Restart;//停止時間間隔測量,並將運行時間重置為零,然後開始測量運行時間

列印日誌方法,目錄也可以自己指定:

 1         public static void WriteError(string message)
 2         {
 3             string path = AppDomain.CurrentDomain.BaseDirectory;//獲取基目錄
 4             path = System.IO.Path.GetDirectoryName(path) + " \\ErrorLogs";//設置輸出日誌輸出目錄
 5             try
 6             {
 7                 if (!System.IO.Directory.Exists(path))
 8                 {
 9                     System.IO.Directory.CreateDirectory(path);
10                 }
11                 string fileName = System.IO.Path.Combine(path, DateTime.Now.ToString("yyyy-MM-dd") + ".log");
12                 System.IO.StreamWriter sw = new System.IO.StreamWriter(fileName, true);//文件流創建寫數據流
13                 sw.WriteLine(DateTime.Now.ToString("HH:mm:ss:fff") + " -------------------");
14                 sw.WriteLine(message);
15                 sw.WriteLine();
16                 sw.Close();//關閉寫數據流
17             }
18             catch
19             {
20             }
21         }

結合Stopwatch 使用列印測量某個時間間隔的運行時間的方法

1          var s = new Stopwatch();
2          //需要測試運行時間的的代碼
3          WriteError(s.ElapsedMilliseconds.ToString() + "  GetNewUpdateFileList");//列印運行時間
4 s.Reset();

註:方法為小七在工作中用到的方法,如果轉載,請註明出處;

     有不對或遺漏的地方,歡迎指出;

     歡迎評論;


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在js中對數組元素進行增刪改移,簡單總結了一下方法: 拼接兩個數組中的元素 (哪個數組在前面,拼接後它的元素就在前面) 把數組轉換為字元串 (將數組中的元素通過特殊符號鏈接成字元串) 把字元串轉為數組 (通過字元串的某個特定符號或者字母拆分為數組的元素) txtStr = "avbvcvdvevf" ...
  • using System; using System.Collections.Generic; using System.Linq; using System.Text; region / 試想一下,如果在一個類A繼承自介面B和C, 並且在B和C中包含具有相同簽名的成員, 那麼在類中實現該成員將導致 ...
  • 文檔目錄 本節內容: 簡介 關於 IAuditingStore 配置 通過特性啟用/禁用 註意 關於 IAuditingStore 簡介 維基百科:“一個審計追蹤(也叫審計日誌)是一個安全相關的時序記錄、記錄組、和/或記錄源和目標,作為任何時候一個特殊操作帶來影響的一序列活動的書面文件”。 ABP提 ...
  • 前言: 最近園子里ABP炒的火熱。看了幾篇對於ABP的介紹後,深感其設計精巧,實現優雅。個人感覺,ABP或ABP衍生品的架構設計,未來會成為中型Net項目的首選架構模式。如果您還不瞭解ABP是什麼,有什麼特色,請移步:《ABP集合帖》——http://www.cnblogs.com/kebinet/ ...
  • 有時候我們在做第三人稱游戲的時候,想讓相機平滑的跟隨物體移動,下麵這些代碼就能很快達到這個效果 ...
  • ...
  • 文檔目錄 本節內容: 簡介 關於 IFeatureValueStore 功能類型 Boolean 功能 Value 功能 定義功能 基本功能屬性 其它功能屬性 功能層次 檢查功能 使用RequiresFeature特性 RequiresFeature特性註意事項 使用 IFeatureChecker ...
  • UEditor For ASP.Net Core Use Qiniu 此項目為UEditor提供文件管理; 後端服務使用 ASP.Net Core; 使用七牛提供的雲存儲; 項目地址 http://git.oschina.net/joesjiang/BaiduEditorUseQiniu.NetCo ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...