C语言的数据类型:基本数据类型、构造数据类型、指针类型、空类型。
- 构造数据类型:是根据已定义的一个或多个数据类型用构造方法来定义的。一个构造类型的值可以分解成若干个“成员”或“元素”
- 指针类型: 指针是一种特殊的,同时又是具有重要作用的数据类型。其值用来表示某个变量在内存储器中的地址。
常量与变量
常量:程序执行过程中其值不发生改变的量。
- 直接常量:
a.整型常量:1,100,29,-10
b.实型常量:5.2,6.4,-0.5
c.字符常量:‘a’,'b' - 符号常量:用宏来代表一个常量。在C语言中,可以使用一个标识符来表示一个常量,称之为符号常量。
符号常量在使用之前需要先定义,其一般形式为: - () #define 标识符 常量
其中#define是一条预处理命令,称为红定义命令,其功能是把该标识符定义为其后的常量值。
习惯上符号常量的标识符使用大写字母,变量标识符使用小写字母,以示区别 - 例如:#define PI 3.1415926
变量:其值可以改变的量成为变量
一个变量应该有一个名字,在内存中占有一定的存储单元,变量在使用之前必须先定义。
int a=3; int是a的数据类型,a是变量名,3是变量值。
整型数据
1.整型常量
整型常量就是整常数,C语言中的常整数有八进制,十六进制,十进制三种。
(1)十进制整常数:十进制常整数没有前缀,其数码为0~9
- 合法的十进制整常数,123,2,4356,-100.
- 不合法的十进制整常数:078,78A(含有非十进制数码)
- 在程序中各个前缀用来区分各种进制数。
(2)八进制常整数:八进制整数必须以0开头,即以0作为八进制数的前缀。数码为0~7。八进制通常是无符号数。 - 合法的八进制整常数:015(13),0101(64),0177777(65535)
- 不合法的八进制整常数:256,03A2,-0127
(3)十六进制整常数:十六进制整常数的前缀为0X或0x,其数码为09,af或A~F, - 合法的十六进制整常数:0X2A(42),0XA0(160),0XFFFF(65535)
- 非法的十六进制整常数:5A,0X3H
实型数据
- 十进制数形式:由0~9和小数点组成
- 合法实数:0.0,0.12,4.567,-256.123 (必须有小数点)
- 指数形式:由十进制数加阶码标志“e”或“E”以及阶码组成。
- 其一般形式为: a E n (a 为十进制数,n为十进制整数)
- 其值为 a10^n.
如:2.1e5(2.110^5) 3.7e-2(3.710^-2) 0.5e7(0.510^7)
实型变量
(1)实型变量实型数据在内存中的存放形式
- 实型数据一般占4个字节。按指数形式存储。
|符号位 |小数部分 |指数部分 |
小数部分占的位越多,数的有效数字越多,精度越高
指数部分占的位数越多,数能表示的范围越大。
(2)实型变量的分类 - 单精度(float),双精度(double型),长双精度(long double型)三类
字符变量
字符数据在内存中的存储形式及使用方法。
每个字符变量被分配一个字节的空间,因此只能存放一个字符。字符值是以ASCII码的形式存放在内存单元中的。
#include <stdio.h>
int main()
{
char a,b;
a = 120;
b = 121;
printf("%c,%c\n",a,b);
printf("%d,%d\n",a,b);
return 0;
}
a=x b=y
a=120 b=121
字符串常量和字符常量是不同的量.他们有以下区别
- 字符常量是由单引号括起来的,字符串常量是由双引号括起来的
- 字符常量只能是单个字符,字符串常量则含有一个火多个字符.
- 可以吧一个字符常量付给一个字符变量,但不能把一个字符串常量付给一个字符变量.在C语言中没有相应的字符串变量。我们用一个字符数组在存放一个字符变量。
- 字符占一个字节的内存空间.字符串常量占的内存字节数等于字符串中的字节数加一.增加的一个字节用于存放字符'\0',这是字符串的结束标志。
各类数据类型的混合运算
(1) 若参与运算量的类型不同,则先转换成同一类型然后进行运算.
(2)转换按数据长度增加的方向进行,以保证精度不降低,如int与long运算时,先把int转换为long,然后进行运算。
(3)所有的浮点型运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要先转换为double型,然后进行运算。
(4)char型和short运算时,必须先转换为int
(5)在赋值运算时,赋值号两边量的数据类型不同时,赋值号右边的量的类型转换为左边量的类型.如果右边量的数据类型长度大于左边的,则会丢失一部分数据,这样会降低精度,丢失的部分四舍五入.
![Upload Paste_Image.png failed. Please try again.]
强制类型转换
- 强制类型转换是通过类型转换运算来实现的。
- 其一般形式为:
(类型说明符)(表达式)
其功能是吧表达式的运算结果强制转换成类型说明符所表示的类型
int a;
(float) a; //把a转换为实型
(int) (x+y) //把x+y的结果转换为整型
注意:
(1)类型说明符和表达式都必须加括号(单个变量可以不加),
(2)无论是强制类型转换还是自动转换,都只是为了本次运算的需要对变爱玲的数据长度进行临时替换,而不是改变变量的类型。