gpt4 book ai didi

c - 如何在 C 中将 2 个带符号的 32 位数字转换为 64 位数字

转载 作者:太空宇宙 更新时间:2023-11-04 08:29:51 26 4
gpt4 key购买 nike

a和b是同一个数的上半部分和下半部分。现在我必须将这个数字保存到 64 位寄存器中。假设 a = -1(高字节)和 b = -50。我怎样才能做到这一点 ?

我正在使用以下适用于正数的方法。

int64_t c = (a);
c = (c<<32);
c+=b;

以上不适用于 -ve 个数字。如何做到这一点?

编辑:上面的 -ve 数字代码为 -50 提供了一个非常大的值。基本上这意味着在操作后“c”的值应该是-50,但它应该是 64 位。作为上半部分,即“a”为 -1 并充当有符号位。下半部分有一个 -ve 符号,由于移位操作,它的值非常大。我希望这更清楚一点。

最佳答案

假设你的意思是直接按位替换而不用符号扩展,那么我想你想替换

c += b;

在你的代码中

c |= (uint32_t)b; 

对于 a = -1 和 b = -50,这将使 c = 0xffff.ffff.ffff.ffce

对于 a = -1 和 b = 50,这将使 c = 0xffff.ffff.0000.0032

对于 a = 1 和 b = -50,这将使 c = 0x0000.0001.ffff.ffce

对于 a = 1 和 b = 50,这将使 c = 0x0000.0001.0000.0032

关于c - 如何在 C 中将 2 个带符号的 32 位数字转换为 64 位数字,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28911524/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com