C语言数据类型和表达式

本文详细介绍了C语言的基本数据类型,包括常量、变量、整型、实型数据、字符型数据以及它们之间的混合运算。讨论了自动类型转换和强制类型转换,并提到了构造数据类型如数组、结构体、共用体,以及指针和空类型的概念。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

数据类型和表达式

1、基本数据类型:

​ 基本数据类型最主要的特点就,其值不可以再分解为其它类型。也就是说,基本数据类型是自我说明的。

常量

在程序执行过程中,其值不发生改变的量。在C语言中用一个标识符来表示,所以又叫作符号常量。

公式:#define 标识符 常量

eg:

#define PI 3.1415926

​ 其中#define也是一条预处理命令(预处理命令都以“#”开头),也叫做宏定义命令,作用是把这个标识符定义为他后面的常量值。一旦定义,以后在这个程序中所有出现该标识符的地方均代之以该常量值。

  • 习惯上符号常量的标识符用大写字母,变量标识符用小写字母作以区别。
  • 它的值在作用域内是不能改变的,也不能被赋值,但是如果要改的话,只需要在开始声明(定义)的地方直接改就好了
变量

顾名思义,它的值是可以改变的。一个变量应该有一个名字,在内存中占据一定的存储单元。变量的定义必须放在变量使用之前(即先声明后使用)。一般放在函数体的开头部分。注意:变量名和变量值是两个不同的概念。

公式:数据类型 变量名(标识符) = 变量值;(必须是英文输入法的分号)

eg:

int woshibianliang = 3;
int a,b,c,d;  
整型变量
  • 基本型 int 在内存中占4个字节
  • 短整型 short int 或 short,所占字节和取值范围与基本型相同
  • 长整型 long int 或 long,在内存中占4个字节,通常有个后缀L(l也行,但是太像1了)
  • 无符号(不是负数)型 unsigned

可以用方法 (函数)sizeof 检查内存大小;数据类型都有对应的变量范围,超过就会出现数据溢出的错误(精确度变小)。

实型数据(浮点型)

实行也称为浮点型。实型常量也称为实数或者浮点数。在C语言中,实数只采用十进制。主要有两种形式:十进制小数形式、指数形式。

  • 十进制形式:0~9和小数点组成

    eg:0、12.0、3.14、-123.456

  • 指数形式:由十进制数,加阶码标志“e”或“E”以及阶码(只能是整数,可以带符号)组成。

    1.34E12(1.34为十进制数,12为十进制整数)

    还有,浮点型还可以分成单精度(float)、双精度(double)和长双精度(long double)三类

字符型数据

字符型数据由**字符常量 *字符变量***组成,eg:char a; 。

字符常量:就是用英文单引号括起来的一个字符。

​ eg:‘a’、‘b’、‘中’、’?’、、、

  • 字符常量只能是单个字符,不能是字符串(字符串是构造型数据类型)

  • 字符可以是字符集中的任意字符。但数字被定义为字符之后就不能参与数值运算了。

    字符变量:用来存储字符常量,即单个字符。

    转义字符 : 一种特殊的字符常量。转义字符用反斜杠“\”开头,后面接一个或者几个字符。转义字符有特定的意义,eg:"\n"表示“回 车换行”。转义字符主要用来表示那些用一般字符不便于表示的控制代码。

各类数值型数据之间的混合运算

​ 变量的数据类型是可以转换的。转换的方法有两种,一种是自动转换,一种是强制转换。

自动类型转换

​ 自动转换发生在不同数据据类型的量混合运算时,有编译系统自动完成。转换遵循以下规则:

  1. 如果参与运算量的类型不同,则先转换成同一种类型,然后进行运算。
  2. 转换按数据长度增加的方向进行,以保证精度不降低。如 int 型和 long 型运算时,先把 int 型转成 long 型后再进行运算。
  3. 所有的浮点运算都是以双精度进行的,即使只含 float 单精度型运算的表达式,也要先转换成 double 型再运算。
  4. char 型和 short 型参与运算时,必须先转换成 int 型。
  5. 在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边量的类型将转换为左边量的类型。如果右边量的数据类型长度比左边长时,将会丢失一部分数据,也就是降低了精度,丢失的部分会按四舍五入向前舍入。
强制类型转换

通过类型转换运算来实现,一般形式为: (类型说明符)(表达式)

其功能是把表达式的运算结果强制转换成类型说明符所表示的类型。eg:

(float)a 把a转换为浮点型

(int)(x+y) 把x+y的结果转换为整型

需要注意的问题:

  1. 类型说明符和表达式都必须加括号(单个变量可以不加),如把(int)(x+y)写成(int)x+y则成了把x转换成int型之后再与y相加了。
  2. 无论是强制转换还是自动转换,都只是为了本次运算的需要而对变量的数据长度进行的临时性转换,但是不改变数据说明时对该变量定义到位类型。

2、构造数据类型:

​ 构造数据类型是根据已定义的一个或多个数据类型用构造的方法来定义的。也就是说,一个构造类型的值可以分解成若干个“成员”或“元素”。每个“成员”都是一个基本数据类型或又是一个构造类型。在C语言中,构造类型有以下几种:

  • 数组类型

  • 结构体类型

  • 共用体(联合)类型

3、指针类型:

​ 指针是一种特殊的,同时又是具有重要作用的数据类型。其值用来表示某个变量在内存储器中的地址。虽然指针变量的取值类似于整型量,但这是两个类型完全不同的量,因此不能混为一谈。

4、空类型:

​ 在调用函数时,通常应向调用者返回一个函数值。这个返回的函数值是具有一定的数据类型的,应在函数定义及函数说明中给以说明,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值