举个例子给你
在 Form1 中拖一个button1, 双击后会生成
private void button1_Click(object sender, EventArgs e) { }在 Form1.designer.cs 文件中, 会自动订阅(绑定)上面这个方法
this.button1.Click += new System.EventHandler(this.button1_Click)System.EventHandler 是一个委托, 原型如下(可点击EventHandler后按F12看到)
public delegate void EventHandler(object sender, EventArgs e)上面这个委托的原型声明了两个参数, 如果你将 button1_Click 方法的参数删除了一个, 那么 button1_Click 方法就不再匹配订阅的委托, 编译器丛慧不会通过, 提示如下
“button1_Click”的重载均与委托“System.EventHandler”不匹配这里所谓的重载, 就颂蔽是编译器在编译时会去查找所有野郑州叫 button1_Click 的方法, 只要有一个匹配 (object sender, EventArgs e) 这样的参数原型, 就不会报上面那个错误, 而查找了所有都没有一个匹配, 就报错了.
这里的重载就是指所有叫 button1_Click 的方法, 可以翻译为
名称为“button1_Click”的所有方法均与委托“System.EventHandler”不匹配步骤:
1、注册窗口类;
2、创建窗体;
3、消息循环;
4、编写窗口消息处理函数。
代码:
#include <windows.h>#include<tchar.h>
LRESULT CALLBACK WindowProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
int WINAPI _tWinMain (HINSTANCE hInstance, HINSTANCE hPrevInstance, LPWSTR szCmdLine, int nCmdShow)
{
WNDCLASS wc
wc.style = CS_HREDRAW | CS_VREDRAW
wc.lpfnWndProc = WindowProc
wc.cbClsExtra = 0
wc.cbWndExtra = 0
wc.hInstance = hInstance
wc.hIcon = NULL
wc.hCursor = LoadCursor(NULL,IDC_ARROW)
wc.hbrBackground = (HBRUSH)COLOR_WINDOW//(HBRUSH)GetStockObject()
wc.lpszMenuName = NULL
wc.lpszClassName = _T("MyWindowClass")
if (!RegisterClass(&wc))
{
MessageBox (NULL, _T("无法注册窗口类"), _T("错误"), MB_OK)
return 0
}
HWND newWindow = CreateWindow(
蠢乱链 _T("MyWindowClass"),
_T("我的第一个winapi程序"),
WS_OVERLAPPEDWINDOW,
0,
0,
CW_USEDEFAULT,
CW_USEDEFAULT,
NULL,
NULL,
hInstance,
NULL
)
if (NULL == newWindow)
{
MessageBox (NULL, _T("无法创建窗体"), _T("错误"), MB_OK)
return 0
}
ShowWindow(newWindow, nCmdShow)
UpdateWindow(newWindow)
MSG msg
while(GetMessage(&msg, NULL, 0, 0))
{
TranslateMessage(&msg)
DispatchMessage(&msg)
}
}
LRESULT CALLBACK WindowProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
{
switch (uMsg)
{
case WM_DESTROY:
{
陪雹PostQuitMessage(0)
break
}
default :
return DefWindowProc(hwnd, uMsg, wParam, lParam)
}
return 0
}
就是一个只有标带孙题栏、关闭按钮、最小化按钮、最大化/还原按钮、显示区域的窗体。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)