1 オペレーティングシステムとCLRのバージョンを読み取ります
OperatingSystem os = System.Environment.OSVersion; Console.WriteLine(“Platform: {0}”, os.Platform); Console.WriteLine(“Service Pack: {0}”, os.ServicePack); Console.WriteLine(“Version: {0}”, os.Version); Console.WriteLine(“VersionString: {0}”, os.VersionString); Console.WriteLine(“CLR Version: {0}”, System.Environment.Version);
私のWindows 7システムでは、次の情報が出力されます
プラットフォーム:Win32NT
サービスパック:
バージョン:6.1.7600.0
バージョン文字列:Microsoft Windows NT 6.1.7600.0
CLR バージョン: 4.0.21006.1
2 CPU の数とメモリ容量を読み取ります
必要な情報は、Windows Management Instrumentation (WMI) が提供するインターフェイスを通じて読み取ることができます。
private static UInt32 CountPhysicalProcessors() { ManagementObjectSearcher objects = new ManagementObjectSearcher( “SELECT * FROM Win32_ComputerSystem”); ManagementObjectCollection coll = objects.Get(); foreach(ManagementObject obj in coll) { return (UInt32)obj[“NumberOfProcessors”]; } return 0; } private static UInt64 CountPhysicalMemory() { ManagementObjectSearcher objects =new ManagementObjectSearcher( “SELECT * FROM Win32_PhysicalMemory”); ManagementObjectCollection coll = objects.Get(); UInt64 total = 0; foreach (ManagementObject obj in coll) { total += (UInt64)obj[“Capacity”]; } return total; }
コードが正しくコンパイルされることを確認するために、アセンブリ System.Management への参照を追加してください。
Console.WriteLine(“Machine: {0}”, Environment.MachineName); Console.WriteLine(“# of processors (logical): {0}”, Environment.ProcessorCount); Console.WriteLine(“# of processors (physical): {0}” CountPhysicalProcessors()); Console.WriteLine(“RAM installed: {0:N0} bytes”, CountPhysicalMemory()); Console.WriteLine(“Is OS 64-bit? {0}”, Environment.Is64BitOperatingSystem); Console.WriteLine(“Is process 64-bit? {0}”, Environment.Is64BitProcess); Console.WriteLine(“Little-endian: {0}”, BitConverter.IsLittleEndian); foreach (Screen screen in System.Windows.Forms.Screen.AllScreens) { Console.WriteLine(“Screen {0}”, screen.DeviceName); Console.WriteLine(“\tPrimary {0}”, screen.Primary); Console.WriteLine(“\tBounds: {0}”, screen.Bounds); Console.WriteLine(“\tWorking Area: {0}”,screen.WorkingArea); Console.WriteLine(“\tBitsPerPixel: {0}”,screen.BitsPerPixel); }
3 レジストリのキーと値のペアを読み取ります
using (RegistryKey keyRun = Registry.LocalMachine.OpenSubKey(@”Software\Microsoft\Windows\CurrentVersion\Run”)) { foreach (string valueName in keyRun.GetValueNames()) { Console.WriteLine(“Name: {0}\tValue: {1}”, valueName, keyRun.GetValue(valueName)); } }
上記のコードがコンパイルできることを確認するために、名前空間 Microsoft.Win32 を追加してください。
4 Windows サービスの開始と停止
この API が提供する実用的な機能は、コントロール パネルの管理サービスにアクセスせずにアプリケーション内のサービスを管理するためによく使用されます。
ServiceController controller = new ServiceController(“e-M-POWER”); controller.Start(); if (controller.CanPauseAndContinue) { controller.Pause(); controller.Continue(); } controller.Stop();
.netが提供するAPIでは、一文のインストール・アンインストールサービスを実装することができます
if (args[0] == "/i") { ManagedInstallerClass.InstallHelper(new string[] { Assembly.GetExecutingAssembly().Location }); } else if (args[0] == "/u") { ManagedInstallerClass.InstallHelper(new string[] { "/u", Assembly.GetExecutingAssembly().Location }); }
コードに示すように、i または u パラメータをアプリケーションに渡して、プログラムをアンインストールするかインストールするかを示します。
5 プログラムに強い名前があるかどうかを検証する(P/Invoke)
例えばプログラム内で、アセンブリに署名があるかどうかを検証するには、次のメソッドを呼び出すことができます
[DllImport("mscoree.dll", CharSet=CharSet.Unicode)] static extern bool StrongNameSignatureVerificationEx(string wszFilePath, bool fForceVerification, ref bool pfWasVerified); bool notForced = false; bool verified = StrongNameSignatureVerificationEx(assembly, false, ref notForced); Console.WriteLine("Verified: {0}\nForced: {1}", verified, !notForced);
この関数はよく使われますソフトウェア保護方法で使用され、署名されたコンポーネントの検証に使用できます。署名が削除された場合、またはすべてのアセンブリの署名が削除された場合でも、プログラム内にこの呼び出しコードが存在する限り、プログラムの実行を停止できます。
6 システム構成項目の変更に対応する
例えば、システムをロックした後、QQ が終了しない場合、ビジー状態が表示されます。
名前空間 Microsoft.Win32 を追加して、以下のイベントを登録してください。 A. DisplaySettingSchanged (変更を含む)
、InstalledfontSchanged フォント変更、SESSIONSWITCH (現在のユーザーの変更)
当社の ERP システムは、システム時間が変更されたかどうかを監視します。 ERP ライセンス ファイルの範囲外で時刻を調整すると、ERP ソフトウェアが使用できなくなります。
7 Windows 7 の新機能を使用する
Windows 7 システムには、ファイルを開くダイアログ ボックスなどのいくつかの新機能が導入されており、ステータス バーには現在のタスクの進行状況が表示されます。
Microsoft.WindowsAPICodePack.Dialogs.CommonOpenFileDialog ofd = new Microsoft.WindowsAPICodePack.Dialogs.CommonOpenFileDialog(); ofd.AddToMostRecentlyUsedList = true; ofd.IsFolderPicker = true; ofd.AllowNonFileSystemItems = true; ofd.ShowDialog();このメソッドを使用してダイアログ ボックスを開くには、BCL 独自のクラス ライブラリの OpenFileDialog よりも多くの機能があります。ただし、Windows 7 システムに限定されているため、このコードを呼び出すには、オペレーティング システムのバージョンが 6 以降であることも確認し、Microsoft®.NET Framework 用のアセンブリ Windows API コード パックへの参照を追加する必要があります。このアドレスにあります http://code.msdn.microsoft.com/WindowsAPICodePack 8 プログラムのメモリ消費量を確認します次の方法を使用すると、.NET によってプログラムに割り当てられたメモリの量を確認できます
long available = GC.GetTotalMemory(false); Console.WriteLine(“Before allocations: {0:N0}”, available); int allocSize = 40000000; byte[] bigArray = new byte[allocSize]; available = GC.GetTotalMemory(false); Console.WriteLine(“After allocations: {0:N0}”, available);私のシステムでは実行しました 結果は以下の通りです
Before allocations: 651,064 After allocations: 40,690,080以下の方法を使用すると、現在のアプリケーションが占有しているメモリを確認できます
Process proc = Process.GetCurrentProcess(); Console.WriteLine(“Process Info: “+Environment.NewLine+
“Private Memory Size: {0:N0}”+Environment.NewLine + “Virtual Memory Size: {1:N0}” + Environment.NewLine +
“Working Set Size: {2:N0}” + Environment.NewLine + “Paged Memory Size: {3:N0}” + Environment.NewLine + “Paged System Memory Size: {4:N0}” + Environment.NewLine +
“Non-paged System Memory Size: {5:N0}” + Environment.NewLine, proc.PrivateMemorySize64, proc.VirtualMemorySize64, proc.WorkingSet64, proc.PagedMemorySize64, proc.PagedSystemMemorySize64, proc.NonpagedSystemMemorySize64 );9 ストップウォッチを使用してプログラムの実行時間を確認してください気になる方は一部のコードは非常に時間がかかります。StopWatch を使用してこのセクションを確認できます。以下のコードに示すように、コードによって消費された時間は
System.Diagnostics.Stopwatch timer = new System.Diagnostics.Stopwatch(); timer.Start(); Decimal total = 0; int limit = 1000000; for (int i = 0; i < limit; ++i) { total = total + (Decimal)Math.Sqrt(i); } timer.Stop(); Console.WriteLine(“Sum of sqrts: {0}”,total); Console.WriteLine(“Elapsed milliseconds: {0}”, timer.ElapsedMilliseconds); Console.WriteLine(“Elapsed time: {0}”, timer.Elapsed);プログラムの実行時間を検出するための特別なツールがあり、調整することができますdotNetPerformance ソフトウェアなどの各メソッドに接続します。 上記のコードを例にとると、ソースコードを直接変更する必要がありますが、プログラムのテストに使用する場合は少し不便です。以下の例を参照してください。
class AutoStopwatch : System.Diagnostics.Stopwatch, IDisposable { public AutoStopwatch() { Start(); } public void Dispose() { Stop(); Console.WriteLine(“Elapsed: {0}”, this.Elapsed); } }以下のコードに示すように、構文を使用すると、コードの実行時間をチェックし、コンソールに出力できます。
using (new AutoStopwatch()) { Decimal total2 = 0; int limit2 = 1000000; for (int i = 0; i < limit2; ++i) { total2 = total2 + (Decimal)Math.Sqrt(i); } }10 カーソルの使用 プログラムがバックグラウンドで保存または削除操作を実行しているときは、カーソルのステータスをビジーに変更する必要があります。次のヒントを使用してください。
class AutoWaitCursor : IDisposable { private Control _target; private Cursor _prevCursor = Cursors.Default; public AutoWaitCursor(Control control) { if (control == null) { throw new ArgumentNullException(“control”); } _target = control; _prevCursor = _target.Cursor; _target.Cursor = Cursors.WaitCursor; } public void Dispose() { _target.Cursor = _prevCursor; } }
用法如下所示,这个写法,是为了预料到程序可能会抛出异常
using (new AutoWaitCursor(this)) { ... throw new Exception(); }
如代码所示,即使抛出异常,光标也可以恢复到之间的状态。