• <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#
            日韩va亚洲va欧美va久久| 精品无码久久久久国产| 国产99久久久久久免费看| 久久婷婷国产麻豆91天堂| 婷婷久久综合九色综合绿巨人| 欧美日韩精品久久免费| 国产午夜精品久久久久免费视| 国产精品gz久久久| 老色鬼久久亚洲AV综合| 久久亚洲av无码精品浪潮| 久久天天躁狠狠躁夜夜96流白浆| 91亚洲国产成人久久精品| 久久精品国产免费观看三人同眠| 国产AⅤ精品一区二区三区久久| 久久亚洲2019中文字幕| 久久夜色精品国产亚洲| 久久久久久久久波多野高潮| 国产精品99久久久久久董美香| 久久婷婷五月综合色高清| 免费一级欧美大片久久网| 99久久精品国内| 久久久久AV综合网成人| 少妇久久久久久被弄高潮| 精品久久久久久99人妻| 久久精品成人免费网站| 久久婷婷五月综合97色| 久久91精品国产91久| 色99久久久久高潮综合影院 | 久久精品人人做人人爽电影| 日本一区精品久久久久影院| 久久不见久久见免费视频7| 久久精品国产清自在天天线| 亚洲综合久久夜AV | 久久亚洲国产精品123区| 亚洲国产二区三区久久| 国内精品久久久久久中文字幕| 狠狠干狠狠久久| 色综合合久久天天综合绕视看| 成人妇女免费播放久久久| 97热久久免费频精品99| 99久久777色|