同一寄存器上的 xorp 的目的是什么
What is the purpose of xorps on the same register?
我正在查看以下反汇编的c ++代码
auto test2 = convert<years, weeks>(2.0);
00007FF6D6475ECC mov eax,16Dh
00007FF6D6475ED1 xorps xmm1,xmm1
00007FF6D6475ED4 cvtsi2sd xmm1,rax
00007FF6D6475ED9 mulsd xmm1,mmword ptr [__real@4000000000000000 (07FF6D64AFE38h)]
00007FF6D6475EE1 divsd xmm1,mmword ptr [__real@401c000000000000 (07FF6D64AFE58h)]
并且很好奇xorps xmm1, xmm1
指令的意义何在。似乎任何数字异或本身都会给出 0?如果是这样,清除寄存器的目的是什么?
注意:我只是出于纯粹的好奇心而问这个问题。我对汇编语言知之甚少。
XMM 寄存器有 128 位,使用 cvtsi2sd
只能填充低 64 位。因此,xorps
指令用于清除可能影响后续操作的垃圾值和/或依赖链。
基本上,您拥有的操作顺序是:
mov eax, 16Dh ; load 0x16D into lower 32 bits of RAX register
xorps xmm1, xmm1 ; zero xmm1
cvtsi2sd xmm1, rax ; load lower 32 bits from RAX into xmm1
<do more stuff with xmm1>
在装配中,当仅加载寄存器的一部分时,将寄存器归零的必要性非常常见,而后续指令在其全范围内运行。执行xor x, x
是通常的寄存器清除模式之一。
另请参阅此(非常详尽且很棒,根据评论)答案,以获取有关为什么xor
可以推荐给其他替代方案(mov x, 0
,and x, 0
)的更多详细信息。
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- C++避免重复声明的语法是什么
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 实现无开销push_back的最佳方法是什么
- C++从另一个类访问公共静态向量的正确方法是什么
- "throw expression code" 1e7 >返回 d 是什么?投掷标准::overflow_error( "too big" ) : d;意味 着?
- C++中名称篡改的目的是什么
- 在 c++ 中拥有一组结构的正确方法是什么?
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 是什么阻止DOMTimerCoordinator::NextID进入无休止的循环
- 派生类销毁的最佳实践是什么
- 这个语法std::class<>{}(arg1, arg2) 在C++中是什么意思?
- 通过JNI传递数据数组的最快方法是什么
- "using namespace std;"在C++的作用是什么?
- 在两台机器之间进行时间戳的最佳c++chrono函数是什么
- 文件系统:复制功能的速度秘诀是什么
- 用常见虚拟函数实现的任意组合来实现派生类的正确方法是什么
- 使用QQuickFramebufferObject时同步数据的最佳方式是什么
- 是什么原因导致它无法编译?它是声明签名还是在函数本身的实现中
- 同一寄存器上的 xorp 的目的是什么