005 windows消息机制

Posted ☆﹎夜﹎☆

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了005 windows消息机制相关的知识,希望对你有一定的参考价值。

#windows消息机制

    新建第一个Win32应用程序 

    VS2015 新建项目 Win32应用程序

 

// Win32WindowDemo.cpp : 定义应用程序的入口点。
//

#include "stdafx.h"
#include "Win32WindowDemo.h"

#define MAX_LOADSTRING 100

// 全局变量: 
HINSTANCE hInst;                                // 当前实例
WCHAR szTitle[MAX_LOADSTRING];                  // 标题栏文本
WCHAR szWindowClass[MAX_LOADSTRING];            // 主窗口类名

// 此代码模块中包含的函数的前向声明: 
ATOM                MyRegisterClass(HINSTANCE hInstance);
BOOL                InitInstance(HINSTANCE, int);
LRESULT CALLBACK    WndProc(HWND, UINT, WPARAM, LPARAM);
INT_PTR CALLBACK    About(HWND, UINT, WPARAM, LPARAM);

//程序入口点

//#define CALLBACK __stdcall    VS默认用的是 __stdcall
//#define WINAPI __stdcall      VS默认用的是 __stdcall
//#define WINAPIV __cdecl       其他版本用编译器用的是 __cdecl
//#define APIENTRY WINAPI

//栈 -》 传递参数

//栈帧 -》 平栈

//__stdcall 是函数调用预定的一种,函数调用约定主要约束了两件事。

  //1.参数传递顺序

  //2.调用堆栈由谁(调用函数或被调用函数)清理

  常用的函数调用约定:stdcall cdecl fastcall thiscall naked call

int APIENTRY wWinMain(_In_ HINSTANCE hInstance,       //int型 wWinMain tWinMain WinMain  不同的编码模式 ASCII UNCIODE
                     _In_opt_ HINSTANCE hPrevInstance,
                     _In_ LPWSTR    lpCmdLine,
                     _In_ int       nCmdShow)
            
            //HINSTANCE hInstance 内核对象 实例对象       操作系统告诉我们
            //HINSTANCE hPrevInstance 启动我的这个进程是谁   操作系统告诉我们
            //lpCmdLine    接收参数运行成           用户告诉我们的

            //nCmdShow      启动的方式            用户高速我们的 { UNREFERENCED_PARAMETER(hPrevInstance); UNREFERENCED_PARAMETER(lpCmdLine);

      //两个宏定义
// TODO: 在此放置代码。 // 初始化全局字符串 LoadStringW(hInstance, IDS_APP_TITLE, szTitle, MAX_LOADSTRING); LoadStringW(hInstance, IDC_WIN32WINDOWDEMO, szWindowClass, MAX_LOADSTRING);

    //
LoadStringW 进行字符串的加载
    //IDS 资源表里面定义的字符串 一个是程序的标题 一个是 窗口类名
    // 国际化 多元化 的一种方式
    MyRegisterClass(hInstance); //向系统注册窗口类

    // 执行应用程序初始化: 
    if (!InitInstance (hInstance, nCmdShow))
    {
        return FALSE;
    }

    HACCEL hAccelTable = LoadAccelerators(hInstance, MAKEINTRESOURCE(IDC_WIN32WINDOWDEMO));

    MSG msg;

    // 主消息循环: 
    //获取消息
    //&msg 结构体
      typedef struct tagMSG{
          HWND hwnd       窗口实例
          UINT message;    窗口消息
          WPARAM wParam    附加值
          LPARAM lParam;    附加值
          DWORD time;     消息时间
          POINT ps;      鼠标位置
        }
