C#中调用API

2016-02-19 17:09 1 1 收藏

在这个颜值当道,屌丝闪边的时代,拼不过颜值拼内涵,只有知识丰富才能提升一个人的内在气质和修养,所谓人丑就要多学习,今天图老师给大家分享C#中调用API,希望可以对大家能有小小的帮助。

【 tulaoshi.com - 编程语言 】

  介绍

  API(Application Programming Interface),我想大家不会陌生,它是我们Windows编程的常客,虽然基于.Net平台的C#有了强大的类库,但是,我们还是不能否认API在Windows编程中的重要性。大多数的编程语言都支持API编程,而.Net平台中的MFC(Microsoft Foundation Class Library)构架本身就封装了大部分的API。

  做为程序员,我们需要了解API从字面上了解便是编程接口,因此,做为开发者,需要了解的只是API的使用方法。

  API根据操作系统、处理器及功能性的不同而拥有很多不同的类型。   操作系统特用的API:

  每种操作系统都有许多通用的API以及一些特用的API,这些特用的API只能在当前操作系统中执行。

  例如:

  Windows NT 支持 MS-DOS, Win16, Win32, POSIX (Portable Operating System Interface), OS/2 console API; 而 Windows 95 支持 MS-DOS, Win16 以及 Win32 APIs.

  Win16 & Win32 API:

  Win16是为十六位处理器开发的,早期的操作系统均支持。

  Win32则是为32位处理器开发。它可移植性强,被大部分的处理器所支持。

  Win32 API在库名后有一个32后缀。比如KERNEL32,USER32等。

  所有API在下面3个库中得以运行:

  

  Kernel  User  GDI 

  1. KERNEL

  他的库名为 KERNEL32.DLL, 他主要用于产生与操作系统之间的关联:

  程序加载

  上下文选择.

  文件输入输出.

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

  内存管理.

  例如: GlobalMemoryStatus 函数就包括当前物理内存及虚拟内存的使用信息。

  2. USER

  这个类库在Win32中名叫 USER32.DLL。

  它允许管理全部的用户接口,比如:

  窗口

  菜单

  对话框

  图标等.,

  例如: DrawIcon 函数将在指定的设备关联上画出图标或者鼠标。

  3. GDI (Graphical Device Interface)

  它在Win32中的库名为:GDI32.dll,它是图形输出库。使用GDI Windows画出窗口、菜单以及对话框等:

  它能创建图形输出.

  它也能保存图形文件.

  例如: CreateBitmap 函数就能通过指定的长、宽、颜色创建一个位图。

  C# 中操作API:

  作为初学者来说,在C#中使用API确是一件令人头疼的问题。在使用API之间你必须知道如何在C#中使用结构、类型转换、安全/不安全代码,可控/不可控代码等许多知识。

  一切从简单开始,复杂的大家一时不能接受。我们就从实现一个简单的MessageBox开始。首先打开VS.Net ,创建一个新的C#工程,并添加一个Button按钮。当这个按钮被点击,则显示一个MessageBox对话框。

  即然我们需要引用外来库,所以必须导入一个Namespace:

  

  using System.Runtime.InteropServices; 

  接着添加下面的代码来声明一个API:

  

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

  此处DllImport属性被用来从不可控代码中调用一方法。User32.dll则设定了类库名。DllImport属性指定dll的位置,这个dll中包括调用的外部方法。Static修饰符则声明一个静态元素,而这个元素属于类型本身而不是上面指定的对象。extern则表示这个方法将在工程外部执行,使用DllImport导入的方法必须使用extern修饰符。

  MessageBox 则是函数名,拥有4个参数,其返回值为数字。

  大多数的API都能传递并返回值。

  添中Click点击事件代码:

  

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

  编译并运行这个程序,当你点击按钮后,你将会看到对话框,这便是你使用的API函数。

  使用结构体

  操作带有结构体的API比使用简单的API要复杂的多。但是一旦你掌握了API的过程,那个整个API世界将在你的掌握之中。

  下面的例子中我们将使用GetSystemInfo API 来获取整个系统的信息。

  第一步还是打开C#建立一个Form工程,同样的添中一个Button按钮,在代码窗中输入下面的代码,导入Namespace:

  

  using System.Runtime.InteropServices;

  声明一个结构体,它将做为GetSystemInfo的一个参数:

  

  [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;  } 

  声明API函数:

  

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

  添加下面的代码至按钮的点击事件处理中:

  首先创建一个SYSTEM_INFO结构体,并将其传递给GetSystemInfo函数。

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

  一旦你接收到返回的结构体,那么就可以以返回的参数来执行操作了。

  

  e.g.listBox1.InsertItem (0,pSI.dwActiveProcessorMask.ToString());:          //          //          //     }     catch(Exception er)     {          MessageBox.Show (er.Message);     }  }

