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
필요한 정보는 WMI(Windows Management Instrumentation)에서 제공하는 인터페이스를 통해 읽을 수 있습니다.
아아아아코드가 올바르게 컴파일될 수 있도록 System.Management 어셈블리에 대한 참조를 추가하십시오.
아아아아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; }
위 코드가 컴파일될 수 있도록 네임스페이스 Microsoft.Win32를 추가하세요.
이 API에서 제공하는 실용적인 기능은 제어판의 관리 서비스로 이동할 필요 없이 애플리케이션에서 서비스를 관리하는 데 자주 사용됩니다.
아아아아.net에서 제공하는 API에서는
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); }
한 문장으로 서비스 설치 및 제거가 가능합니다. 코드에 표시된 대로 i 또는 u 매개변수를 애플리케이션에 전달하여 프로그램을 제거할지 아니면 설치할지 여부를 나타냅니다.
예를 들어, 프로그램에서 어셈블리가 서명되었는지 확인하기 위해 다음 메서드를
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)); } }
호출할 수 있습니다. 이 기능은 일반적으로 소프트웨어 보호 방법에 사용되며 서명된 구성 요소를 확인하는 데 사용할 수 있습니다. 서명이 제거되거나 모든 어셈블리의 서명이 제거되더라도 프로그램에 이 호출 코드가 있는 한 프로그램 실행이 중지될 수 있습니다.
예를 들어, 시스템을 잠근 후 QQ가 종료되지 않으면 사용 중 상태가 표시됩니다.
Microsoft.Win32 네임스페이스를 추가한 후 다음 이벤트를 등록하세요.
. 디스플레이설정변경됨(변경 포함) 디스플레이 설정
. InstalledFontsChanged 글꼴 변경
.PaletteChanged
.PowerMode전원 상태가 변경되었습니다
.SessionEnded(사용자가 로그아웃 중이거나 세션이 종료되었습니다)
.SessionSwitch(현재 사용자 변경)
. TimeChanged 시간이 변경되었습니다
. UserPreferenceChanged(사용자 기본 설정 번호에는 변경 포함)
당사 ERP 시스템은 시스템 시간이 변경되었는지 모니터링합니다. ERP 라이센스 파일 범위를 벗어나 시간이 조정되면 ERP 소프트웨어를 사용할 수 없게 됩니다.
Windows 7 시스템에는 파일 열기 대화 상자와 같은 몇 가지 새로운 기능이 도입되었으며 상태 표시줄에 현재 작업의 진행 상황이 표시될 수 있습니다.
아아아아이 방법을 사용하여 대화 상자를 열면 BCL 자체 클래스 라이브러리의 OpenFileDialog보다 더 많은 기능이 있습니다. 그러나 Windows 7 시스템으로 제한되므로 이 코드를 호출하려면 운영 체제 버전이 6 이상인지 확인하고 Microsoft®.NET Framework용 Windows API 코드 팩 어셈블리에 대한 참조를 추가해야 합니다. //m.sbmmt.com/
.NET이
<p style="margin-bottom: 7px;">ServiceController controller = new ServiceController(“e-M-POWER”); <br/>controller.Start(); <br/>if (controller.CanPauseAndContinue) <br/>{ <br/> controller.Pause(); <br/> controller.Continue(); <br/>} <br/>controller.Stop();<br/></p>
프로그램에 할당한 메모리 양을 확인하려면 다음 방법을 사용하세요. 제 시스템에서 실행 결과는 다음과 같습니다
if (args[0] == "/i") { ManagedInstallerClass.InstallHelper(new string[] { Assembly.GetExecutingAssembly().Location }); } else if (args[0] == "/u") { ManagedInstallerClass.InstallHelper(new string[] { "/u", Assembly.GetExecutingAssembly().Location }); }
현재 애플리케이션이 차지하는 메모리를 확인하려면 다음 방법을 사용하세요.
[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);
Microsoft.WindowsAPICodePack.Dialogs.CommonOpenFileDialog ofd = new Microsoft.WindowsAPICodePack.Dialogs.CommonOpenFileDialog(); ofd.AddToMostRecentlyUsedList = true; ofd.IsFolderPicker = true; ofd.AllowNonFileSystemItems = true; ofd.ShowDialog();
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+
와 같이 StopWatch를 사용하여 이 코드에 소요되는 시간을 확인할 수 있습니다. 이제 dotNetPerformance 소프트웨어와 같이 프로그램의 실행 시간을 감지하는 특수 도구가 있으며 이를 각 방법에 맞게 조정할 수 있습니다.
위의 코드를 예로 들면, 소스코드를 직접 수정해야 하는데, 프로그램을 테스트하는데 사용한다면 다소 불편할 수 있습니다. 아래 예를 참조하세요.
아아아아다음 코드와 같이 구문을 사용하면 코드의 실행 시간을 확인하고 콘솔에 인쇄할 수 있습니다.
아아아아프로그램이 백그라운드에서 저장 또는 삭제 작업을 실행 중인 경우 커서 상태는 사용 중으로 변경되어야 합니다. 다음 팁을 사용하세요.
아아아아사용법은 다음과 같습니다.
“Private Memory Size: {0:N0}”+Environment.NewLine + “Virtual Memory Size: {1:N0}” + Environment.NewLine +
프로그램에서 예외가 발생할 수 있음을 예상하기 위한 것입니다. 코드에서 볼 수 있듯이 예외가 발생하더라도 커서는 이전 상태로 복원될 수 있습니다.
위 내용은 C# 프로그래머가 자주 사용하는 10가지 실용적인 코드 조각에 대한 자세한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!