Key points for calling Windows API in C #

xiaoxiao2021-03-05  31

In the .NET Framework SDK document, the indication of calling the Windows API is more zero, and a slightly comprehensive one is to tell Visual Basic .NET. This article brings together the point of the C # to the API, and I hope to give a little help for friends who have not used API in C #. In addition, if Visual Studio .NET is installed, there is a large number of examples of the API in the C: / Program Files / Microsoft Visual Studio .NET / FRAMEWORKSDK / SAMPLES / Technologies / Interop / PlatformInvoke / WinAPIS / CS directory. First, call format using system.runtime.interopservices; // Reference This namespace, simplify the following code ... // use the DLLIMPORTATTRIBUTE feature to introduce the API function, pay attention to the empty method, that is, the method is empty. [DLLIMPORT ("User32.dll")] Public Static Extern Returntype FunctionName (Type Arg1, Type Arg2, ...); // When calling, there is no difference between calling other methods, you can use the field to further describe characteristics, separated by commas, Such as: [DLLIMPORT ("kernel32", entrypoint = "getversionex")] The public field of the DLLIMPORTATTRIBUTE feature is as follows: 1. CallingConvention indicates the CallingConvention value used to deliver the pass method parameter to the non-hosting method. Callingconvention.cdecl: The caller clensizes the stack. It allows you to call functions with VARARGS. Callingconvention.stdcall: Clean up the stack by the memory. It is the default convention for calling the non-hosting function from the hosted code. 2, the name version of the CHARSET control call function and indicates how to block the String parameter to the method. This field is set to one of the CharSet value. If the CHARSET field is set to Unicode, all string parameters are converted to Unicode characters before passing to the unmanaged implementation. This also results in adding letters "W" to the name of DLL EntryPoint. If this field is set to ANSI, the string will be converted to an ANSI string while adding letters "a" to the name of DLL Entrypoint. Most Win32 APIs use this agreed "W" or "a" agreement. If the Charset is set to Auto, this conversion is related to the platform (Unicode on Windows NT, ANSI on Windows 98). The default value of Charset is ANSI. The CHARSET field is also used to determine which version of the version will be imported from the specified DLL. Charset.ansi and charset.Unicode's name match rules are very different. For ANSI, if you set the entrypoint to "MyMethod" and it exist, return "MyMethod". If there is no "MyMethod" in the DLL, "MyMethoda" is existed, then "MyMethoda" is returned. For Unicode, it is just the opposite. Return "MyMethodw" if you exist in "MyMethod" and it exists. If "MyMethodw" does not exist in the DLL, there is "MyMethod", then return "MyMethod". If Auto is used, the matching rules are related to the platform (Unicode on Windows NT, which is ANSI on Windows 98).

If Exactspelling is set to TRUE, only "MyMethod" is returned when "MyMethod" is present in the DLL. 3. EntryPoint indicates the name or serial number of the DLL entry point to be called. If your method name does not want to be with the API function, you must specify this parameter, for example: [DLLIMPORT ("User32.dll", charset = "charset.auto", entrypoint = "messagebox")] public static extern int msgbox INTPTR HWND, STRING TXT, STRING CAPTION, INT TYPE; 4, Exactspelling Indicates whether the name of the entry point in the non-host DLL should be modified to correspond to the charset value specified in the Charset field. If true, when the DLLIMPORTATTRIBUTE.CHARSET field is set to the ANSI value of the CHARSET, the letter A is added to the method name. When the DLLIMPORTATTRIBUTE.CHARSET field is set to the Unicode value of the method, the letter W is added to the name of the method. The default value of this field is False. 5, preservesig indicates that the host signature should not be converted to return to HRESULT, and may have an unmanaged signature corresponding to the additional [OUT, RETVAL] parameter corresponding to the return value. 6, setLastError indicates that the Win32 API setLastError will call the win32 API SetLastError before returning from the property. TRUE Indicates the Compass to call SetLastError, which defaults to false. The runtime encapsulator will call the getLastError and cache the returned value to prevent it by other API calls. The user can retrieve the error code by calling getLastWin32error. Second, the parameter type: 1, the numerical type can be used directly. (DWORD -> INT, WORD, WORD16) 2, API string pointer type -> .NET in String3, Optical Handle (DWORD) -> .NET in INTPTR4, API Structure -> .NET structure or class . Note that in this case, you must first define a StructLayout feature to define a declarative structure or a public language runtime using the StructLayOutAttribute control class or the physical layout in the managed memory, that is, the class or structure needs to be arranged in some way. If you want to pass the class to a non-hosting code that needs to be specified, the explicit control class layout is important. Its constructor initials a new instance of the StructLayOatttribute class with a layoutkind value. LayoutKind.sequential is used to enforce the member to sequentially in the order of its appearance. Layoutkind.exPlicit is used to control the exact location of each data member. With Explicit, each member must use FieldOffsetAttribute to indicate the location of this field in the type.

Such as: [StructLayout (LayoutKind.Explicit, Size = 16, CharSet = CharSet.Ansi)] public class MySystemTime {[FieldOffset (0)] public ushort wYear; [FieldOffset (2)] public ushort wMonth; [FieldOffset (4)] public ushort wDayOfWeek; [FieldOffset (6)] public ushort wDay; [FieldOffset (8)] public ushort wHour; [FieldOffset (10)] public ushort wMinute; [FieldOffset (12)] public ushort wSecond; [FieldOffset (14)] Public Ushort WmilliseConds;} The following is an OSVersionInfo structure in the API, as an example of the corresponding class or structure in .NET: / ********************** ********************* API defined in the original structure declaration * OSVERSIONFOA STRUCT * DWOSVERSIONFOA STRUCT * DWOSVERSIONFOSIZE DWORD? * DWMAJORVERSION DWORD? * DWMINORVERSION DWORD? * DWBUILDNUMBER DWORD? * DWPLATFORMID DWORD? * SZCSDVERSION BYTE 128 DUP (?) * OsversionInfoa Ends ** OsversionInfo Equ *************************************** ************** / //. Declared in NET as class [StructLayout (layoutkind.sequential] public class osversioninfo {public int INT OSVersionInfoSize; public int majorVersion; public int minorVersion; public int buildNumber; public int platformId; [MarshalAs (UnmanagedType.ByValTStr, SizeConst = 128)] public String versionString;} // declare a structure or //.net [StructLayout (LayoutKind .Sequential)] public struct OSVersionInfo2 {public int OSVersionInfoSize; public int majorVersion; public int minorVersion; public int buildNumber; public int platformId; [MarshalAs (UnmanagedType.ByValTStr, SizeConst = 128)] public String versionString;} used in this embodiment Mashalas features, it is used to describe the sealing processing format of fields, methods, or parameters. Use it as a parameter prefix and specify the data type required for the target.

转载请注明原文地址:https://www.9cbs.com/read-34157.html

New Post(0)