变量的类型决定了什么
高级语言为什么要区分数据类型
为了更有效地组织数据,规范数据的使用有助于提高程序的可读性,方便用户使用
在程序设计语言中引入数据类型的好处
带来了程序的简明性和数据的可靠性。有助于提高程序的执行效率,节省内存空间
C语言的数据类型
基本类型
整型
基本整型: int长整型: long短整型:short无符号整型:在前面三种整型数据类型之前增加一个unsigned关键字,就变为相应的无符号整型 实型(浮点型)
单精度实型:float双精度实型:double长双精度实型:long double 字符型枚举类型
构造类型
数组类型结构体类型共用体(联合)类型
指针类型和空类型
变量的类型决定了什么
占用空间的大小数据的存储形式合法的表数范围可参与的运算种类
不同类型的变量占用的内存不同
整型
int: 基本整型
对于其占用的内存空间,C标准并没有规定,这和系统有关,和计算机的字长有关,通常int类型所占用内存的大小为一个字长。目前的大多数系统上int占用4个字节。 short int,简写为short: 短整型
占用2字节 long int, 简写为long: 长整型
占用4字节 unsigned: 无符号整型(正整数和0)
用来修饰int, short和long
实型
float: 单精度实型
占用4个字节
double: 双精度实型
占用8字节
long double: 长双精度实型
IEEE规定为10字节,但是实际上很多编译器没有遵循这一规则,所以这个类型的变量占用的内存也是和系统相关
字符型
char: 字符型
占用1字节
注意
由上面的内容可知,C语言中,有的类型的变量所占用的字节数是和系统相关的,因此绝不能对于变量所占用的内存字节数想当然
如何计算变量或类型所占内存的大小
使用sizeof运算符
sizeof运算符是一个一元运算符,用于计算变量或类型占用内存的大小
语法
语法形式运算结果
sizeof(类型名)这种类型的变量在内存中所占用的内存字节数sizeof(变量或表达式)变量或者是表达式的结果所属类型所占用的内存字节数
sizeof运算符的好处
增加程序的可移植性sizeof运算符是编译时执行的运算符,所以使用该运算符不会导致程序运行时间的额外开销
不同类型的数据表数范围不同
不同类型的表数范围不同有符号和无符号类型的表数范围也不同
有符号整数的最高位为符号位无符号整数的最高位为数据位有符号整数所能表示的最大整数仅为无符号整数所能表示的最大整数的一半
不同类型数据的存储形式不同
整型数
以short类型(占用2字节)为例
一个short类型的数据使用二进制表示如下
由于计算机的内存是一维线性排列的,并且一个单元为一个字节
因此,将这样的一个2字节的数据存放到内存中就有两种存储的方式
小端次序
存放形式如下
这种存放形式的好处
便于计算机从低位字节向高位字节进行运算
大端次序
存放形式
好处
与人们从左到右的书写顺序相同,便于对字符串的处理
实型数
如何存储一个实型数的关键是确定小数点的位置
实型数的表示方法
小数形式指数形式,也就是科学计数法
只有小数部分或者只有整数部分的实型数成为定点数
定点数的小数点位置固定只有整数部分的定点数叫做定点整数只有小数部分的定点数称为定点小数(纯小数)
定点数的表示
定点数通常用小数形式来进行表示
定点小数:小数点位于符号位和最高数值位之间
定点整数:小数点位于数值位的最低位
小数点位置不固定的实型数称为浮点数
浮点数以科学计数法的方式表示,这样就可以分别用一些位表示指数部分和小数部分
浮点数实现小数点位置浮动的原理
将实数拆分为==阶码(Exponent)和尾数(Mantissa)==两个部分分别进行存储。如下图所示
对于同样的尾数,阶码的值越大,则浮点数所表示的数值就越大
对于同样大小的存储单元,用于存储阶码的位数越多,则能表数的范围就越大,但是相应的用于存储尾数的位就变少了,这时候表数的精度就会变差
在计算机中,通常用定点数来表示整数和纯小数;而用浮点数来表示既有整数又有小数的实数
字符型数据
字符型数据是指那些英文字母、数字以及控制字符等在C语言中,字符型数据以二进制编码的形式进行存储,一个字节保存一个字符字符的编码方式
取决于计算机系统所采用的字符集ASCII字符集是一个我们常用的字符集根据字符集,每一个字符具有一个编码值,这个值可以使用二进制的整数进行表示因此,一个字符常数,实际上就是一个普通的整数
不同的数据类型可参与的运算不同
整型
加减乘除和取余
实型
加减乘除
字符型
加减对于字符型数据的运算,实际上是对表示字符的整数进行运算。对于ASCII字符集,也就是对字符的ASCII值的运算
指针类型
加减和比较运算
END