我用 C++ 编程,使用 CAS 操作进行线程同步。
我使用 Vtune 分析了我的程序,发现大部分时间花在了 CAS 操作上。
我看了一下汇编代码。
分析结果显示大部分时间花在了“movq %rax, (%rsi)”上,而不是花在“lock cmpxchgq %rcx, (%rdi)”上。
'movq %rax, (%rsi)' 操作与 CAS 操作有什么关系? 此操作正在移动哪些数据?
最佳答案
lock cmpxchgq
花费了很长时间。当探查器确定程序当前所在的位置时,有时必须等待一条指令执行完毕才能找到。这会导致一条长的、不可中断的指令之后的指令被报告为占用大量时间,而实际上前一条指令确实如此冗长。
关于c++ - '__atomic_compare_exchange'汇编代码难懂,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42545946/