调用API全部代码

  

  //Created By Ajit Mungale  //程序补充 飞刀  namespace UsingAPI  {  using System;  using System.Drawing;  using System.Collections;  using System.ComponentModel;  using System.WinForms;  using System.Data;  using System.Runtime.InteropServices;  //Struct 收集系统信息  [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;    }  //struct 收集内存情况  [StructLayout(LayoutKind.Sequential)]  public struct MEMORYSTATUS  {       public uint dwLength;       public uint dwMemoryLoad;       public uint dwTotalPhys;       public uint dwAvailPhys;       public uint dwTotalPageFile;       public uint dwAvailPageFile;       public uint dwTotalVirtual;       public uint dwAvailVirtual;  }  public class Form1 : System.WinForms.Form  {    private System.ComponentModel.Container components;    private System.WinForms.MenuItem menuAbout;    private System.WinForms.MainMenu mainMenu1;    private System.WinForms.ListBox listBox1;    private System.WinForms.Button button1;  //获取系统信息    [DllImport("kernel32")]    static extern void GetSystemInfo(ref SYSTEM_INFO pSI);    //获取内存信息    [DllImport("kernel32")]    static extern void GlobalMemoryStatus(ref MEMORYSTATUS buf);    //处理器类型    public const int PROCESSOR_INTEL_386 = 386;    public const int PROCESSOR_INTEL_486 = 486;    public const int PROCESSOR_INTEL_PENTIUM = 586;    public const int PROCESSOR_MIPS_R4000 = 4000;    public const int PROCESSOR_ALPHA_21064 = 21064;    public Form1()    {      InitializeComponent();    }    public override void Dispose()    {      base.Dispose();      components.Dispose();    }    private void InitializeComponent()     {       this.components = new System.ComponentModel.Container ();       this.mainMenu1 = new System.WinForms.MainMenu ();       this.button1 = new System.WinForms.Button ();       this.listBox1 = new System.WinForms.ListBox ();       this.menuAbout = new System.WinForms.MenuItem ();       mainMenu1.MenuItems.All = new System.WinForms.MenuItem[1] {this.menuAbout};       button1.Location = new System.Drawing.Point (148, 168);       button1.Size = new System.Drawing.Size (112, 32);       button1.TabIndex = 0;       button1.Text = "&Get Info";       button1.Click += new System.EventHandler (this.button1_Click);       listBox1.Location = new System.Drawing.Point (20, 8);       listBox1.Size = new System.Drawing.Size (368, 147);       listBox1.TabIndex = 1;       menuAbout.Text = "&About";       menuAbout.Index = 0;       menuAbout.Click += new System.EventHandler (this.menuAbout_Click);       this.Text = "System Information - Using API";       this.MaximizeBox = false;       this.AutoScaleBaseSize = new System.Drawing.Size (5, 13);       this.MinimizeBox = false;       this.Menu = this.mainMenu1;       this.ClientSize = new System.Drawing.Size (408, 213);       this.Controls.Add (this.listBox1);       this.Controls.Add (this.button1);    }    protected void menuAbout_Click (object sender, System.EventArgs e)    {       Form abt=new about() ;       abt.ShowDialog();    }    protected void button1_Click (object sender, System.EventArgs e)    {       try       {          SYSTEM_INFO pSI = new SYSTEM_INFO();          GetSystemInfo(ref pSI);          string CPUType;          switch (pSI.dwProcessorType)          {            case PROCESSOR_INTEL_386 :               CPUType= "Intel 386";               break;            case PROCESSOR_INTEL_486 :               CPUType = "Intel 486" ;              break;            case PROCESSOR_INTEL_PENTIUM :              CPUType = "Intel Pentium";              break;            case PROCESSOR_MIPS_R4000 :              CPUType = "MIPS R4000";              break;            case PROCESSOR_ALPHA_21064 :              CPUType = "DEC Alpha 21064";              break;            default :              CPUType = "(unknown)";         }         listBox1.InsertItem (0,"Active Processor Mask :"+pSI.dwActiveProcessorMask.ToString());         listBox1.InsertItem (1,"Allocation Granularity :"+pSI.dwAllocationGranularity.ToString());         listBox1.InsertItem (2,"Number Of Processors :"+pSI.dwNumberOfProcessors.ToString());         listBox1.InsertItem (3,"OEM ID :"+pSI.dwOemId.ToString());         listBox1.InsertItem (4,"Page Size:"+pSI.dwPageSize.ToString());         listBox1.InsertItem (5,"Processor Level Value:"+pSI.dwProcessorLevel.ToString());         listBox1.InsertItem (6,"Processor Revision:"+ pSI.dwProcessorRevision.ToString());         listBox1.InsertItem (7,"CPU type:"+CPUType);         listBox1.InsertItem (8,"Maximum Application Address: "+pSI.lpMaximumApplicationAddress.ToString());         listBox1.InsertItem (9,"Minimum Application Address:" +pSI.lpMinimumApplicationAddress.ToString());         /************** 从 GlobalMemoryStatus 获取返回值****************/         MEMORYSTATUS memSt = new MEMORYSTATUS ();         GlobalMemoryStatus (ref memSt);         listBox1.InsertItem(10,"Available Page File :"+ (memSt.dwAvailPageFile/1024).ToString ());         listBox1.InsertItem(11,"Available Physical Memory : " + (memSt.dwAvailPhys/1024).ToString());         listBox1.InsertItem(12,"Available Virtual Memory:" + (memSt.dwAvailVirtual/1024).ToString ());         listBox1.InsertItem(13,"Size of structur :" + memSt.dwLength.ToString());         listBox1.InsertItem(14,"Memory In Use :"+ memSt.dwMemoryLoad.ToString());         listBox1.InsertItem(15,"Total Page Size :"+ (memSt.dwTotalPageFile/1024).ToString ());         listBox1.InsertItem(16,"Total Physical Memory :" + (memSt.dwTotalPhys/1024).ToString());         listBox1.InsertItem(17,"Total Virtual Memory :" + (memSt.dwTotalVirtual/1024).ToString ());       }       catch(Exception er)       {         MessageBox.Show (er.Message);       }    }    public static void Main(string[] args)    {      try       {          Application.Run(new Form1());       }       catch(Exception er)       {          MessageBox.Show (er.Message );       }   }  }}

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

