草庐IT

shared_lib

全部标签

c++ - 为什么隐式 DLL 链接需要相关的 Lib 文件而显式链接不需要?

在Windows环境中,当我尝试显式(使用LoadLibrary)将DLL链接到我的程序时,首先我需要根据每个定义函数指针DLL中的函数签名。然后使用“GetProcAddress”获取函数地址并将它们分配给那些指针。当我尝试将DLL链接到我的程序时隐式(使用头文件)首先需要相关的头文件来获取函数签名。然后它需要用DLL生成的相关Lib文件。我的问题是为什么隐式链接也需要一个Lib文件?它需要从“Lib”文件中检索哪些无法从DLL或Header文件中获取的信息?如果有问题2,显式加载时如何检索信息?我已经通过了this问题。但我无法理解任何有值(value)的理由。拜托,有人可以帮助用

Docker下/var/lib/docker/overlay2空间清理

​1.查看磁盘占用df-h2.Docker的内置CLI指令dockersystemdf可用于查询镜像(Images)、容器(Containers)和本地卷(LocalVolumes)等空间使用大户的空间占用情况。dockersystemdf查看详细~]#dockersystemdf-v3.空间清理【1】通过Docker内置的CLI指令dockersystemprune来进行自动空间清理。~]#dockersystemprune--help该指令默认会清除所有如下资源:已停止的容器(container)未被任何容器所使用的卷(volume)未被任何容器所关联的网络(network)所有悬空镜像(

c++ - 使用 braced-init 初始化 std::shared_ptr<std::map<>>

我有以下shared_ptr到map:std::shared_ptr>我想使用braced-init来初始化它。可能吗?我试过:std::strings1("temp");std::shared_ptr>foo=std::make_shared>(1000.0,s1);但是在使用Xcode6.3编译时出现以下错误:/usr/include/c++/v1/map:853:14:Candidateconstructornotviable:noknownconversionfrom'double'to'constkey_compare'(aka'conststd::__1::less')fo

c++ - 如何为 std::shared_ptr<PureVirtualClass> 传递默认参数

我有一个类型的函数virtualvoidfoo(bla,bla,bla,std::shared_ptrlogger)=0;我想传递一个带有NULL指针的默认参数,例如:virtualvoidfoo(bla,bla,bla,std::shared_ptrlogger=NULL)=0;所以在实现中,如果logger是NULL我什么也不做,否则我使用logger。我试图寻找解决方案但找不到..UPD:重复声明无关紧要,我问的是默认NULL参数。有没有可能gcc4.4不支持nullptr? 最佳答案 你可以简单地这样做:virtualvoi

C++ 依赖注入(inject)——通过引用还是通过 boost::shared_ptr?

在需要构造函数依赖注入(inject)的情况下,使用引用注入(inject)与使用boost::shared_ptr注入(inject)有哪些注意事项?还有其他常见的方法吗?它与上述两种方法相比如何? 最佳答案 您可以选择如何管理要注入(inject)的对象的生命周期。整体架构可能会决定哪种选择最有意义。有了引用,更高层次的东西必须管理对象的生命周期;使用shared_ptr将自动管理生命周期。 关于C++依赖注入(inject)——通过引用还是通过boost::shared_ptr?,

c++ - 通过继承扩展 shared_ptr

做这样的事情有什么不好?classmyclass:publicstd::shared_ptr{//somecode,anallocationisneverdonestd::stringget_info(){if(*this!=nullptr)return""+(this->info*3)+"";elsereturn"";}};当类中没有分配时---只是像上面那样提供一些装饰? 最佳答案 原则上允许从STL类派生,参见here和here.但是,您必须知道您不应该使用指向基类的指针——即std::shared_ptr*。在这种情况下。所

C++11 闭包 shared_ptr

创建由shared_ptr管理的堆分配闭包的语法是什么。我想将闭包传递给函数并能够传递nullptr。似乎使用了shared_ptr但我无法理解从lambda表达式初始化它的语法 最佳答案 应该是这样的autolambda=[](){/*dosomethingusefull*/};autop=std::make_shared>(lambda);但实际上你可能不需要shared_ptr,因为function可以从nullptr构造。std::functionfnc(nullptr); 关于

c++ - std::make_shared 与 throw dtor 和 libc++ 不编译

这是非常基本的代码:#includeclassfoo{public:~foo()noexcept(false){}};intmain(){autox=std::make_shared();return0;}编译如下:g++-std=c++11test.cpp当使用libc++编译时,它会失败:/usr/bin/../include/c++/v1/memory:3793:7:error:exceptionspecificationofoverridingfunctionismorelaxthanbaseversionclass__shared_ptr_emplace^/usr/bin/.

c++ - 对于不同版本的 Microsoft Visual C++,已编译的 .lib 文件是否可以互换?

一些项目为C(和可能的C++-不确定)库提供了一组“Windows”二进制文件。例如,查看thislibxml-relatedpage右侧的链接.我很确定无法在VC++.lib文件和MinGWGCC.a文件之间进行转换,因此将它们称为“Windows”而不是“Microsoft”二进制文件似乎有点误导。但我也感到惊讶的是,对于不同的VC++版本显然不需要不同的二进制文件。我似乎记得,很多年前,在为跟踪器风格的音乐程序(JeskolaBuzz)编写插件时遇到问题,因为该程序使用的是VC++6,而我已升级到VC++7。我不记得确切的问题-它可能部分与DLL相关,但我知道那些不需要关心VC+

CMake Error at /usr/local/share/cmake-3.24/Modules/FindCUDA.cmake:859 (message): Specify CUDA_TOOL

问题从错误日志中可以看到,问题出在CMake无法找到CUDA工具包的根目录。错误消息是:CMakeErrorat/usr/local/share/cmake-3.24/Modules/FindCUDA.cmake:859(message):SpecifyCUDA_TOOLKIT_ROOT_DIR这意味着CMake需要知道CUDA工具包的安装位置,以便正确配置和构建denseflow。解决方式1为了解决这个问题,你需要设置CUDA_TOOLKIT_ROOT_DIR环境变量,指向CUDA的安装目录。通常,CUDA安装在/usr/local/cuda目录,但这可能因系统而异。你可以通过以下命令设置C