草庐IT

pthreads-win

全部标签

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

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

c++ - pthread_create 段错误

我在我的程序中使用“pthread_create”方法,并在该方法中出现段错误。什么可能导致这个?我正在使用正确的参数类型调用此函数!这是代码:pthread_t*_daemon;void*writer(void*arg){//stuffthatdontinvolve"arg"...}intinitdevice(){if(pthread_create(_daemon,NULL,&writer,NULL)!=0)//seginthisline{cerr注意:在调用pthread_create中的writer之前,我也尝试在没有“&”的情况下运行它,而且-我们尝试向该方法发送一些void*

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

c++ - 一旦 std :thread makes into C++Ox,pthreads 会过时吗

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭5年前。Improvethisquestion显然我们仍会维护它,但一旦C++标准保证可用,它会有多大用处。随着新标准的出现,同步原语(Mutex、条件变量)会怎样?您是否认为pthread比std::thread更难掌握?

封装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++ - 如何用 "-pthread"而不是 "-mthread"编译 boost_thread?

我有一个操作系统,编译时没有可用的-mthread。我有-pthread。如何用-pthread而不是-mthread编译boost_thread?我当前的编译器构建日志:./b2-j1--with-threadlink=static--prefix=./install-dirreleasethreading=multi--builddir=./build-dirinstallComponentconfiguration:-chrono:notbuilding-context:notbuilding-date_time:notbuilding-exception:notbuilding

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

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