无符号数的算术运算的溢出问题

Posted working-in-heart

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了无符号数的算术运算的溢出问题相关的知识,希望对你有一定的参考价值。

1.unsigned char 

    unsigned char a = A;
    unsigned char b = H;
    unsigned char c;
    c = a - b;

    cout << a - b << endl;
    cout << sizeof(a - b) << endl;
    cout << typeid(a - b).name() << endl;
    cout << bitset<sizeof(a - b) * 8>(a - b) << endl;

    cout << c << endl;
    cout << sizeof(c) << endl;
    cout << typeid(c).name() << endl;
    cout << bitset<sizeof(c) * 8>(c) << endl;

技术分享图片

直接输出a-b的情况下,无论a与b的大小,都会转成int类型数据,原因还不知道,知道后再修改

两段代码在输出a-b和c,前者输出-7后者不输出原因在于:a-b是int类型所以直接输出-7,而c是unsigned char 类型,输出c是需要查看assic代码值0B11111001(c虽然没有输出,但是计算仍然进行了),而我们知道ascii是无符号数,也就是0开头的二进制数,不可能出现1开头的二进制数(补码为负数),所有根本没有这个符号,所以什么也没有输出。当大小转换,不是小减大时,输出c,会输出相应的assic字符,但a-b仍是int类型的数字。

以上是关于无符号数的算术运算的溢出问题的主要内容,如果未能解决你的问题,请参考以下文章

组成原理-数据定点数的编码与运算

有符号数与无符号数之间运算问题探究

有符号数与无符号数之间运算问题探究

有符号和无符号整型数据溢出问题

信息的表示和处理

verilog中有符号数的运算