草庐IT

c++ - 带有 PAGE_GUARD 的 VirtualProtect 不使用局部变量

这按预期工作。引发了STATUS_GUARD_PAGE_VIOLATION。intmain(){DWORDoldp;DWORD*pdp=newDWORD;*pdp=0;if(!VirtualProtect(pdp,sizeof(DWORD),PAGE_READWRITE|PAGE_GUARD,&oldp))return1;*pdp=1000;return0;}然而,当运行这段几乎相同的代码时,程序无一异常(exception)地退出。intmain(){DWORDoldp;DWORDpd=0;DWORD*pdp=&pd;if(!VirtualProtect(pdp,sizeof(DWO

c++ - wchar_t 对 Windows API 有用吗?

当我#include在C或C++中,我被迫决定字符的格式,其中TCHAR要么等于char或wchar_t.我四处看了很多,就像thisone这样的帖子或类似this的网站指出wchar_t事情发生在UTF8之前的很久以前,并且由于各种原因,在现代编程中并不是一个特别好的Unicode解决方案。然而,这些并没有说明对已经在wchar_t中运行的现有系统的支持。.所以我的问题是,我应该使用哪一个?如果我使用普通的char这会在未来被MS放弃吗,因为在一天结束时,wchar_tAPI版本更新?或者如果我使用wchar_t,让我的代码在其他现代平台上运行会很痛苦吗,这些平台后来使用普通的旧ch

c++ - 为什么 GetFileAttributesW(L"C :") return FILE_ATTRIBUTE_REPARSE_POINT?

通常,GetFileAttributesW(L"C:")返回0x10(FILE_ATTRIBUTE_DIRECTORY),这是合理的。在某些情况下,GetFileAttributesW(L"C:")将返回0x2416(FILE_ATTRIBUTE_DIRECTORY|FILE_ATTRIBUTE_REPARSE_POINT|FILE_ATTRIBUTE_NOT_CONTENT_INDEXED)我想知道是什么让它发生以及如何摆脱它。这个问题使得boost::filesystem::canonical无法工作。你有什么主意吗? 最佳答案

c++ - 符号 (&) 在 .rc 文件中的含义

在Windows上使用WIN32编写Windows应用程序时,要非动态加载资源,必须加载一个*.rc文件,该文件包含用于定义应用程序中常见功能的资源定义语句,例如按钮和菜单。在阅读WIN32API的教程时,来自WinProg,我遇到了这段让我困惑的代码:IDR_MYMENUMENUBEGINPOPUP"&File"BEGINMENUITEM"E&xit",ID_FILE_EXITENDPOPUP"&Stuff"BEGINMENUITEM"&Go",ID_STUFF_GOMENUITEM"G&osomewhereelse",0,GRAYEDENDEND看了上面的代码,就明白是什么功能了。

windows - GetProcAddress 不返回 LoadLibraryA 的真实地址

DWORDdwLoadLibrary=(DWORD)GetProcAddress(GetModuleHandleA("kernel32.dll"),"LoadLibraryA");当我转到OllyDbg中的返回地址时,我可以看到该地址指向跳转到LoadLibraryA的真实地址的代码。我想获得LoadLibraryA的真实地址,它不会改变,因为kernel32.dll在每个进程中的相同位置加载,而且我想知道为什么GetProcAddress不返回真实地址。 最佳答案 您正在获取kernel32.LoadLibraryA的“真实”地址

c++ - 结构上溢出的整数加法

这个问题在这里已经有了答案:OverflowingofUnsignedInt(3个答案)C/C++unsignedintegeroverflow(4个答案)关闭5年前。有ULARGE_INTEGERunion对于不支持64位算术的编译器。如果最后一行的加法溢出,下面的代码会发生什么?ULARGE_INTEGERu;u.LowPart=ft->dwLowDateTime;u.HighPart=ft->dwHighDateTime;u.LowPart+=10000;//whatifoverflow?相关问题:WhatisthepointoftheULARGE_INTEGERunion?

C++ 函数为无法调用 SysFreeString() 的函数返回 BSTR

请耐心等待,我作为C++程序员已经有一段时间了。我需要知道我是否做错了。它有效,但我怀疑它会导致内存泄漏。我有这个功能:_bstr_tWCH2BSTR(wchar_t*st){BSTRstres=SysAllocString(st);return(_bstr_t)stres;}假设我要使用这样的结果:wcout这会导致内存泄漏,还是BSTR会被Java中的“垃圾收集器”删除?如果是内存泄漏,我怎样才能在不失去作为单行程序的能力的情况下防止它发生?有时WCH2BSTR的结果存储在BSTR变量中并正确处理,但我想使用相同的函数以单行方式将wchar_t连接到BSTR。谢谢。

c++ - wchar_t 和 char16_t 在 Windows 上是一样的吗?

我有一个std::u16string的实例,我可以将它的c_str()传递给需要LPCWSTR的Win32API,而无需任何类型的转换?例如,我可以安全地这样做吗:autou16s=std::u16string(u"Hello");::SetWindowTextW(hWnd,reinterpret_cast(u16s.c_str()));已更新,MSDN说herewchar_t是UTF-16LE,而char16_t只是没有指定字节序的UTF-16。那么可以安全地假设char16_t在Windows上也始终是UTF-16LE吗?或者那是特定于MSVC编译器的,因此如果我使用GCC编译,它

windows - "This file contained a virus and was deleted"在我构建(和代码签名)的可执行文件上

我已经构建了一个Windows可执行文件(使用MSVC++),需要管理员权限才能运行(它索引文件);我什至使用我购买的代码签名证书对其进行了代码签名。它在Win7、Win8上运行良好,但在Windows10上,如果我从浏览器下载文件,那么我会从IE/Edge收到此消息:Thisfilecontainedavirusandwasdeleted并且(非高级用户)用户几乎不可能访问ZIP、解压缩并运行.exe。(找到合适的检疫地点,解除检疫等等都是非常复杂的;而且对于商业产品来说也是不行的)很明显是误报(我没有病毒,用了很多杀毒软件都查过了,还有https://www.virustotal.

c++ - Windows VK_ 常量是如何声明的?

例如VK_LEFT、VK_DELETE、VK_ESCAPE、VK_RETURN等。它们是如何声明的,在哪里声明的?它们是常量、#defines还是其他?它们来自哪里?如果可能,请提供声明它们的文件名/路径。或者其他一些尽可能具体的信息。 最佳答案 这些是在PlatformSDK的winuser.h文件中使用#define声明的。在我安装的VisualStudio2008中,完整路径是C:\ProgramFiles\MicrosoftSDKs\Windows\v6.0A\Include\WinUser.h