来源:https://www.tulaoshi.com/n/20160219/1614351.html

延伸阅读
API函数是构筑Windows应用程序的基石,是Windows编程的必备利器。每一种Windows应用程序开发工具都提供了间接或直接调用了Windows API函数的方法,或者是调用Windows API函数的接口,也就是说具备调用动态连接库的能力。Visual C#和其它开发工具一样也能够调用动态链接库的API函数。本文中笔者就结合实例向大家介绍在Visual C#中如何调用各...
在 C++ 中我们能够通过 LoadLibrary, GetProcAddress 来动态调用 dll 的导出函数. 在 C# 中也能够用这样的方式吗? 在 DotNet 2.0 里面这样是可以的, 这完全得益于 2.0新增的一个函数,Marshal.GetDelegateForFunctionPointer 方法。此方法在 .NET Framework 2.0 版中是新增的。 将非托管函数指针转换为委托。 实例代...
我在编写一个系统时遇到了一个问题,无法在C#中调用Delphi6写的DLL,只因为DLL的参数是string类型的。然后在网上找相关的资料,还是没有结果。经过我的再三琢磨,现在已经解决,特写此文章与大家分享我的喜愉! Dellphi DLL文件: /////////////////////////////////////////////////////////////////// library mydll; uses SysUtils, Clas...
控制结阅与过程编程清浪冲天 马敬发 QQ: 283989349 E-mail: mjf150080@tom.com 有问题时,我们可以通过http://www.hustc.mpc.cn 这个论坛, 或 通过QQ 共同学习和讨论 一、控制结构 首先了解比较运算符: == 等于 >= 大于等于 大于 了解逻辑运算符: && 逻辑AND || 逻辑OR ! 逻辑NOT 警告:执行顺序是:! && || if...else...结构: 第...
Java跨平台的特性使Java越来越受开发人员的欢迎,但也往往会听到不少的抱怨:用Java开发的图形用户窗口界面每次在启动的时候都会跳出一个控制台窗口,这个控制台窗口让本来非常棒的界面失色不少。怎么能够让通过Java开发的GUI程序不弹出Java的控制台窗口呢?其实现在很多流行的开发环境例如JBuilder、Eclipse都是使用纯Java开发的集成环境...

经验教程

144

收藏

14
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部