• <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>

            為生存而奔跑

               :: 首頁 :: 聯系 :: 聚合  :: 管理
              271 Posts :: 0 Stories :: 58 Comments :: 0 Trackbacks

            留言簿(5)

            我參與的團隊

            搜索

            •  

            積分與排名

            • 積分 - 328386
            • 排名 - 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#
            久久精品国产一区二区三区不卡| 久久久精品人妻一区二区三区蜜桃 | 久久福利片| 亚洲精品无码久久久久去q| 免费精品国产日韩热久久| 久久精品亚洲乱码伦伦中文| 久久精品国产亚洲Aⅴ蜜臀色欲| 久久无码人妻精品一区二区三区| 国内精品久久久久久久涩爱| 国产精品99久久久久久www| 亚洲国产成人久久精品99| 久久天天躁夜夜躁狠狠| 久久久亚洲欧洲日产国码二区 | 伊色综合久久之综合久久| 久久精品成人免费国产片小草 | 久久人人妻人人爽人人爽| 久久久久国产精品熟女影院| 色综合久久中文综合网| 亚洲国产天堂久久久久久| AAA级久久久精品无码片| 久久精品18| 潮喷大喷水系列无码久久精品| 久久久久免费精品国产| 亚洲国产日韩欧美久久| 日韩亚洲欧美久久久www综合网| 久久久久亚洲精品日久生情| 久久亚洲国产午夜精品理论片| 久久无码人妻精品一区二区三区 | 77777亚洲午夜久久多人| 日韩亚洲欧美久久久www综合网| 伊人久久亚洲综合影院| 夜夜亚洲天天久久| 伊人久久大香线蕉综合Av| 久久久久久av无码免费看大片| 亚洲AV无码久久精品色欲| 免费精品久久久久久中文字幕| 色欲久久久天天天综合网精品| 久久久精品日本一区二区三区| 国产精品女同久久久久电影院| 亚洲国产精品久久久久婷婷软件 | 久久久久国产成人精品亚洲午夜|