2360985396 发表于 2023-8-18 09:49:13

关于C语言 无符号数 和 有符号 数的运算问题

keil5 stm32 在进行如下代码时   
    unsigned int a = 6;
    int b = -20;
   while(a+b > 1)
    {
       study();
    }
答案是会进入study 为什么得到的结果是a+b >1 呢? 无符号数和有符号数运算的结果到底是怎样的? 请教一下大家

eric2013 发表于 2023-8-18 12:44:01

看反汇编,有符号转无符号后相加



    55:         unsigned int a = 6;
0x08103C1E 2006      MOVS          r0,#0x06
    56:   int b = -20;
    57:         
0x08103C20 F06F0113MVN         r1,#0x13
    58:      while(a+b > 1)
    59:   {
0x08103C24 1844      ADDS          r4,r0,r1




2360985396 发表于 2023-8-18 13:38:07

eric2013 发表于 2023-8-18 12:44
看反汇编,有符号转无符号后相加




谢了 硬汉哥看来下次做运算的时候尽量是相同类型的 不然数据很容易是意想不到的{:13:}

caicaptain2 发表于 2023-8-21 08:37:35

本帖最后由 caicaptain2 于 2023-8-21 08:48 编辑

eric2013 发表于 2023-8-18 12:44
看反汇编,有符号转无符号后相加



还不一定都是优先转无符号的。
网上找到个说明:


① 当一个int类型的a与unsigned int类型的b相运算时,例如:a+b的时候,如果直接是a+b的话,各个变量就会隐式转换成为unsigned int的类型再相加。

② 当用print函数指定打印的时候,例如:printf(”%d\n”,a+b),就要各个变量转换为%d的类型再想加。

③ 当用一个int c类型去装这个结果时,如:c=a+b,同理,a和b会根据c的类型去分别转换跟c一致的类型再去运算。
————————————————
版权声明:本文为CSDN博主「杨 戬」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_45525272/article/details/120246756

eric2013 发表于 2023-8-21 09:02:09

caicaptain2 发表于 2023-8-21 08:37
还不一定都是优先转无符号的。
网上找到个说明:



对,看反汇编就行,比较省事。

caicaptain2 发表于 2023-11-28 15:53:19

你可以改个写法,就应该正常了。

unsigned int a = 6;
    int b = -20;
int c;
c= a+b;//这里c的类型很重要。 因为它是个有符号的,所以结果就是-14
   while(c> 1)
    {
       study();
    }
页: [1]
查看完整版本: 关于C语言 无符号数 和 有符号 数的运算问题