C#程序员经常用到的10个实用代码片段

简介:


1 读取操作系统和CLR的版本


 
 
  1. OperatingSystem os = System.Environment.OSVersion; 
  2. Console.WriteLine(“Platform: {0}”, os.Platform); 
  3. Console.WriteLine(“Service Pack: {0}”, os.ServicePack); 
  4. Console.WriteLine(“Version: {0}”, os.Version); 
  5. Console.WriteLine(“VersionString: {0}”, os.VersionString); 
  6. Console.WriteLine(“CLR Version: {0}”, System.Environment.Version); 

在我的Windows 7系统中,输出以下信息


 
 
  1. Platform: Win32NT 
  2. Service Pack: 
  3. Version: 6.1.7600.0 
  4. VersionString: Microsoft Windows NT 6.1.7600.0 
  5. CLR Version: 4.0.21006.1 

2 读取CPU数量,内存容量

可以通过Windows Management Instrumentation (WMI)提供的接口读取所需要的信息。


 
 
  1. private static UInt32 CountPhysicalProcessors() 
  2.      ManagementObjectSearcher objects = new ManagementObjectSearcher( 
  3.         “SELECT * FROM Win32_ComputerSystem”); 
  4.      ManagementObjectCollection coll = objects.Get(); 
  5.      foreach(ManagementObject obj in coll) 
  6.     { 
  7.         return (UInt32)obj[“NumberOfProcessors”]; 
  8.     } 
  9.     return 0
  10. private static UInt64 CountPhysicalMemory() 
  11.    ManagementObjectSearcher objects =new ManagementObjectSearcher( 
  12.       “SELECT * FROM Win32_PhysicalMemory”); 
  13.    ManagementObjectCollection coll = objects.Get(); 
  14.    UInt64 total = 0
  15.    foreach (ManagementObject obj in coll) 
  16.    { 
  17.        total += (UInt64)obj[“Capacity”]; 
  18.     } 
  19.     return total; 

请添加对程序集System.Management的引用,确保代码可以正确编译。


 
 
  1. Console.WriteLine(“Machine: {0}”, Environment.MachineName); 
  2. Console.WriteLine(“# of processors (logical): {0}”, Environment.ProcessorCount); 
  3. Console.WriteLine(“# of processors (physical): {0}”  CountPhysicalProcessors()); 
  4. Console.WriteLine(“RAM installed: {0:N0} bytes”,  CountPhysicalMemory()); 
  5. Console.WriteLine(“Is OS 64-bit? {0}”,   Environment.Is64BitOperatingSystem); 
  6. Console.WriteLine(“Is process 64-bit? {0}”,  Environment.Is64BitProcess); 
  7. Console.WriteLine(“Little-endian: {0}”, BitConverter.IsLittleEndian); 
  8. foreach (Screen screen in  System.Windows.Forms.Screen.AllScreens) 
  9.      Console.WriteLine(“Screen {0}”, screen.DeviceName); 
  10.      Console.WriteLine(“\tPrimary {0}”, screen.Primary); 
  11.      Console.WriteLine(“\tBounds: {0}”, screen.Bounds); 
  12.      Console.WriteLine(“\tWorking Area: {0}”,screen.WorkingArea); 
  13.      Console.WriteLine(“\tBitsPerPixel: {0}”,screen.BitsPerPixel); 

3 读取注册表键值对


 
 
  1. using (RegistryKey keyRun = Registry.LocalMachine.OpenSubKey(@”Software\Microsoft\Windows\CurrentVersion\Run”)) 
  2.     foreach (string valueName in keyRun.GetValueNames()) 
  3.     { 
  4.      Console.WriteLine(“Name: {0}\tValue: {1}”, valueName, keyRun.GetValue(valueName)); 
  5.     } 

请添加命名空间Microsoft.Win32,以确保上面的代码可以编译。

4 启动,停止Windows服务

这项API提供的实用功能常常用来管理应用程序中的服务,而不必到控制面板的管理服务中进行操作。


 
 
  1. ServiceController controller = new ServiceController(“e-M-POWER”);      
  2. controller.Start();      
  3. if (controller.CanPauseAndContinue)      
  4. {      
  5.     controller.Pause();      
  6.     controller.Continue();      
  7. }      
  8. controller.Stop();       

.net提供的API中,可以实现一句话安装与卸载服务


 
 
  1. if (args[0] == "/i"
  2.        ManagedInstallerClass.InstallHelper(new string[] { Assembly.GetExecutingAssembly().Location }); 
  3. else if (args[0] == "/u"
  4.    ManagedInstallerClass.InstallHelper(new string[] { "/u", Assembly.GetExecutingAssembly().Location }); 

如代码所示,给应用程序传入i或u参数,以表示是卸载或是安装程序。

5 验证程序是否有strong name (P/Invoke)

比如在程序中,为了验证程序集是否有签名,可调用如下方法


 
 
  1. [DllImport("mscoree.dll", CharSet=CharSet.Unicode)] 
  2. static extern bool StrongNameSignatureVerificationEx(string wszFilePath, bool fForceVerification, ref bool  pfWasVerified); 
  3.  
  4. bool notForced = false
  5. bool verified = StrongNameSignatureVerificationEx(assembly, false, ref notForced); 
  6. Console.WriteLine("Verified: {0}\nForced: {1}", verified, !notForced); 

这个功能常用在软件保护方法,可用来验证签名的组件。即使你的签名被人去掉,或是所有程序集的签名都被去除,只要程序中有这一项调用代码,则可以停止程序运行。

6 响应系统配置项的变更

比如我们锁定系统后,如果QQ没有退出,则它会显示了忙碌状态。

请添加命名空间Microsoft.Win32,然后对注册下面的事件。


 
 
  1. . DisplaySettingsChanged (包含Changing)  显示设置 
  2. . InstalledFontsChanged  字体变化 
  3. . PaletteChanged  
  4. . PowerModeChanged 电源状态 
  5. . SessionEnded (用户正在登出或是会话结束) 
  6. . SessionSwitch (变更当前用户) 
  7. . TimeChanged 时间改变 
  8. . UserPreferenceChanged (用户偏号 包含Changing) 

我们的ERP系统,会监测系统时间是否改变,如果将时间调整后ERP许可文件之外的范围,会导致ERP软件不可用。

7 运用Windows7的新特性

Windows7系统引入一些新特性,比如打开文件对话框,状态栏可显示当前任务的进度。


 
 
  1. Microsoft.WindowsAPICodePack.Dialogs.CommonOpenFileDialog ofd = new  Microsoft.WindowsAPICodePack.Dialogs.CommonOpenFileDialog(); 
  2. ofd.AddToMostRecentlyUsedList = true
  3. ofd.IsFolderPicker = true
  4. ofd.AllowNonFileSystemItems = true
  5. ofd.ShowDialog(); 

用这样的方法打开对话框,与BCL自带类库中的OpenFileDialog功能更多一些。不过只限于Windows 7系统中,所以要调用这段代码,还要检查操作系统的版本要大于6,并且添加对程序集Windows API Code Pack for Microsoft®.NET Framework的引用,请到这个地址下载 http://code.msdn.microsoft.com/WindowsAPICodePack

8 检查程序对内存的消耗

用下面的方法,可以检查.NET给程序分配的内存数量


 
 
  1. long available = GC.GetTotalMemory(false); 
  2. Console.WriteLine(“Before allocations: {0:N0}”, available); 
  3. int allocSize = 40000000
  4. byte[] bigArray = new byte[allocSize]; 
  5. available = GC.GetTotalMemory(false); 
  6. Console.WriteLine(“After allocations: {0:N0}”, available); 

在我的系统中,它运行的结果如下所示


 
 
  1. Before allocations: 651,064 
  2. After allocations: 40,690,080 

使用下面的方法,可以检查当前应用程序占用的内存


 
 
  1. Process proc = Process.GetCurrentProcess(); 
  2. Console.WriteLine(“Process Info: “+Environment.NewLine+  
  3.  
  4.  “Private Memory Size: {0:N0}”+Environment.NewLine + 
  5. “Virtual Memory Size: {1:N0}” + Environment.NewLine + 
  6.  
  7. “Working Set Size: {2:N0}” + Environment.NewLine + 
  8. “Paged Memory Size: {3:N0}” + Environment.NewLine + 
  9. “Paged System Memory Size: {4:N0}” + Environment.NewLine + 
  10.  
  11.   “Non-paged System Memory Size: {5:N0}” + Environment.NewLine, 
  12. proc.PrivateMemorySize64,   proc.VirtualMemorySize64,  proc.WorkingSet64,  proc.PagedMemorySize64, proc.PagedSystemMemorySize64,  proc.NonpagedSystemMemorySize64 ); 

9 使用记秒表检查程序运行时间

如果你担忧某些代码非常耗费时间,可以用StopWatch来检查这段代码消耗的时间,如下面的代码所示


 
 
  1. System.Diagnostics.Stopwatch timer = new System.Diagnostics.Stopwatch(); 
  2. timer.Start(); 
  3. Decimal total = 0
  4. int limit = 1000000
  5. for (int i = 0; i < limit; ++i) 
  6.       total = total + (Decimal)Math.Sqrt(i); 
  7. timer.Stop(); 
  8. Console.WriteLine(“Sum of sqrts: {0}”,total); 
  9. Console.WriteLine(“Elapsed milliseconds: {0}”, 
  10. timer.ElapsedMilliseconds); 
  11. Console.WriteLine(“Elapsed time: {0}”, timer.Elapsed); 

现在已经有专门的工具来检测程序的运行时间,可以细化到每个方法,比如dotNetPerformance软件。

以上面的代码为例子,您需要直接修改源代码,如果是用来测试程序,则有些不方便。请参考下面的例子。


 
 
  1. class AutoStopwatch : System.Diagnostics.Stopwatch, IDisposable 
  2.    public AutoStopwatch() 
  3.    { 
  4.        Start(); 
  5.    } 
  6.    public void Dispose() 
  7.    { 
  8.        Stop(); 
  9.        Console.WriteLine(“Elapsed: {0}”, this.Elapsed); 
  10.    } 

借助于using语法,像下面的代码所示,可以检查一段代码的运行时间,并打印在控制台上。


 
 
  1. using (new AutoStopwatch()) 
  2.     Decimal total2 = 0
  3.     int limit2 = 1000000
  4.     for (int i = 0; i < limit2; ++i) 
  5.     { 
  6.        total2 = total2 + (Decimal)Math.Sqrt(i); 
  7.     } 

10 使用光标

当程序正在后台运行保存或是册除操作时,应当将光标状态修改为忙碌。可使用下面的技巧。


 
 
  1. class AutoWaitCursor : IDisposable 
  2. private Control _target; 
  3. private Cursor _prevCursor = Cursors.Default; 
  4. public AutoWaitCursor(Control control) 
  5.    if (control == null
  6.    { 
  7.      throw new ArgumentNullException(“control”); 
  8.    } 
  9.    _target = control; 
  10.    _prevCursor = _target.Cursor; 
  11.    _target.Cursor = Cursors.WaitCursor; 
  12. public void Dispose() 
  13.    _target.Cursor = _prevCursor; 

用法如下所示,这个写法,是为了预料到程序可能会抛出异常


 
 
  1. using (new AutoWaitCursor(this)) 
  2. ... 
  3. throw new Exception(); 

如代码所示,即使抛出异常,光标也可以恢复到之间的状态。


来源:51CTO

相关文章
|
4月前
|
程序员 C# 开发工具
C#☀️原来高级程序员是这样使用 & 操作符
C#☀️原来高级程序员是这样使用 & 操作符
|
6月前
|
程序员 C# C++
lpszBlogName C#开发多年中途被迫改行C++但工作中又经常偷偷使用C#的C++程序员
通过AUMID解析出packageFamily,再根据PackageManager解析出安装目录 PackageManager是WinRT的类型,如何在c++中使用WinRT,请参考C++/WinRT 以下代码需要管理员权限才能运行。
|
7月前
|
开发框架 .NET Linux
2024年最全C# 图解教程 第5版 —— 第1章 C# 和 ,2024年最新终于有人把Linux运维程序员必学知识点全整理出来了
2024年最全C# 图解教程 第5版 —— 第1章 C# 和 ,2024年最新终于有人把Linux运维程序员必学知识点全整理出来了
2024年最全C# 图解教程 第5版 —— 第1章 C# 和 ,2024年最新终于有人把Linux运维程序员必学知识点全整理出来了
|
前端开发 JavaScript 程序员
【程序员的福音】一款C#开源的GitHub加速神器
【程序员的福音】一款C#开源的GitHub加速神器
198 0
|
Java 程序员 PHP
C#-程序员不积跬步无以至千里 076
<p>  首先感谢关注支持我的老铁,感谢你们的点赞鼓励,使我有动力继续写下去,多余的话也不多说了,只能是尽最大力气把001承诺的知识一一认真地写出来,供大家免费学习;在评论区也不用拿说什么大佬的来噎我,在IT界没几个敢说自己是大佬的,且不说编程语言几百种(通过百度百科查询到了600多种编程语言,其中一一比较广泛的通用开发语言有 C, C++,JAVA,C#,VB,Python, PHP, 等)一些大牛也只是在某一方面研究比较深,比别人厉害一些,大而全不如小而精;提一些把我难住的问题给我难堪,没必要这么无聊消遣我,我写这个本身就是一个兴趣,又不靠这个生活,文章内容也会尽量专业化,更新可能会慢些望
131 0
|
程序员 C# 图形学
Unity C#基础之 反射反射,程序员的快乐
反射反射,程序员的快乐 这句话想必大家都经常听过,基本上在绝大多数的框架和一些设计模式中都能看到反射的身影(MVC、IOC、AOP、O/RM), 反射:是.Net Framework提供的一个帮助类库,可以访问dll的metadata,并且使用它。
1172 0