实现回调函数
-
开始实现之前,先查看 EnumWindows 函数的签名。 EnumWindows 具有以下签名:
BOOL EnumWindows(WNDENUMPROC lpEnumFunc, LPARAM lParam)
表示此函数需要回调的线索之一是存在 lpEnumFunc 参数。 如果参数采用指向回调函数的指针,其名称中通常会有 lp(长指针)前缀与 Func 后缀的组合。 有关 Win32 函数的文档,请参见 Microsoft Platform SDK。
-
创建托管回调函数。 该示例声明一个名为 CallBack 的委托类型,此委托类型采用两个参数:hwnd 和 lparam。 第一个参数是窗口的句柄;第二个参数由应用程序定义。 在此版本中,这两个参数都必须是整数。
回调函数通常会返回非零值来表示成功,返回零来表示失败。 本示例将返回值显式设置为 true,以继续进行枚举。
-
创建一个委托,并将其作为参数传递给 EnumWindows 函数。 平台调用会自动将委托转换为常见的回调格式。
-
确保在回调函数完成其工作之前,垃圾回收器不会回收委托。 如果委托作为参数进行传递,或者所包含的委托作为结构中的字段进行传递,则该委托在调用期间不会被回收。 因此,正如下面的枚举示例所示,回调函数会在调用返回前完成其工作,而无需托管调用方执行额外的操作。
然而,如果可以在调用返回后调用回调函数,则托管调用方必须采取相应的措施来确保委托在回调函数完成其工作之前不会被回收。 有关防止垃圾回收的详细信息,请参见用平台调用进行互操作封送处理。
using System; using System.Runtime.InteropServices; public delegate bool CallBack(int hwnd, int lParam);//回调函数声明 public class EnumReportApp { [DllImport("user32")] public static extern int EnumWindows(CallBack x, int y); //调用主函数 public static void Main() { CallBack myCallBack = new CallBack(EnumReportApp.Report);//回调函数实例 EnumWindows(myCallBack, 0);//调用 } public static bool Report(int hwnd, int lParam)//实现函数 { Console.Write("Window handle is "); Console.WriteLine(hwnd); return true; } }