C#代碼性能測(cè)試類(簡(jiǎn)單實(shí)用)
更新時(shí)間:2015年06月08日 09:52:39 投稿:junjie
這篇文章主要介紹了C#代碼性能測(cè)試類(簡(jiǎn)單實(shí)用),本文直接給出實(shí)現(xiàn)代碼和使用示例,需要的朋友可以參考下
介紹:
可以很方便的在代碼里循環(huán)執(zhí)行 需要測(cè)試的函數(shù) 自動(dòng)統(tǒng)計(jì)出執(zhí)行時(shí)間,支持多線程。
使用方法:
PerformanceTest p = new PerformanceTest();
p.SetCount(10);//循環(huán)次數(shù)(默認(rèn):1)
p.SetIsMultithread(true);//是否啟動(dòng)多線程測(cè)試 (默認(rèn):false)
p.Execute(
i =>
{
//需要測(cè)試的代碼
Response.Write(i+"<br>");
System.Threading.Thread.Sleep(1000);
},
message =>
{
//輸出總共運(yùn)行時(shí)間
Response.Write(message); //總共執(zhí)行時(shí)間:1.02206秒
}
);
源碼:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
namespace SyntacticSugar
{
/// <summary>
/// ** 描述:程序性能測(cè)試類
/// ** 創(chuàng)始時(shí)間:2015-5-30
/// ** 修改時(shí)間:-
/// ** 修改人:sunkaixuan
/// ** 使用說(shuō)明:tml
/// </summary>
public class PerformanceTest
{
private DateTime BeginTime;
private DateTime EndTime;
private ParamsModel Params;
/// <summary>
///設(shè)置執(zhí)行次數(shù)(默認(rèn):1)
/// </summary>
public void SetCount(int count)
{
Params.RunCount = count;
}
/// <summary>
/// 設(shè)置線程模式(默認(rèn):false)
/// </summary>
/// <param name="isMul">true為多線程</param>
public void SetIsMultithread(bool isMul)
{
Params.IsMultithread = isMul;
}
/// <summary>
/// 構(gòu)造函數(shù)
/// </summary>
public PerformanceTest()
{
Params = new ParamsModel()
{
RunCount = 1
};
}
/// <summary>
/// 執(zhí)行函數(shù)
/// </summary>
/// <param name="action"></param>
public void Execute(Action<int> action, Action<string> rollBack)
{
List<Thread> arr = new List<Thread>();
BeginTime = DateTime.Now;
for (int i = 0; i < Params.RunCount; i++)
{
if (Params.IsMultithread)
{
var thread = new Thread(new System.Threading.ThreadStart(() =>
{
action(i);
}));
thread.Start();
arr.Add(thread);
}
else
{
action(i);
}
}
if (Params.IsMultithread)
{
foreach (Thread t in arr)
{
while (t.IsAlive)
{
Thread.Sleep(10);
}
}
}
rollBack(GetResult());
}
public string GetResult()
{
EndTime = DateTime.Now;
string totalTime = ((EndTime - BeginTime).TotalMilliseconds / 1000.0).ToString("n5");
string reval = string.Format("總共執(zhí)行時(shí)間:{0}秒", totalTime);
Console.Write(reval);
return reval;
}
private class ParamsModel
{
public int RunCount { get; set; }
public bool IsMultithread { get; set; }
}
}
}
您可能感興趣的文章:
- 使用 BenchmarkDotNet 對(duì) C# 代碼進(jìn)行基準(zhǔn)測(cè)試
- C#建立測(cè)試用例系統(tǒng)的示例代碼
- 關(guān)于Unity C# Mathf.Abs()取絕對(duì)值性能測(cè)試詳解
- C#使用base64對(duì)字符串進(jìn)行編碼和解碼的測(cè)試
- C#使用String和StringBuilder運(yùn)行速度測(cè)試及各自常用方法簡(jiǎn)介
- 詳解C# WebApi 接口測(cè)試工具:WebApiTestClient
- c# 插入數(shù)據(jù)效率測(cè)試(mongodb)
- 京東聯(lián)盟C#接口測(cè)試示例分享
- C#/.Net 中快速批量給SQLite數(shù)據(jù)庫(kù)插入測(cè)試數(shù)據(jù)
- C#控制臺(tái)下測(cè)試多線程的方法
- c#測(cè)試反射性能示例
- c#測(cè)試本機(jī)sql運(yùn)算速度的代碼示例分享
- C# 單元測(cè)試全解析
相關(guān)文章
C#實(shí)現(xiàn)程序開機(jī)啟動(dòng)的方法
這篇文章主要介紹了C#實(shí)現(xiàn)程序開機(jī)啟動(dòng)的方法,涉及C#針對(duì)應(yīng)用程序及注冊(cè)表的相關(guān)操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06
C#中參數(shù)個(gè)數(shù)可變的方法實(shí)例分析
這篇文章主要介紹了C#中參數(shù)個(gè)數(shù)可變的方法,以一個(gè)簡(jiǎn)單實(shí)例分析了C#中參數(shù)個(gè)數(shù)可變的方法,主要是使用params關(guān)鍵字來(lái)實(shí)現(xiàn)的,是C#編程中比較實(shí)用的技巧,需要的朋友可以參考下2014-11-11
使用C#連接并讀取MongoDB數(shù)據(jù)庫(kù)
這篇文章介紹了使用C#連接并讀取MongoDB數(shù)據(jù)庫(kù)的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03
Unity Shader實(shí)現(xiàn)黑幕過(guò)場(chǎng)效果
這篇文章主要為大家詳細(xì)介紹了Unity Shader實(shí)現(xiàn)黑幕過(guò)場(chǎng)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07

