《编写高质量代码:改善c程序代码的125个建议》——建议2-2:使用显式声明为signed char或unsigned char的类型来执行算术运算

简介:

本节书摘来自华章计算机《编写高质量代码:改善c程序代码的125个建议》一书中的第1章,建议2-2,作者:马 伟 更多章节内容可以访问云栖社区“华章计算机”公众号查看。

建议2-2:使用显式声明为signed char或unsigned char的类型来执行算术运算

在讨论本建议话题之前,我们先看看下面的这段代码的输出结果,如代码清单1-1
所示。

代码清单1-1 char使用示例 
#include <stdio.h>   
int main(void)  
{             
    char c=150;       
    int i=900;      
    printf("i/c=%d\n", i/c);       
    return 0;   
}

在代码清单1-1中,或许大多数人都认为它输出的结果应该是“i/c= 6”,但实际的输出结果却大相径庭。前面已经讲过,char类型的变量c可以有两种类型:有符号的(signed char)和无符号的(unsigned char)。这里假设char是8位的补码字符类型,那么代码清单1-1就可能输出“i/c=-8”(signed char)或者“i/c= 6”(unsigned char)两种结果。其中,在Microsoft Visual Studio 2010与GCC中的输出结果都是“i/c=-8”,如图1-4与图1-5所示。


<a href=https://yqfile.alicdn.com/912b8589f10bc9e379bbcd2fa8df9ebd1d761fc7.png" >

其实,导致这种结果最根本的原因就在于我们不能够准确地确定char类型的变量c究竟是signed char类型还是unsigned char类型。因此,我们把决策权交给编译器,而不同的编译器默认的char类型是不同的,所以最后得到的结果也就不相同。
解决这种问题的办法很简单,就是显式地将char类型的变量c声明为signed char或unsigned char类型,这样可保证结果的唯一性,如代码清单1-2所示。
代码清单1-2 unsigned char使用示例
#include <stdio.h>   
int main(void)  
{             
    unsigned char c=150;       
    int i=900;      
    printf("i/c=%d\n", i/c);       
    return 0;   
}

这样就显式地将char类型的变量c声明为unsigned char类型,现在,后面的除法运算(i/c)与char的符号无关,所以代码清单1-2输出的结果为“i/c= 6”。

相关文章
|
1月前
|
存储 编译器 C语言
c语言中char的作用类型
c语言中char的作用类型
28 0
|
3月前
|
存储 人工智能 编译器
learn_C_deep_5 (温故知新、sigend char a = -128的深度理解、unsigned int类型的写法规范)
learn_C_deep_5 (温故知新、sigend char a = -128的深度理解、unsigned int类型的写法规范)
|
3月前
|
存储 算法 安全
C++系列-第1章顺序结构-9-字符类型char
C++系列-第1章顺序结构-9-字符类型char
|
3月前
|
存储 自然语言处理 安全
【C++11保姆级教程】空指针(nullptr),long long类型,char16_t和char32_t类型
【C++11保姆级教程】空指针(nullptr),long long类型,char16_t和char32_t类型
【C++11保姆级教程】空指针(nullptr),long long类型,char16_t和char32_t类型
|
6月前
|
存储 小程序 程序员
8k字详解整型(int)/字符型(char)/浮点型(float)/有符号(signed)/无符号(unsigned)数据在内存中的存储【程序员内功修炼/C语言】
8k字详解整型(int)/字符型(char)/浮点型(float)/有符号(signed)/无符号(unsigned)数据在内存中的存储【程序员内功修炼/C语言】
63 0
|
6月前
|
存储 数据库
SAP CDS view 如何将 CHAR 类型的数据字段和当前系统日期比较
SAP CDS view 如何将 CHAR 类型的数据字段和当前系统日期比较
59 0
|
7月前
|
存储 关系型数据库 MySQL
MySql 字符串类型 - char、varchar
MySql 字符串类型 - char、varchar
58 0
|
7月前
|
存储 C语言
C语言:char与unsigned char类型数据的范围
unsigned char 的范围是 0~255,当 i=255 时,i++变为0,从0到255无限循环,因此程序运行结果为死循环
147 0
|
7月前
|
存储 关系型数据库 MySQL
面试时被这样一个问:”存储MD5值应该用VARCHAR还是用CHAR?
一个5年工作经验的小伙伴,在面试的时候被这样一个问题。说”存储MD5值应该用VARCHAR还是用CHAR“,他一时间不只如何选择,感觉用VARCHAR也可以,用CHAR也行。希望我来帮忙分析一下。
70 0
|
15天前
|
存储 数据库
5. CHAR和VARCHAR的区别?
`CHAR`和`VARCHAR`在数据库中有所不同:`CHAR`长度固定,用空格填充,存储效率高,英文占1字节,汉字占2字节;而`VARCHAR`长度可变,节省空间,英文和汉字都占2字节。
15 0