char与signed char, unsigned char的区别
2016-03-07 10:36
176 查看
一、开始
今天有一个困扰的问题,就是char与signed char, unsigned char这三者的区别。二、三者之间
1.ANSI C 提供了3种字符类型,分别是char、signed char、unsigned char。而不是像short、int一样只有两种(int默认就是unsigned int).2.三者都占1个字节
3.signed char取值范围是 -128 到 127(有符号位) unsigned char 取值范围是 0 到 255
4.内存中一串二进制,它的含义,就是这个类型来说明的。
5.所谓signed char 和 unsigned char 其实是相对“运算”而说的,已经脱离了我们字面含义“字符”,表示的范围有限。
三、char
1.char的定义C标准中对char是 Impementation Defined,就是未明确定义
(1)那它由什么定义?坦白说,具体的编译器明确定义,一般都是用signed char或unsigned char来实现char的,也就是说不同的编译器对char是什么定义不一样
(2)为什么要这样定义?因为这三种类型的对象在存储介质中的表现形式是一样的(都是一个占8bit的01串,只是解析的时候不同)
(3)到底是signed char还是unsigned char?这得看编译器:VC编译器、x86上的GCC都把char定义为signed char,而arm-linux-gcc却把char定义为 unsigned char
2.char的使用
char的不同使用给了它不同的字面上的含义
(1)当字符用
原始的ASCII标准里,定义的字符码值是只有0~127,所以怎么定义的char都刚好好装得下,于是普通意义上我们对它的理解就是它表示一个字符,也就是让表示一个ASCII码(这也是C语言基础中对它的解释)
(2)当单字节整数
从本质上来说,字符('a', 'b', 'c'等)本质上也是一个整数,只是字符代表的值是0~127,我们可以用char表示一个不太大的整数
四、关于高位扩展
说明:我们现在默认为VC的这一套 char 定义为 signed char首先在内存中,char 与unsigned char没有什么不同,都是一个字节,8个bit,普通的赋值,读写文件和网络字节流都没什么区别,反正就是一个字节,不管最高位是什么,最终的读取结果都一样,只是你怎么理解最高位而已。
好吧,我们认为现在char的最高位为符号位,因此char能表示-128~127, unsigned char没有符号位,因此能表示0~255。
但是屏幕上面的显示可能不一样。
相关文章推荐
- IOCP的线程池管理
- rand函数和srand函数
- 如何将一批pdf文件转换成jpg文件
- VelocityTracker
- Python基础(Django)
- 《深入理解Spark:核心思想与源码分析》——SparkContext的初始化(叔篇)——TaskScheduler的启动
- boost-同步-互斥量的概念
- 模糊查询
- PPP 会话的创建过程
- 欢迎使用CSDN-markdown编辑器
- Peugeot 301
- mongodb图形化管理工具
- 整合Spring MVC,mybatis,hibernate,freemarker框架实现的自定义注解Validator验证机制实现对敏感词过滤的代码分享
- Ajax核心XMLHttpRequest对象、(发送请求、接收)方法和属性介绍、AJAX开发框架、数据格式提要(XML、JSON、HTML)
- 小学四则运算2.0
- *.pro、*.pri、*.prf、*.prl等四种文件
- 深入理解Java内存模型——volatile
- hibernate中持久化对象的生命周期(三态:自由态,持久态,游离态 之间的转换)
- VW Passat B6
- 贪心算法