C++ 调用GetWindowRect时出现编译器错误

C++ 调用GetWindowRect时出现编译器错误,c++,winapi,compiler-errors,dev-c++,C++,Winapi,Compiler Errors,Dev C++,在MSDN示例中以相同的方式使用GetWindowRect时,我得到以下错误:, “无法将参数“2”的“RECT”转换为“tagRECT*”,而将参数“2”转换为“BOOL GetWindowRect(HWND_uu;,tagRECT)”,下面是复制错误的代码: #include <windows.h> LRESULT CALLBACK WindowProcedure (HWND, UINT, WPARAM, LPARAM); char szClassName[ ] = "Windo

在MSDN示例中以相同的方式使用
GetWindowRect
时,我得到以下错误:, “无法将参数“2”的“RECT”转换为“tagRECT*”,而将参数“2”转换为“BOOL GetWindowRect(HWND_uu;,tagRECT)”,下面是复制错误的代码:

#include <windows.h>
LRESULT CALLBACK WindowProcedure (HWND, UINT, WPARAM, LPARAM);
char szClassName[ ] = "WindowsApp";

int WINAPI WinMain (HINSTANCE hThisInstance, HINSTANCE hPrevInstance,
                LPSTR lpszArgument, int nFunsterStil)
{
 HWND hwnd;               
 MSG messages;            
 WNDCLASSEX wincl;        

 wincl.hInstance = hThisInstance;
 wincl.lpszClassName = szClassName;
 wincl.lpfnWndProc = WindowProcedure;     
 wincl.style = CS_DBLCLKS;                 
 wincl.cbSize = sizeof (WNDCLASSEX);

 wincl.hIcon = LoadIcon (NULL, IDI_APPLICATION);
 wincl.hIconSm = LoadIcon (NULL, IDI_APPLICATION);
 wincl.hCursor = LoadCursor (NULL, IDC_ARROW);
 wincl.lpszMenuName = NULL;                 
 wincl.cbClsExtra = 0;                      
 wincl.cbWndExtra = 0;                       
 wincl.hbrBackground = (HBRUSH) COLOR_BACKGROUND;

 if (!RegisterClassEx (&wincl))
    return 0;

 hwnd = CreateWindowEx (0, szClassName, "Windows App", WS_OVERLAPPEDWINDOW,
        CW_USEDEFAULT, CW_USEDEFAULT, 544, 375, HWND_DESKTOP, NULL, 
        hThisInstance, NULL);

 RECT blah;
 GetWindowRect (hwnd, blah);

 ShowWindow (hwnd, nFunsterStil);

 while (GetMessage (&messages, NULL, 0, 0))
 {
     TranslateMessage(&messages);
     DispatchMessage(&messages);
 }

 return messages.wParam;
 }


 LRESULT CALLBACK WindowProcedure (HWND hwnd, UINT message, WPARAM wParam,
 LPARAM, lParam)
 {
 switch (message)                  
 {
     case WM_DESTROY:
         PostQuitMessage (0);       
         break;
     default:                      
         return DefWindowProc (hwnd, message, wParam, lParam);
 }
 return 0;
}
#包括
LRESULT回调窗口过程(HWND、UINT、WPARAM、LPARAM);
char szClassName[]=“WindowsApp”;
int WINAPI WinMain(HINSTANCE hThisInstance、HINSTANCE HPPreInstance、,
LPSTR lpsz参数,int nFunsterStil)
{
HWND-HWND;
消息;
WNDCLASSEX wincl;
wincl.hInstance=hthis实例;
wincl.lpszClassName=szClassName;
wincl.lpfnWndProc=窗口程序;
wincl.style=CS_DBLCLKS;
wincl.cbSize=sizeof(WNDCLASSEX);
wincl.hIcon=加载图标(空,IDI_应用程序);
wincl.hIconSm=加载图标(空,IDI_应用程序);
wincl.hCursor=LoadCursor(空,IDC_箭头);
wincl.lpszMenuName=NULL;
wincl.cbClsExtra=0;
wincl.cbWndExtra=0;
wincl.hbrBackground=(HBRUSH)颜色背景;
if(!RegisterClass(&wincl))
返回0;
hwnd=CreateWindowEx(0,szClassName,“Windows应用程序”,WS_OVERLAPPEDWINDOW,
CW_USEDEFAULT,CW_USEDEFAULT,544375,HWND_桌面,空,
hthis实例,空);
直截了当的废话;
GetWindowRect(hwnd,blah);
显示窗口(hwnd、nFunsterStil);
while(GetMessage(&messages,NULL,0,0))
{
翻译消息(和消息);
DispatchMessage(&messages);
}
返回messages.wParam;
}
LRESULT回调窗口过程(HWND HWND,UINT消息,WPARAM WPARAM,
LPARAM,LPARAM)
{
开关(信息)
{
案例WM_销毁:
PostQuitMessage(0);
打破
违约:
返回DefWindowProc(hwnd、message、wParam、lParam);
}
返回0;
}

您需要传递
RECT
的地址,以便
GetWindowRect
可以更改它。该函数获取指向
RECT
RECT*
)的指针,但您正在传递
RECT

像这样修复它:

RECT blah;
GetWindowRect(hwnd, &blah);
                    ^

如果函数采用
RECT
,对它所做的任何更改都将被丢弃,因为它将按值传递(也就是说,将传入对象的副本)。
&blah
的结果是指针(而不是对象)按值传递,但该值仍然是对象的同一地址,因此更改该地址处的内容仍然存在。因此,一个概念是通过引用传递对象,另一个概念是通过实际引用传递对象。由于Windows API主要是在C中实现的,但是它使用的是更多的C-ISH方法,而不是引用,而C++通常更适合。p> 您需要传递
RECT
的地址,以便
GetWindowRect
可以更改它。该函数获取指向
RECT
RECT*
)的指针,但您正在传递
RECT

像这样修复它:

RECT blah;
GetWindowRect(hwnd, &blah);
                    ^

如果函数采用
RECT
,对它所做的任何更改都将被丢弃,因为它将按值传递(也就是说,将传入对象的副本)。
&blah
的结果是指针(而不是对象)按值传递,但该值仍然是对象的同一地址,因此更改该地址处的内容仍然存在。因此,一个概念是通过引用传递对象,另一个概念是通过实际引用传递对象。由于Windows API主要是在C中实现的,但是它使用的是更多的C-ISH方法,而不是引用,而C++通常更适合。p> 错误消息告诉您出了什么问题。我可以想象看到
RECT
tagRECT*
,而它真正的意思是
RECT
RECT*
,是多么令人困惑。这真的让错误失去了一些用处。错误消息告诉你出了什么问题。我可以想象看到
RECT
tagRECT*
,而它真正的意思是
RECT
RECT*
,是多么令人困惑。这确实让错误失去了一些用处。