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

            我參與的團隊

            搜索

            •  

            積分與排名

            • 積分 - 327087
            • 排名 - 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 閱讀(296) 評論(0)  編輯 收藏 引用 所屬分類: C#
            久久亚洲精精品中文字幕| 久久精品国产亚洲av麻豆色欲| 欧美一区二区三区久久综合| 亚洲人成无码久久电影网站| 久久久久四虎国产精品| 2020久久精品国产免费| 久久精品国产亚洲av麻豆小说| 无码伊人66久久大杳蕉网站谷歌 | 久久91精品国产91久| 久久综合五月丁香久久激情| 久久久久久A亚洲欧洲AV冫| 精品久久久无码中文字幕天天| 精品久久久久久中文字幕人妻最新 | 欧美性大战久久久久久| 亚洲另类欧美综合久久图片区| 久久久久久午夜精品| 国产精品中文久久久久久久| 欧美丰满熟妇BBB久久久| 国产人久久人人人人爽| 777久久精品一区二区三区无码 | 99久久这里只有精品| 久久夜色精品国产噜噜亚洲AV| 国产精品一久久香蕉国产线看观看| 久久ZYZ资源站无码中文动漫| 精品伊人久久大线蕉色首页| 久久久久亚洲av无码专区喷水 | 亚洲国产精品无码久久一线| 国产精品久久久久jk制服| 精品久久久久久国产免费了| 国产一区二区精品久久凹凸| 久久精品国产亚洲AV不卡| 91久久精一区二区三区大全| 久久婷婷五月综合色99啪ak | 99久久精品国产一区二区三区| 国产99久久久久久免费看| 欧美伊人久久大香线蕉综合| 久久99国产精品久久99| 综合网日日天干夜夜久久| 国产女人aaa级久久久级| 99久久精品国产一区二区| 亚洲国产成人久久精品动漫|