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会被当作一个非常大的正整数,计算结果可能不是我们期望的。

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

相关推荐
To_OC15 小时前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode
05Kevin1 天前
lk每日冒险题--数据结构6.27
算法
To_OC2 天前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
千纸鹤安安2 天前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法
七牛开发者2 天前
MCP 到底是什么?为什么 Agent 都想接上它
算法·aigc·agent
kisshyshy2 天前
从递归到迭代,一文吃透二叉树的核心知识与 JavaScript 实现
javascript·算法·代码规范
To_OC3 天前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode