草庐IT

weak-linking

全部标签

c++ - cmake:我必须按什么顺序指定 TARGET_LINK_LIBRARIES

我一次又一次地与链接器问题作斗争,因为必须以正确的顺序指定TARGET_LINK_LIBRARIES中的所有库。但是我怎样才能确定这个顺序呢?示例:我有以下库libAdependsonboostlibBdependsonpostgresqlandlibA(andthereforeonboost)myTargetuseslibA,libBandboostdirectly(andthroughlibBdependsonpostgresql)由于所有必需的库仅在创建可执行文件时才被链接,因此我必须在链接myTarget(最终可执行文件)时指定所有库:TARGET_LINK_LIBRARIES

c++ - 构造函数中的 weak_from_this()

我知道您不能在构造函数中使用shared_from_this。但是可以在构造函数中使用新的weak_from_this吗?根据cppreference:Thisisacopyofthetheprivatemutableweak_ptrmemberthatispartofenable_shared_from_this.http://en.cppreference.com/w/cpp/memory/enable_shared_from_this/weak_from_this我没有看到从构造函数中获取内部存储的weak_ptr拷贝的问题,但我可能遗漏了一些东西,所以我不确定这一点。

ST-Link配置使用与常见问题

目录一、资源下载二、 ST-Link配置三、使用ST-Link进行Debug调试四、遇到的问题一、资源下载ST-Link驱动下载链接:https://pan.baidu.com/s/1F33YmHH6K94ueJPI9XdBQQ?pwd=3kos 提取码:3kos也可通过官网下载:https://www.st.com/content/st_com/en/products/development-tools/software-development-tools/stm32-software-development-tools/stm32-programmers/stsw-link004.html

c++ - __attribute__ ((weak)) 的处理在 clang 和 gcc 中是不同的

我有一个应用程序(app)和一个动态库/共享对象(dlib),它们都链接到一个静态库,该静态库使用__declspec(selectany)在头文件中声明了一个全局变量(gvar)|/__attribute__((weak)).通过设计,app和dlib都应该有自己的gvar拷贝(在MSVC和GCC上我完全明白这一点)。移植到MacOSX并用clang编译后,我看到dlib中的gvar链接到应用程序中的gvar。不确定这是一个clang错误还是设计使然;如果是设计使然,是否有任何方法可以避免它并获得与GCC/MSVC中相同的行为?clang版本:bash-3.2$c++--versio

c++ - 加速 RcppArmadillo : How to link to OpenBlas in an R package

我正在开发一个使用RcppArmadillo的R包。我正在尝试利用OpenBLAS中更快的矩阵乘法。在documentation在C++armadillo库中,它说如果我们的机器上有OpenBLAS,那么Armadillo将使用OpenBLAS而不是BLAS。然而,当我编译我的R包时,我得到如下信息:g++-m64-std=c++11-shared-L/usr/lib64/R/lib-Wl,-z,relro-specs=/usr/lib/rpm/redhat/redhat-hardened-ld-oPackageTest.soclass1.oclass2.oclass3.oclass4

100天精通鸿蒙从入门到跳槽——第20天:ArkTS装饰器@Link双向数据绑定

博主猫头虎的技术世界🌟欢迎来到猫头虎的博客—探索技术的无限可能!专栏链接:🔗精选专栏:《面试题大全》—面试准备的宝典!《IDEA开发秘籍》—提升你的IDEA技能!《100天精通Golang》—Go语言学习之旅!《100天精通鸿蒙》—从Web/安卓到鸿蒙大师!100天精通鸿蒙OS(基础篇)

c++ - 如何使用 boost::filesystem 检查文件是常规文件还是符号链接(symbolic link)?

我想检查字符串name是否指向我可以打开和读取的文件,因此它可以是常规文件或符号链接(symboliclink)。我第一次用这个:std::ifstreamin(name.c_str());if(!in.is_open()){//throwexception!}但是当name引用目录名称时它没有抛出异常。现在我正在使用这个:if(!fs::exists(name)||fs::is_directory(name)){//throwexception!}但如果它是目录的符号链接(symboliclink),它(大概)不会抛出异常。这也是同样的道理:if(!fs::is_regular_fi

C++ 重复符号链接(symbolic link)器错误与适当的包含保护?

我正在编写一个程序来测试具体的继承,但我无法解决Clang返回的重复符号链接(symboliclink)器错误。我的理解是重复的符号总是不正确的包含/守卫的结果。我已经三次检查了我的包含/守卫,但我找不到任何错误。重复的符号可能是包含guard以外的其他东西的结果吗?非常感谢,随着我的编程技能的提高,我打算经常在这里做出贡献。.h#ifndefPOINTARRAY_H#definePOINTARRAY_H#include"array.h"namespaceJules{namespaceContainers{classPointArray:publicArray{public:Point

c++ - VS2015 CE - 无法找到 Link.exe

我正在尝试编译一些需要VisualStudio2015和C++支持的开源软件(Rust语言)。我的PATH变量必须包含link.exe的位置。我目前安装了VisualStudio2015CommunityEdition,以及两个C++Redistributables(x86和x64)。我无法在任何目录中找到link.exe。在哪里可以找到link.exe?它住在别的地方吗?我的安装是否损坏? 最佳答案 默认安装不包括C++工具。这可以通过在安装程序中启用编程语言->VisualC++选项来解决。

c++ - 我的 g++ 使用 vector<weak_ptr> erase() 方法生成奇怪的警告

我有以下C++代码:#include#include#include#includevoiderase_from_vector(std::vector>&mvec){for(automvec_it=mvec.begin();mvec_it!=mvec.end();)mvec_it=mvec.erase(mvec_it);}intmain(void){#if0std::vector>mvec;for(automvec_it=mvec.begin();mvec_it!=mvec.end();)mvec_it=mvec.erase(mvec_it);#endif}当我这样编译时,GCC会生成