while (GetMessage(&msg, nullptr, 0, 0)) { if (!TranslateAccelerator(msg.hwnd, hAccelTable, &msg)) { TranslateMessage(&msg); DispatchMessage(&msg); } } return (int) msg.wParam; } // // 函数: MyRegisterClass() // // 目的: 注册窗口类。 // ATOM MyRegisterClass(HINSTANCE hInstance) { WNDCLASSEXW wcex; wcex.cbSize = sizeof(WNDCLASSEX); wcex.style = CS_HREDRAW | CS_VREDRAW;                      //窗口风格 wcex.lpfnWndProc = WndProc;                               //窗口类 wcex.cbClsExtra = 0;                                  //预留空间的附加值,此程序没用到这个域! wcex.cbWndExtra = 0;                                  //预留空间的附加值,此程序没用到这个域! wcex.hInstance = hInstance;                             //实例句柄,主函数的参数之一! wcex.hIcon = LoadIcon(hInstance, MAKEINTRESOURCE(IDI_WIN32WINDOWDEMO)); //装载图标函数,在这可以装载自己的图标! wcex.hCursor = LoadCursor(nullptr, IDC_ARROW);                 //装载光标函数,在这可以装载自己的光标! wcex.hbrBackground = (HBRUSH)(COLOR_WINDOW+1);                    //初始化窗口的画刷 wcex.lpszMenuName = MAKEINTRESOURCEW(IDC_WIN32WINDOWDEMO);            //窗口菜单 wcex.lpszClassName = szWindowClass;                          //程序名字! wcex.hIconSm = LoadIcon(wcex.hInstance, MAKEINTRESOURCE(IDI_SMALL)); return RegisterClassExW(&wcex); //// 函数: InitInstance(HINSTANCE, int)//// 目的: 保存实例句柄并创建主窗口
//
//   注释: 
//
//        在此函数中,我们在全局变量中保存实例句柄并
//        创建和显示主程序窗口。
//
BOOL InitInstance(HINSTANCE hInstance, int nCmdShow)
{
   hInst = hInstance; // 将实例句柄存储在全局变量中

   HWND hWnd =  CreateWindowW(szWindowClass,             //应用程序在操作系统注册表中的名称
          szTitle,                         
//应用程序标题栏名称
          WS_OVERLAPPEDWINDOW,                 
//窗口风格       CW_USEDEFAULT,                      //窗口显示时左上角x坐标
          0,                            
//窗口显示时左上角y坐标
          CW_USEDEFAULT,                     
//窗口显示时右下角x坐标
          0,                            
//窗口显示时右下角y坐标
          nullptr,                         
//父窗口句柄,此程序没有
          nullptr,                         
//菜单句柄
          hInstance,                       
//handle程序实例句柄if (!hWnd) { return FALSE; } ShowWindow(hWnd, nCmdShow);          //显示窗口 UpdateWindow(hWnd); return TRUE; }

 

//
//  函数: WndProc(HWND, UINT, WPARAM, LPARAM)
//
//  目的:    处理主窗口的消息。
//
//  WM_COMMAND  - 处理应用程序菜单
//  WM_PAINT    - 绘制主窗口
//  WM_DESTROY  - 发送退出消息并返回
//
//
#消息是已整数形式传送的
LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
              //HWND 实例
              //message 消息队列
              //附加值
              //附加值
{
    switch (message)
    {
    case WM_COMMAND:
        {
            int wmId = LOWORD(wParam);
            // 分析菜单选择: 
            switch (wmId)
            {
            case IDM_ABOUT:
                DialogBox(hInst, MAKEINTRESOURCE(IDD_ABOUTBOX), hWnd, About);
                break;
            case IDM_EXIT:
                DestroyWindow(hWnd);
                break;
            default:
                return DefWindowProc(hWnd, message, wParam, lParam);
            }
        }
        break;
    case WM_PAINT:
        {
            PAINTSTRUCT ps;
            HDC hdc = BeginPaint(hWnd, &ps);
            // TODO: 在此处添加使用 hdc 的任何绘图代码...
            EndPaint(hWnd, &ps);
        }
        break;
    case WM_DESTROY:
        PostQuitMessage(0);
        break;
    default:
        return DefWindowProc(hWnd, message, wParam, lParam);
    }
    return 0;
}

// “关于”框的消息处理程序。
INT_PTR CALLBACK About(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
{
    UNREFERENCED_PARAMETER(lParam);
    switch (message)
    {
    case WM_INITDIALOG:
        return (INT_PTR)TRUE;

    case WM_COMMAND:
        if (LOWORD(wParam) == IDOK || LOWORD(wParam) == IDCANCEL)
        {
            EndDialog(hDlg, LOWORD(wParam));
            return (INT_PTR)TRUE;
        }
        break;
    }
    return (INT_PTR)FALSE;
}

 

#MFC  Win32 

  由于win32 开发程序比较繁琐复杂

      消息体系

  MFC其实就是将 消息和方法 封装成了 类

   MFC中 函数 跟win32 api 函数的参数是不一样的..

    MSDN MFC是中文的 win32 api 是英文的

    

以上是关于005 windows消息机制的主要内容,如果未能解决你的问题,请参考以下文章

005JVM的垃圾回收机制是用来干嘛的?为什么要垃圾回收?

windows 7中内存保护机制不包括哪项技术?

windows消息机制是怎么一回事?谢谢!

windows程序消息循环机制

windows消息处理机制的消息内容

hook技术需要了解windows消息机制吗