草庐IT

c++ - 创建进程处理

我使用WindowsAPICreateProcess函数。在它的msdn手册中,我找到了Ifthefunctionsucceeds,besuretocalltheCloseHandlefunctiontoclosethehProcessandhThreadhandleswhenyouarefinishedwiththem.Otherwise,whenthechildprocessexits,thesystemcannotcleanuptheprocessstructuresforthechildprocessbecausetheparentprocessstillhasopenhand

c++ - c++ new 运算符可以在 Windows 上自动使用大页面吗?

假设我使用VisualStudio编写了一个C++程序,它使用new运算符分配内存。我想知道是否有一种方法可以让new自动使用大页面而不是标准的4KB页面(即,我的程序无需显式调用VirtualAlloc)。感谢您的宝贵时间。 最佳答案 您可以覆盖所有new和delete运算符。例如void*operatornew(size_tsize){returnmalloc(size);}voidoperatordelete(void*pointer){free(pointer);}此外,您应该覆盖此运算符的所有变体:http://www.c

c++ - 在 C++ 中将 UnicodeString 转换为 const char* 的最简单方法?

我是C++的新手,在将UnicodeString转换为字符串时遇到问题,所以现在正在寻找从一种类型转换为另一种类型的最简单方法。我想使用需要字符串和UnicodeString的基本Windows函数,如何使代码工作?UnicodeStringExec="notepad";WinExec(Exec.c_str(),0);使用的环境是c++builderxe2 最佳答案 std::string不能存储unicode数据。为此你需要一个std::wstring。我以前从未听说过UnicodeString,但在这里查看API:http://

c++ - 检测 C++ Windows 应用程序中的内存泄漏

我有一个C++Windows应用程序,它有一些内存泄漏问题。是否可以使用NTSD分析转储中的内存泄漏?如果是这样,请指导我该怎么做?我还听说我们可以使用用户模式转储来完成。我不太熟悉在Windows中查找泄漏。在Linux中使用Valgrind非常容易。有没有其他更好的选择来检查这个? 最佳答案 seehere有关视觉检漏仪的详细信息。我在Windows上使用过它。您在应用程序中所做的就是#include您将在调试程序时看到有关在终端中检测到泄漏的报告,如下所示:----------Block1199at0x04BE1058:136

c++ - 通过 FS 寄存器访问衍生进程的 TIB?

我想访问衍生进程的TIB(我使用CreateProcessW成功创建了进程)。我通过以下方式获得了指向生成进程的TIB的指针:GetThreadContext(当然有权限设置)访问pContext.SegFs像这样格式化这个值:(ldtSel.HighWord.Bits.BaseHi(我不认为这是必要的)。格式后我剩下的值是一个10位指针。我如何使用这个变量代替fs寄存器来访问线程信息block?我访问它的常规方式通常是这样的:__asm{moveax,fs:[0x30]//PEBmovdwPebBase,eax}不过,用指针变量替换“fs”当然不行,去掉分号还有意想不到的效果。那么我

c++ - 包括它们在 C++、Windows 中的调用顺序

我有点困惑为什么会这样,我确信如果我用C++编程,这是我应该知道的基本知识,但问题是:我有一个“Windows.cpp”,它的顶部包含#include#include"Game.h"#include"Mouse.h"#include"Screen.h"...在我的Screen.h中,由于使用了DWORD,所以显然需要来自windows.h的信息:#pragmaonce#includeclassScreenServer;classScreenClient{public:ScreenClient(constScreenServer&server);DWORDGetScreenHeight(

c++ - std::map 中值的内存分配

我在学校工作中获得了一些C++经验。我了解到,除其他外,对象应该作为指针存储在容器(vector、map等)中。主要原因是我们需要使用new运算符以及复制构造函数,以便在对象的堆(也称为动态内存)上创建拷贝。此方法还需要定义一个析构函数。然而,从我从那以后读到的内容来看,STL容器似乎已经将它们包含的值存储在堆上。因此,如果我要将我的对象存储为值,无论如何都会在堆上创建一个拷贝(使用复制构造函数),并且不需要定义析构函数。总而言之,无论如何都会在堆上创建一个拷贝???此外,如果(真),那么我能想到的使用指针存储对象的唯一其他原因是减轻复制容器的资源需求,因为指针比整个对象更容易复制。但

c++ - 检索用户路径环境变量

我尝试在Windows上检索路径环境变量。因此,我尝试了#include#includeusingnamespacestd;intmain(){char*path=getenv("Path");cout这很好用,给了我一条路。我将它与我的实际路径进行了比较,发现我通过该程序检索到的路径是系统路径。但是,我不想获取系统路径,而是获取用户路径。我尝试更改"Path"的大小写,因为在我的系统上"path"指的是user路径变量,而"Path"指的是system路径变量,但getenv似乎忽略了这一点。如何获取system路径变量的值? 最佳答案

c++ - WIndows - 基于 list 的 ETW 提供程序问题

我有一个C/C++应用程序,我想在其中使用基于list的ETW解决方案。我在使用打开生成的*.etl的工具(如Windows或任何其他工具上的默认工具)时遇到问题,因为我看不到我的事件的具体细节(list中定义的模板)我如何将list注册到系统并将其指定给众所周知的ETW消费者工具以显示该信息?我做了http://www.codeproject.com/Articles/570690/Application-Analysis-with-Event-Tracing-for-Window中提到的事情mcFirstETW.man//includedgenerated*.rcinproject

c++ - 如何找到跳转列表窗口?

如何通过::FindWindow或::EnumWindows获取Windows7跳转列表窗口?类(class)或家长是什么?我不能Spy++它,因为如果失去焦点它就会消失。谢谢。http://msdn.microsoft.com/en-us/library/windows/desktop/aa511446.aspx 最佳答案 这里有一种类似于Spy++技术的方法,可以在使用事件Hook显示时立即通过代码找到它:voidCALLBACKWinEventProc(HWINEVENTHOOK,DWORD,HWNDhwnd,LONG,LON