• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            為生存而奔跑

               :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
              271 Posts :: 0 Stories :: 58 Comments :: 0 Trackbacks

            留言簿(5)

            我參與的團隊

            搜索

            •  

            積分與排名

            • 積分 - 328382
            • 排名 - 74

            最新評論

            閱讀排行榜

            評論排行榜

            Implementing APIs in C# is a tough job for beginners. Before implementing API you should know how to implement structure in C#, type conversion, safe/unsafe code, managed/unmanaged code and lots more.

            Before implementing complex APIs we will start with simple MessageBox API. To implement code for the MessageBoxAPI open a new C# project and add one button. When button gets clicked the code will display a Message Box.

            Since we are using external library, add a namespace:

             Collapse code snippet
            using System.Runtime.InteropServices;

            Add the following lines to declare the API

             Collapse
            [DllImport("User32.dll")]
            public static extern int MessageBox(int h, string m, string c, int type);

            Here the DllImport attribute is used for calling the method from unmanaged code. "User32.dll" indicates the library name. The DllImport attribute specifies the dll location that contains the implementation of an extern method. Thestatic modifier is used to declare a static member, which belongs to the type itself rather than to a specific object,extern is used to indicate that the method is implemented externally. A method that is decorated with the DllImportattribute must have the extern modifier.

            MessageBox is the function name, which returns int and takes 4 parameters as shown in declaration.

            Many APIs use structures to pass and retrieve values, as it is less expensive. It also uses constant data type for passing constant data and simple data types for passing built-in data types as seen in the previous declaration of the MessageBox function.

            Add following code for button click event:

             Collapse
            protected void button1_Click(object sender, System.EventArgs e)
            {
            	MessageBox (0,"API Message Box","API Demo",0);
            }

            Compile and run project, after clicking on the button you will see a MessageBox, which you called using API the function!!!

            Using Structures

            Working with APIs, which use complex structures, or structures inside structures, is somewhat more complex than using simple APIs. But once you understand the implementation then the whole API world is yours.

            In next example we will use GetSystemInfo API which returns information about the current system.

            The first step is open a new C# form and add one button on it. Go to the code window of the form and add a namespace:

             Collapse
            using System.Runtime.InteropServices;

            Declare the structure, which is the parameter of GetSystemInfo.

             Collapse
            [StructLayout(LayoutKind.Sequential)]
            public struct SYSTEM_INFO {
            	public uint dwOemId;
            	public uint dwPageSize;
            	public uint lpMinimumApplicationAddress;
            	public uint lpMaximumApplicationAddress;
            	public uint dwActiveProcessorMask;
            	public uint dwNumberOfProcessors;
            	public uint dwProcessorType;
            	public uint dwAllocationGranularity;
            	public uint dwProcessorLevel;
            	public uint dwProcessorRevision;
            }

            Declare the API function:

             Collapse
            [DllImport("kernel32")]
            static extern void GetSystemInfo(ref SYSTEM_INFO pSI); 

            Where ref is next to the method parameter keyword it causes a method to refer to the same variable that was passed into the method.

            Add the following code in the button click event in which we first create a struct object and then pass it to function.

             Collapse
            protected void button1_Click (object sender, System.EventArgs e)
            {
            	try
            	{
            		SYSTEM_INFO pSI = new SYSTEM_INFO();
            		GetSystemInfo(ref pSI);
            		//
            
            		//
            
            		//

            Once you retrieve the structure, perform operations on the required parameter

            e.g.listBox1.InsertItem (0,pSI.dwActiveProcessorMask.ToString());:

             Collapse
            		//
            
            		//
            
            		//
            
            	}
            	catch(Exception er)
            	{
            		MessageBox.Show (er.Message);
            	}
            }
            posted on 2009-12-20 14:09 baby-fly 閱讀(304) 評論(0)  編輯 收藏 引用 所屬分類: C#
            久久99国产乱子伦精品免费| 亚洲国产精品久久久久婷婷老年 | 欧美激情一区二区久久久| 久久久久99这里有精品10| 久久精品无码专区免费东京热| 精品国产一区二区三区久久| 久久国产精品视频| 国产精品久久久久蜜芽| 久久亚洲高清观看| 久久久无码精品亚洲日韩蜜臀浪潮 | 国产精品久久久久aaaa| 97视频久久久| 久久99热这里只有精品国产| 亚洲精品乱码久久久久久久久久久久 | 国产精品女同一区二区久久| 欧美丰满熟妇BBB久久久| 久久国产三级无码一区二区| 国产精品九九九久久九九| 亚洲乱码日产精品a级毛片久久 | 国产综合久久久久| 久久久国产打桩机| 日韩中文久久| 人妻无码久久精品| 精品多毛少妇人妻AV免费久久| 久久久精品人妻一区二区三区四| 亚州日韩精品专区久久久| 久久97久久97精品免视看| 伊人色综合久久天天| 久久国产亚洲精品无码| 婷婷久久久亚洲欧洲日产国码AV | 久久96国产精品久久久| 日本强好片久久久久久AAA| 国色天香久久久久久久小说| 亚洲国产成人精品久久久国产成人一区二区三区综 | 狠狠久久综合伊人不卡| 久久综合久久综合九色| 亚洲伊人久久大香线蕉苏妲己| www.久久精品| 久久久久久狠狠丁香| 国产成人无码精品久久久久免费 | 亚洲午夜无码久久久久|