在尝试对16字节块进行原子加载时,我有链接错误.我有以下代码:
#include <atomic>
struct MyStruct{
long x; long y;
};
struct X{
std::atomic<MyStruct> myStruct;
};
int main(){
X x;
MyStruct s = atomic_load(&x.myStruct);
}
Run Code Online (Sandbox Code Playgroud)
当我使用(g ++版本5.3.1)编译它时:
g++ --std=c++11 test.cpp
Run Code Online (Sandbox Code Playgroud)
我收到了错误
/tmp/ccrvzLMq.o: In function `std::atomic<MyStruct>::load(std::memory_order) const':
test.cpp:(.text._ZNKSt6atomicI8MyStructE4loadESt12memory_order[_ZNKSt6atomicI8MyStructE4loadESt12memory_order]+0x1c): undefined reference to `__atomic_load_16'
collect2: error: ld returned 1 exit status
Run Code Online (Sandbox Code Playgroud)
如果(在另一篇文章中提示)我添加"-latomic"标志,我得到错误"/ bin/ld:找不到/usr/lib64/libatomic.so.1.1.0".事实上,该文件并不存在.
有什么建议?
加文
Clang 编译器也有同样的问题,简而言之:安装 libatomic 并与其链接。(在 RHEL 中,库已命名,libatomic.so.1因此您可能需要-l:libatomic.so.1设置名称)
https://releases.llvm.org/14.0.0/tools/clang/docs/Toolchain.html#libatomic-gnu
如果编译器不知道如何将“c++_atomic_operation_code”翻译成 CPU 指令,它会向 libatomic 寻求帮助。默认编译参数使程序更普遍地可以在 x86/64 CPU 上运行,因此某些 CPU 指令被禁用。
另一方面,使用 libatomic 将有机会以更快的速度执行更现代的指令,请参阅下面的评论。感谢@Peter Cordes
在 中-march=native,编译器可以利用更多的指令集来翻译代码。(你的CPU比Generial-x86/64-CPU)
或者链接libatomic以避免分配-march.
例如,使用tbb时,通常会要求libatomic来制定算法。
| 归档时间: |
|
| 查看次数: |
2407 次 |
| 最近记录: |