当前位置:首页 > 科学课件 > 正文内容

C语言有哪些数据类型?为什么要区分数据类型,还得类型转换,感觉好麻烦啊?

zhao_admin1年前 (2022-05-27)科学课件39

谢邀。

C语言将数据划分为不同的数据类型,是为了在保持较小开销的情况下,尽量精确的记录和计算数据。要知道,C语言程序的宗旨就是“小开销,高效率”。解决问题时,选择合适的数据类型,能够大大提升程序最终的效率。

题主应该是想问C语言有哪些“基础”数据类型吧?毕竟C语言是支持结构体语法的,它允许我们自定义各种数据类型。下面谈谈C语言中的基础数据类型。

整型计算机存储的最小单位是字节(Byte),一个字节通常是 8 个 bit。我们常说的硬盘容量 500GB,就是指硬盘能够存储 500G 字节的数据。

C语言规定 char 型占一个字节的存储空间,如果是 unsigned char(无符号),则可表示的取值范围是 0~255。如果是 signed char(有符号),则取值范围为 -128~127。

定义 char 型变量时不指定 unsigned 或 signed ,C语言标准规定这种情况属于 implemention defined,具体 char 型变量是否有符号取决于使用的编译器。C语言标准的原则是:优先考虑效率,可移植性其次。

所以如果在对应的体系架构上,char 型变量有符号时效率最高,则编译器就将其解释为有符号。若char 型变量无符号时效率最高,则编译器就将其解释为无符号。

应该没有人故意写出没有移植性的代码,所以建议写C语言代码用到 char 型变量时,显性的指出其是否有符号。

另外,整型数据类型还有 short int(可简写为 short),int, long int(可简写为 long),long long int(可简写为 long long)几种,这些类型也可以加上 unsigned 或 signed 表示无符号型或有符号型。

上面几种整数类型与 char 类型的区别主要在于占用的存储空间不同,但是究竟这几种整型类型占几个字节,C语言标准没有规定,所以在不同架构的计算机中,这几种类型占用的空间可能不同。

例如在大多数 32 位计算机中,这几种数据类型占用的字节数分别为 2,4,4,8。而在大多数 64 位计算机中,这几种数据类型占用的字节数分别为 2,4,8,8。

除了 char,其他几种整型类型如果定义时没有写符号,则默认为是有符号的。

浮点型C语言标准规定的浮点型有 float,double,long double,但是对每种数据类型占用的存储空间却没有规定。

浮点型的实现在不同的平台上的差异性比整型更大。有的处理器自带的有浮点运算单元,称为浮点运算的硬件实现。有的处理器没有,只能用整型运算模拟,这称为浮点运算的软件实现。

我们在C语言编程时应选择最合适的数据类型。例如某个变量的变化范围是 0~100,那选择 char 类型就足够了(无论有没有符号),选择 long 类型会导致性能下降,原因在我之前的文章里已经解释过。如果某个变量的变化范围可能超过 255,那就不能选择 char 类型了,否则会造成数据溢出,例如

编译并执行这段C语言代码,会得到输出:i=1。C语言程序中的数据溢出,可以借助计算器直观的看出,请看下图:

C语言的数据类型转换C语言中的基本运算,如+-* /%这些算术运算以及> = long -> int -> short -> char 的顺序转换类型的。

C语言在赋值时,也会做自动的类型转换,例如:

以上代码会输出 “i=3”,i 只保留的 3.14 的整数部分。C语言还有强制类型转换语法,只需要在要转换的数据前加上 (要转换的类型),例如:

以上代码会输出“j=1”,溢出的部分被忽略了。

很多C语言初学者看到这些规则通常会很不舒服,觉得这不是在学编程而是在啃法律条文,结果越学越泄气。

是的,C语言并不像一个数学定理那样完美,现实世界里的东西总是不够完美的。但还好啦,C语言程序员已经很幸福了,只要严格遵照C标准来写代码,不要去触碰那些阴暗角落,写出来的代码就有很好的可移植性。

想想那些可怜的JavaScript程序员吧,他们甚至连一个可以遵照的标准都没有,一个浏览器一个样,因而不得不为每一种浏览器的每一个版本分别写不同的代码。

欢迎在评论区一起讨论,质疑。文章都是手打原创,每天最浅显的介绍C语言、linux等嵌入式开发,喜欢我的文章就关注一波吧,可以看到最新更新和之前的文章哦。

扫描二维码推送至手机访问。

版权声明:本文由PPT写作技巧发布,如需转载请注明出处。

本文链接:http://www.ppt3000.com/post/64776.html

分享给朋友:

相关文章