草庐IT

VC_redist.x86

全部标签

c++ - VC 选择错误的 operator<< 仅在第一次调用时重载。漏洞?

我花了一些时间删除所有无影响的代码,这就是我的问题。---File.h---#include#includetemplateclassDataOutput:publicstd::basic_ofstream{public:DataOutput(conststd::string&strPath,boolbAppend,boolbBinary):std::basic_ofstream(strPath.c_str(),(bAppend?ios_base::app:(ios_base::out|ios_base::trunc))|(bBinary?ios_base::binary:0)){if

c++ - 为 X86 创建 native 应用程序?

有没有一种方法可以让我制作一个C或C++程序,它可以在没有操作系统的情况下运行,并且会在左上角绘制一个红色像素之类的东西?我一直想知道这些类型的应用程序是如何制作的。由于Windows是用C编写的,我想有一种方法可以做到这一点。谢谢 最佳答案 如果你正在为一个裸处理器编写代码,根本没有库支持,你将不得不获取所有硬件手册,弄清楚如何访问你的显存,并执行硬件需要的任何操作以获得一个绘制到显示器上的像素(或蜂鸣器上的声音,或从磁盘读取的内存块,或其他)。当您使用操作系统时,您将依赖设备驱动程序来了解这一切。每天仍在为没有操作系统的平台编写

c++ - 用 VC10 (sp1) 编译的 C++ 库可以通过用 VC11 编译的代码链接吗?

问题说明了一切。我知道VC11目前仅处于测试阶段,但我要问的是:具有尝试与使用vc10编译的闭源(如果可能,广泛使用)库链接的经验Microsoft的规范明确说明vc11是否能够与vc10库链接。我只是在谈论C++的情况。 最佳答案 关于动态链接的情况,您可能需要阅读thisanswer。关于静态链接,我认为您不能安全地将用VCx编写的C++库与用VCy编译的代码链接起来。例如,STL容器实现因版本而异(即使在同一版本中,调试和Release模式之间也存在变化,以及_HAS_ITERATOR_DEBUGGING等设置)。Quotin

c++ - 全局 Hook 是否可以跨 x86 和 x64 工作

我试图将所有内容嵌入到一个COMdll中。目前我按如下方式连接了WH_GETMESSAGE和WH_CBT:BOOLTouchDetector::SetMessageHook(BOOLInstall){if(Install){return((mHookMessage=::SetWindowsHookEx(WH_GETMESSAGE,MessageHookProc,mDll,0))!=NULL)&&((mHookWin=::SetWindowsHookEx(WH_CBT,WinHookProc,mDll,0))!=NULL);}else{returnUnhookWindowsHookEx(

c++ - 架构 x86_64 的 undefined symbol : OS X, Boost Log,CMake

链接的另一个问题OSX10.9.5x64跨平台项目正在使用CMake工具链构建。使用boost。将所有可执行文件与BoostLog链接时出错(肯定找到了BOOST_PATH,单元测试与Boost测试链接成功)首先尝试。使用Clanggcc-vAppleLLVMversion6.0(clang-600.0.56)(basedonLLVM3.5svn)Target:x86_64-apple-darwin13.4.0Threadmodel:posix建筑boost./bootstrap&&./b2threading=multilink=staticruntime-link=staticins

c++ - VC++ 堆栈跟踪不解析生产中的函数名称

我最近使用boost'snewstacktracelibrary实现了堆栈跟踪日志记录:intdebugErrorCallback(intstatus,constchar*func_name,constchar*err_msg,constchar*file_name,intline,void*userdata){boost::stacktrace::stacktracestacktrace(4,10);//skipped4framesincludecv::error,thisfunctionand2inboost::stacktracectorstd::cout在我的开发机器上进行了测

c++ - 使用 C++ 和 EasyHook 注入(inject) x64 进程 Hook x86-DLL 的 x64-DLL 失败

注入(inject)x64进程的x64-DLL使用C++和EasyHookHookx86-DLL失败。如果Loader、InjectionLibrary和InjectionTarget(它在两个版本中都可用,我需要两者都被Hook)是x86,它就可以工作。获取导出过程的地址(GetProcAddress本身)在x64上不是问题。InjectionTarget也有HookTarget(Kernel32.dll)作为x64的依赖项。LhInstallHook(...)返回STATUS_NOT_SUPPORTED,其中源评论说在以下情况下发生:“目标入口点包含不受支持的指令。”由于源适用于x

VC++中使用OpenCV进行颜色检测

VC++中使用OpenCV进行颜色检测在VC++中使用OpenCV进行颜色检测非常简单,首选读取一张彩色图像,并调用函数cvtColor(img,imgHSV,COLOR_BGR2HSV);函数将原图img转换成HSV图像imgHSV,再设置好HSV三个分量的上限和下限值,调用inRange函数inRange(imgHSV,lower,upper,mask);将HSV色彩图像转换成掩码图,掩码图中只有黑白二值图像,从而达到颜色检测的目的。颜色检测通常可以用于物体检测和跟踪中,尤其在不同的图像和物体中根据特定的颜色去筛选出某个物体。RGB色彩空间和HSV色彩空间RGB色彩空间是一种被广泛接受的色

c++ - VC++11 映射和多映射迭代器(重载)C2535

我正在玩新的VS2012,我可能对新的C++11有疑问。当我在项目设置中将平台工具集设置为VS2010(v100)时,这段代码完美运行。.h:typedefstd::multimapSizeMap;typedefstd::mapOffsetMap;private:inlinevoid_RemoveBlockL(SizeMap::iteratorsizeI);inlinevoid_RemoveBlockL(OffsetMap::iteratoroffsetI);.cpp:inlinevoidFoo::_RemoveBlockL(SizeMap::iteratorsizeI){//impe

c++ - VC++ 和 GCC 下 boost::condition_variable 的不同行为

在我的计算机上,在Windows7上运行,以下代码在带有Boost1.53的VisualC++2010中编译,输出notimeoutelapsedtime(ms):1000使用GCC4.8编译的相同代码(onlinelink)输出timeoutelapsedtime(ms):1000我的意见是VC++输出不正确,应该是timeout。有没有人在VC++中有相同的输出(即notimeout)?如果是,那么它是否是boost::condition_variable的Win32实现中的错误?代码是#include#includeintmain(void){boost::condition_v