ホームページ > バックエンド開発 > C#.Net チュートリアル > C# プログラマーが頻繁に使用する 10 の実用的なコード スニペット

C# プログラマーが頻繁に使用する 10 の実用的なコード スニペット

伊谢尔伦
リリース: 2016-11-30 11:05:53
オリジナル
1236 人が閲覧しました

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();
}
ログイン後にコピー

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


関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート