草庐IT

win_params

全部标签

c++ - COM 初始化和在 Win32 C++ DLL 中的使用

我正在编写一个使用COM查询WMI的Win32C++DLL。如何以编程方式确定COM是否已初始化?谢谢。 最佳答案 MarkRansom是对的直接、干净和简单的解决方案是要求调用者对COM进行初始化。丑陋的骇客您可以尝试第一次调用-可能是CoCreateInstance,如果它返回CO_E_NOTINITIALIZED,请自己运行CoInitialize(在这种情况下不要忘记取消初始化)但是,从DLL将CoInitialize“注入(inject)”到调用者线程中仍然存在问题。所以有一个清洁溶液让DLL创建一个工作线程(这意味着DL

win11 使用windows自带的Linux(Ubuntu)教程

1.去windows商店下载windows自己带的Ubuntu1.下载完成之后可能遇到的问题提示你的WSL版本过低的问题,我这里已经下载过了,就不演示了。不过还是建议在下载完Ubuntu之后去下面这个网址更新wsl版本解决:去微软官网下载最新的wsl版本:旧版WSL的手动安装步骤|MicrosoftLearn  尚未安装wsl解决:在搜索查找WindowsPowerShell用管理员的方式打开然后输入如下指令:Enable-WindowsOptionalFeature-Online-FeatureNameMicrosoft-Windows-Subsystem-Linux  等待其安装完成2.控

c++ - new[] 比 Win32 的 VirtualAlloc 快吗?

我正在测试一些字符串池分配器的性能:我考虑了提供的那个here调用VirtualAlloc然后分割出子分配,以及使用标准C++(不直接调用任何Win32API)和new[]的类似实现。我希望VirtualAlloc版本更快,因为我认为开销应该比C++new[]少;但我观察到的结果恰恰相反:使用new[]似乎比使用较低级别的VirtualAlloc产生更快的代码。我跑了几次测试(代码是用VS2010SP1编译的),输出是这样的:StringpoolusingVirtualAlloc:1280.07msStringpoolusingnew[]:799.193ms这是为什么?为什么new[]

c++ - 如何从 win32 应用程序的命令行参数中获取 std::string?

所以现在我有一个intmain(intargc,char*argv[]){}如何使它基于字符串?intmain(intargc,std::string*argv[])就够了吗? 最佳答案 你不能改变main的签名,所以这是你最好的选择:#include#includeintmain(intargc,char*argv[]){std::vectorparams(argv,argv+argc);//...return0;} 关于c++-如何从win32应用程序的命令行参数中获取std::st

封装win10系统并保存为iso格式【一】

封装WINDOWS10系统封装win10系统并保存为iso格式【一】:https://www.cnblogs.com/jw35/p/18006534封装win10系统并保存为iso格式【二】: https://www.cnblogs.com/jw35/p/18006738封装win10系统并保存为iso格式【完】: https://www.cnblogs.com/jw35/p/18006752一、准备工具:1、安装NTLite。下载链接:https://www.ntlite.com/download/2、准备一个ISO的PE例如:FirPE。下载链接https://firpe.cn/page-

C++ -- Detours (Win32 API Hijacking) -- 劫持类方法

很长一段时间我都没有遇到使用Detours劫持函数的问题...当我试图劫持类方法时(在我的例子中是IHTMLDocument2::writefrommshtml.dll)我遇到了无穷无尽的问题(主要是类型不匹配)。由于我没有在网上找到任何相关示例,我开始怀疑是否可以这样做。我的问题是:是否可以使用Detours劫持类方法?我可以举个例子吗?如果不是,是否可以使用另一个Hook库以更简单的方式劫持类方法?提前谢谢大家! 最佳答案 IHTMLDocument2::write不仅仅是一个类方法;这是一个COM方法。这意味着更多。例如,还有

c++ - 如何在没有延迟的情况下从 Win32 中的另一个进程捕获标准输出?

我想做的类似于VisualStudio在其输出窗口或其他编辑器在其工具窗口中所做的:从我的进程A启动另一个进程B并捕获其stdout/stderr输出。到目前为止,我使用CreatePipe()让它工作,但由于某种原因,B的输出在写入时并没有立即到达B。它的行为更像是某种缓冲区被填满,当缓冲区已满时,所有缓冲区内容立即到达A。我编写了自己的测试程序,该程序输出一些内容并随后直接执行fflush(stdout)。然后输出直接到达A。但是我不能更改我想那样使用的所有B进程的代码。尝试从A冲洗管道也不起作用。这应该如何工作?我的初始化代码和消费代码:sa.nLength=sizeof(SEC

c++ - 如何使用 Win32 Imaging API (Windows Mobile 6+) 将 HBITMAP 保存为 JPG?

我已经创建了将窗口截图保存到文件的程序。它适用于PNG和BMP,但不适用于JPG(和GIF)。下面是捕获HBITMAP的代码:HBITMAPSignature::getScreenHBITMAP(){//getscreenrectangleRECTwindowRect;GetWindowRect(getMainWnd(),&windowRect);//bitmapdimensionsintbitmap_dx=windowRect.right-windowRect.left;intbitmap_dy=windowRect.bottom-windowRect.top;//createbit

c++ - 为什么 boost::call_traits<double>::param_type 是 "const double&"而不是 "double"

我在win32program@windows7机器上使用代码“boost::call_traits::param_type”。令我惊讶的是,它不是“double”而是“constdouble&”。我认为所有原始类型都适合对函数参数使用“按值传递”,这不是常识吗?因为很多人会使用is_pod来判断是否使用引用,不是吗? 最佳答案 根据doc,该优化显然只适用于“小型”内置类型。.快速浏览source,看起来“小”类型被认为是满足sizeof(T)的类型.在32位机器上,这显然不包括double.在某些情况下,将参数传递为double可

c++ - 为什么win32线程不自动退出?

背景:在我用C++编写的应用程序中,我创建了一个工作线程,该工作线程又使用CreateThread()创建了两个线程.工作线程创建的两个线程通过使用WindowsWebServicesAPI实现的客户端与WCF服务通信。它提供C/C++应用程序编程接口(interface)(API),用于构建基于SOAP的Web服务和客户端。我的应用程序仅使用此API的客户端。问题:我面临的问题是,除工作线程外,所有其他线程都正常退出,正如您自己所见,在下图中WorkerThreadProc不使用CPU周期但它不导出。还有一些其他线程正在运行,它们不是由我创建的,而是由运行时创建的。线程状态如下(由P