本文记录对一些 Win32 方法进行 Benchmark 基准性能测试
本文非严谨测试,仅在我开发机器进行测试,没有在纯净系统和机器上进行测试
开始之前的说明:
本文使用的是 BenchmarkDotNet 进行测试,没有考虑 AOT 之后的调用性能,仅仅只是 Release 版本的 dotnet 程序的调用而已
数值单位说明:
1,000,000 纳秒(ns) = 1毫秒 (ms)
GetDoubleClickTime
性能: 396.2 ns
BenchmarkDotNet v0.14.0, Windows 11 (10.0.22631.4391/23H2/2023Update/SunValley3) 13th Gen Intel Core i7-13700K, 1 CPU, 24 logical and 16 physical cores .NET SDK 9.0.100 [Host] : .NET 9.0.0 (9.0.24.52809), X64 RyuJIT AVX2 DefaultJob : .NET 9.0.0 (9.0.24.52809), X64 RyuJIT AVX2
Method | Mean | Error | StdDev |
---|---|---|---|
Test | 396.2 ns | 14.32 ns | 41.53 ns |
测试代码如下
public class GetDoubleClickTimeTest
{
[Benchmark]
public void Test()
{
_ = GetDoubleClickTime();
}
public const string LibraryName = "user32";
/// <summary>
/// 获取鼠标双击事件两次点击的时间间隔
/// </summary>
/// <returns></returns>
[DllImport(LibraryName)]
public static extern uint GetDoubleClickTime();
}
以上代码放在 github 和 gitee 上,可以使用如下命令行拉取代码。我整个代码仓库比较庞大,使用以下命令行可以进行部分拉取,拉取速度比较快
先创建一个空文件夹,接着使用命令行 cd 命令进入此空文件夹,在命令行里面输入以下代码,即可获取到本文的代码
git init
git remote add origin https://gitee.com/lindexi/lindexi_gd.git
git pull origin 02ae29a86adb257c285046fc1e27a5539cf8bbb3
以上使用的是国内的 gitee 的源,如果 gitee 不能访问,请替换为 github 的源。请在命令行继续输入以下代码,将 gitee 源换成 github 源进行拉取代码。如果依然拉取不到代码,可以发邮件向我要代码
git remote remove origin
git remote add origin https://github.com/lindexi/lindexi_gd.git
git pull origin 02ae29a86adb257c285046fc1e27a5539cf8bbb3
获取代码之后,进入 Workbench/CofacelceawurDemharawjo 文件夹,即可获取到源代码
GetSystemMetrics
测试内容: 测试获取双击尺寸范围,双击的误差范围
性能:30.09 ns
BenchmarkDotNet v0.14.0, Windows 11 (10.0.22631.4391/23H2/2023Update/SunValley3) 13th Gen Intel Core i7-13700K, 1 CPU, 24 logical and 16 physical cores .NET SDK 9.0.100 [Host] : .NET 9.0.0 (9.0.24.52809), X64 RyuJIT AVX2 DefaultJob : .NET 9.0.0 (9.0.24.52809), X64 RyuJIT AVX2
Method | Mean | Error | StdDev |
---|---|---|---|
Test | 30.09 ns | 0.035 ns | 0.031 ns |
测试代码:
public class GetSystemMetricsTest
{
[Benchmark]
public (int X, int Y) Test()
{
var x = GetSystemMetrics(SystemMetric.SM_CXDOUBLECLK);
var y = GetSystemMetrics(SystemMetric.SM_CYDOUBLECLK);
return (x, y);
}
public const string LibraryName = "user32";
/// <summary>
/// 获取系统度量值
/// </summary>
/// <param name="smIndex"></param>
/// <returns></returns>
[DllImport(LibraryName)]
private static extern int GetSystemMetrics(SystemMetric smIndex);
internal enum SystemMetric
{
SM_CXDOUBLECLK = 36, // 0x24
SM_CYDOUBLECLK = 37, // 0x25
}
}
以上代码放在 github 和 gitee 上,可以使用如下命令行拉取代码。我整个代码仓库比较庞大,使用以下命令行可以进行部分拉取,拉取速度比较快
先创建一个空文件夹,接着使用命令行 cd 命令进入此空文件夹,在命令行里面输入以下代码,即可获取到本文的代码
git init
git remote add origin https://gitee.com/lindexi/lindexi_gd.git
git pull origin 02ae29a86adb257c285046fc1e27a5539cf8bbb3
以上使用的是国内的 gitee 的源,如果 gitee 不能访问,请替换为 github 的源。请在命令行继续输入以下代码,将 gitee 源换成 github 源进行拉取代码。如果依然拉取不到代码,可以发邮件向我要代码
git remote remove origin
git remote add origin https://github.com/lindexi/lindexi_gd.git
git pull origin 02ae29a86adb257c285046fc1e27a5539cf8bbb3
获取代码之后,进入 Workbench/CofacelceawurDemharawjo 文件夹,即可获取到源代码
相关博客
更多技术博客,请参阅 博客导航
本文会经常更新,请阅读原文: https://blog.lindexi.com/post/dotnet-%E5%AF%B9%E4%B8%80%E4%BA%9B-Win32-%E6%96%B9%E6%B3%95%E8%BF%9B%E8%A1%8C-Benchmark-%E5%9F%BA%E5%87%86%E6%80%A7%E8%83%BD%E6%B5%8B%E8%AF%95.html ,以避免陈旧错误知识的误导,同时有更好的阅读体验。
如果你想持续阅读我的最新博客,请点击 RSS 订阅,推荐使用RSS Stalker订阅博客,或者收藏我的博客导航
本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。欢迎转载、使用、重新发布,但务必保留文章署名林德熙(包含链接: https://blog.lindexi.com ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请 与我联系 。
无盈利,不卖课,做纯粹的技术博客
以下是广告时间
推荐关注 Edi.Wang 的公众号
欢迎进入 Eleven 老师组建的 .NET 社区
以上广告全是友情推广,无盈利