草庐IT

DLL_THREAD_ATTACH

全部标签

c++ - 读取大文件时杀死 std::thread

我有一个std::thread函数调用fopen将一个大文件加载到一个数组中:voidloadfile(char*fname,char*fbuffer,longfsize){FILE*fp=fopen(fname,"rb");fread(fbuffer,1,fsize,fp);flose(fp);}调用者:std::threadloader(loadfile,fname,fbuffer,fsize);loader.detach();在某些时候,我的程序中的某些东西想要停止读取该文件并请求另一个文件。问题是当我删除fbuffer指针时,loader线程仍在运行,我得到了一个引发异常的竞争

c++ - std::type_index 跨 DLL 是否安全

假设我有一个主DLL,其中有一个这样的类:classTest{public:typedefstd::unordered_mapMap;templatevoidSetValue(intval){SetValue(std::type_index(typeid(T)),val);}templateintGetValue(){returnGetValue(std::type_index(typeid(T)));}protected://Definedin.cppfilevoidSetValue(conststd::type_index&idx,intval){m_Map[idx]=val;}/

c++ - 在不复制 .dll 的情况下运行 .exe

我已准备好交付VisualStudio2015解决方案。我要求.exe应该开箱即用。但是,我收到“缺少dll...”错误。有什么办法可以让某人运行exe而无需下载一堆ddls吗?我能否以某种方式将.exe构建为可独立执行? 最佳答案 是的,您必须静态链接二进制文件。在项目设置(ConfigurationProperties->C/C++->CodeGeneration)中,分别使用/MT、/MTd作为Release、Debug配置。但是,这会增加可执行文件的大小。MSDNdocumentationon/MT,/MTdoptions

c++ - Valgrind 下 Mac OS 上的 std::thread.join() SIGSEGV

以下简单代码(C++11)将仅在MacOS和Linux上运行:#include#include#includevoidthreadFunction(){for(intcc=0;cc但是,在Valgrind中包装执行:valgrind--leak-check=full--show-reachable=no--track-fds=yes--error-exitcode=1--track-origins=yes./theexecutable...它现在可以在Linux上运行,但不能在MacOSX上运行,失败:==47544==Processterminatingwithdefaultacti

c# - 将 char * 从 C# 字符串传递到 C DLL

我需要在C#应用程序的DLL中使用C函数库。我在使用char*参数调用DLL函数时遇到问题:CDLL:extern"C"__declspec(dllexport)intCopyFunc(char*,char*);intCopyFunc(char*dest,char*src){strcpy(dest,src);return(strlen(src));}C#应用程序需要看起来像这样:[DllImport("dork.dll")]publicstaticexternintCopyFunc(stringdst,stringsrc);intGetFuncVal(stringsource,stri

c++ - 我可以跨 DLL 边界传递 FILE 对象吗?

我有一个C++框架,其中一些计算被委托(delegate)给(有时是自动生成的)C函数或具有外部“C”链接的C++函数。这些是低级例程,必须以极快的速度和最小的开销进行评估,它们通常驻留在单独的共享对象/DLL中。他们目前的签名是这样的:intmy_generated_function(constdouble*input,double*output,double*work);它将驻留在共享库中,在POSIX上使用dlopen或在Windows上使用LoadLibrary加载。在POSIX上使用dlsym(handle,"my_generated_function")或在Windows上

c++ - std::thread vs pthread,我做错了什么?

我正在从事一个需要在docker容器内执行某些进程的项目。我想处理进程没有按时终止的情况(比如说在10秒内)。我正在使用这个DockerClientpp用于管理基本上只向Docker套接字发出HTTP请求的容器的库。到目前为止一切都很好。要停止花费太长时间的容器,我使用了一个单独的线程。问题是我能够使用ptheads来实现它,但是我找不到使用std::thread和lambas的方法这是我使用pthread的工作实现void*ContainerManager::spawnKiller(void*ref){ContainerManager*self=(ContainerManager*)

c# - 将 native DLL 和程序集合并为一个 DLL

我目前正在使用C++和C#进行编程。在数值计算部分使用原生C++。最初我打算使用C++/CLI为nativeC++类制作一个包装器,但我发现它会导致2到4倍的减速。所以我决定将我的原生C++编译成一个DLL并通过P/Invoke调用.NET/C#.我将在C#中进行数据预处理,在nativeDLL中进行数字运算。问题是,当我将我的作品交付给其他人使用时,我希望它是单个DLL。这可能吗?顺便说一句,我有原生C++的所有源代码。 最佳答案 通过生成网络模块,您可以非常轻松且完全支持地做到这一点。将组合的C++和C++/CLI代码编译成.o

c++ - 将静态库链接到 DLL

我正在使用VisualStudio5.0我有DLL和静态库。我的意图是使用静态库中定义的静态函数。我已将头文件包含在预期的源cpp中,并在项目依赖项中给出了路径。它仍然给我链接器错误。以下是链接错误errorLNK2019:unresolvedexternalsymbol"public:staticbool__cdeclgph::IsA(classPtOnDemand&,wchar_tconst*)"(?IsA@gph@@SA_NAAVPtOnDemand@@PB_W@Z)referencedinfunction"private:int__thiscallPtXMLP::HandleO

c++ - GCC 仅从 dll 导出修饰函数名称

我有一个dll,它导出一个函数...extern"C"int__stdcallMP_GetFactory(gmpi::IMpUnknown**returnInterface){}我使用Code::BlocksGCC编译器(V3.4.5)编译它。问题:生成的dll导出修饰函数名称...MP_GetFactory@4加载失败,应该是旧的...MP_GetFactory我已经为此研究了大约4个小时。我认为--add-stdcall-alias是解决此问题的选项。我的代码::block日志显示...mingw32-g++.exe-shared-Wl,--out-implib=bin\Debug