C中无符号数与有符号数的运算

在C语言中,无符号数和有符号数是不同的数据类型,它们在内存中以不同的方式表示和处理。

对于有符号数,例如signed char、signed int、signed long等,使用最高位来表示正负号,剩余位表示数值。

例如,对于一个8位的有符号整数,范围通常是-128到127。

而对于无符号数,例如unsigned char、unsigned int、unsigned long等,所有的位都用于表示数值,没有正负号的区分。

例如,对于一个8位的无符号整数,范围是0到255。

当有符号数和无符号数进行混合运算时,C语言会将有符号数自动转换为无符号数进行计算。

这种隐式类型转换可能会导致一些意想不到的结果,因此在使用时需要格外小心。

例如,考虑下面这个例子:

cpp 复制代码
#include<stdio.h>

int main(){

    unsigned int a = 10;

    int b = -20;

    int c = a + b;



if (a+b > 0) {

// if (c > 0) {

    printf("%d\n",c);

    printf("%llu\n",b);

    printf("a + b is positive.\n");

} else {

    printf("%d\n",c);

    printf("%llu\n",b);

    printf("a + b is negative.\n");

}

    return 0;

}

在这个例子中,由于b是一个有符号数,它会在与无符号数a进行计算时被隐式转换为无符号数。

因此,-20会被当作一个非常大的正整数,计算结果可能不是我们期望的。

为了避免出现意外的结果,我们应该在混合运算之前进行显式的类型转换,或者确保有符号数和无符号数之间的操作是安全和正确的

相关推荐
半个落月2 小时前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
小月土星3 小时前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试
小月土星3 小时前
JavaScript 递归入门:从 1 到 n 求和,再到数组扁平化
javascript·算法·面试
To_OC18 小时前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
鱼鱼不愚与1 天前
《原来如此 | 第01期:为什么导航软件能预测红绿灯倒计时?》
算法
复杂网络1 天前
论最小 Agent 计算机的形态
算法
kisshyshy2 天前
🍦 雪糕、食堂、火车厢:三幅漫画吃透栈、队列与链表
javascript·算法
猿人谷2 天前
不只是 CPU 阈值:STAR 如何用 GAT + Transformer 做容器级自动扩缩容?
人工智能·算法
复杂网络2 天前
Stable Diffusion 视觉大模型微调技术深度调研
算法