c/c++中int类型的负数用强制类型转化为long long类型的讨论

本文探讨了一段C++代码中涉及类型转换和整数溢出的问题。当有符号窄整数直接转换为有符号宽整数时,符号位会被一同转换,而通过无符号中间层进行转换则不会处理符号,导致结果不同。博客揭示了这种差异及其原因,并提供了实验观察作为佐证。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天遇到一个问题,想分享一下,以下是运行代码:

#include <iostream>

int main(int argn, char ** argc)
{
    int int_num = 0xffffff00;

    //1
    unsigned int uint_num = (unsigned int)(int_num);
    unsigned long long ull_num = (unsigned long long)(uint_num);
    long long ll_num_1 = (long long)(ull_num);

    //2
    long long ll_num_2 = (long long)(int_num);

    std::cout << "ll_num_1:" << std::hex << ll_num_1 << std::endl;
    std::cout << "ll_num_2:" << std::hex << ll_num_2 << std::endl;
}

这段代码的运行结果是:

ll_num_1:ffffff00
ll_num_2:ffffffffffffff00

ffffff00是4294967040。

ffffffffffffff00是-256。

从输出结果来看为什么两个值是不一样的呢?

在遇到这个问题之前,我是认为,类型只是对变量的解析。例如int的int_num数值是0xffffff00,那么转化成long long之后,应该数据是没有变化的,所以应该是ffffff00,而不是ffffffffffffff00,那么为什么会出现上述代码中2的情况呢?

经过几次实验发现,如果有符号窄整数直接转化成有符号宽整数,那么符号位也会一起转化过去。但是如果先把有符号窄整数先转化为无符号的窄整数,然后再把无符号窄整数转化为无符号宽整数,这个时候因为是无符号的,所以是直接转化而没有符号处理,最后把无符号宽整数转化为有符号宽整数,这个时候得到的结果就是上述代码1的结果了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值