C语言变量和数据类型总结

本文详细介绍了C语言中的变量、数据类型及其相关概念,包括变量的定义与赋值、数据类型的含义及固定字节数、整数的二进制、八进制、十六进制表示,以及正负数、小数的处理。同时,讲解了C语言中的输出数据方式printf,转义字符,标识符、关键字和注释的规则,以及各种运算,如加减乘除、自增自减和数据类型转换的原理和用法。

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

一、变量

a = 123;
  • 在C语言中,"="的作用是赋值,赋值是指把数据存放到内存中的过程。
int a = 123;
a = 1000;
a = 9999;
  • a的值可以改变,所以我们给它起了一个形象的名字叫做变量。
  • int a; 创建了一个变量a,我们把这个过程称为变量定义。
  • a = 123;把123交给了变量a,我们把这个过程叫做给变量赋值;有因为是第一次赋值,所以也叫作变量的初始化,或者赋初值。

二、数据类型

  • 数据类型用来说明数据的类型,确定了数据的解释方式,让计算机和程序员不会产生歧义。
  • C语言中有以下数据类型:
    在这里插入图片描述
  • 另外,数据长度是指数据占用多少个字节。
  • 在C语言中,每一种数据类型占用的字节数都是固定的,知道了数据类型,也就知道了数据的长度。
  • 数据类型只在定义变量时指明,而且必须指明;使用变量时无需再指明,因为此时的数据类型已经确定。

三、输出数据

printf("格式化输出")
  • printf是print format的缩写,意思是“格式化输出”,即在屏幕上显示内容。
int a = 100;
int b = 200;
int c = 300;
printf("a = %d,b = %d,c = %d",a,b,c);
  • %d与后边的变量是一一对应的,第一个%d对应第一个变量,第二个%d对应第二个变量······
  • %d称为格式控制符,它指明了以何种形式输出数据。格式控制符均以%开头,后跟其他字符。%d表示以十进制形式淑出一个整数。除了%d,printf支持更多的格式控制,例如:
  • %c 输出一个字符。c是character的简写。
  • %s 输出一个字符串。s是string的简写。
  • %f 输出一个小数。 f是float的简写。

四、整数

  • short,int,long是C语言中常见的整数类型,其中int称为整型,short称为短整型,long称为长整型
  • 但是实际上C语言中并没有严格规定short,int,long的长度,只做了宽泛的限制
    • short至少占用2个字节。
    • int建议为一个机器字长。32位环境下机器字长为4字节,64位环境下机器字长为8字节。
    • short的长度不能大于int,long的长度不能小于int。
2 <= short <= int <= long
  • 这就意味着,short并不一定真的“短”,long也不一定真的“长”,他们有可能和int占用相同的字节。
二进制数、八进制数、十六进制数
  • 二进制由 0 和 1 两个数字组成,使用时必须以 0b 或 0B(不区分大小写)开头
  • 八进制由 0~7 八个数字组成,使用时必须以 0 开头(注意是数字 0,不是字母 o)
  • 十六进制由数字 0~9、字母 A~F 或 a~f(不区分大小写)组成,使用时必须以 0x 或 0X(不区分大小写)开头

在这里插入图片描述

  • 十六进制数字的表示用到了英文字母,有大小写之分,要在格式控制符中体现出来:
    • %hx、%x 和 %lx 中的 x 小写,表明以小写字母的形式输出十六进制数
    • %hX、%X 和 %lX 中的 X 大写,表明以大写字母的形式输出十六进制数
#include<stdio.h>
int main()
{
	short a = 0b1010110;
	int b = 02713;
	long c = 0X1DAB83;
		
	printf("a = %ho,b = %o,c = %lo \n", a, b, c);				//以八进制的形式输出	
	printf("a = %hd,b = %d,c = %lx \n", a, b, c);				//以十进制的形式输出
	printf("a = %hx,b = %x,c = %lx \n", a, b, c);				//以十六进制的形式输出(字母小写)
	printf("a = %hX,b = %X,c = %lX \n", a, b, c);				//以十六进制的形式输出(字母大写)
	return 0;
}

结果:
在这里插入图片描述

  • 从这个例子可以发现,一个数字不管以何种进制来表示,都能够以任意进制的形式输出。数字在内存中始终以二进制的形式存储,其它进制的数字在存储前都必须转换为二进制形式;同理,一个数字在输出时要进行逆向的转换,也就是从二进制转换为其他进制。
正负数
  • 在数学中,数字有正负之分。在 C 语言中也是一样,short、int、long 都可以带上正负号
//负数
short a1 = -10;
short a2 = -0x2dc9;  //16进制
//正数
int b1 = +10;
int b2 = +0174;      //八进制
int b3 = 22910;
//负数和正数相加
long c = (-9) + (+12);
  • C语言规定把内存的最高位作为符号位。用0表示正数,用1表示负数。

五、小数

  • 小数分为整数部分和小数部分,由点.号分割。
  • 小数可以使用printf函数输出,包括十进制形式和指数形式,他们对应的格式控制符分别是:
    在这里插入图片描述
  • 下面的代码演示了小数的表示以及输出
#include<stdio.h>
#include<stdlib.h>
int main()
{
	float a = 0.302;
	float b = 128.101;
	double c = 123;
	float d = 112.64E3;
	double e = 0.7623e-2;
	float f = 1.23002398;
	printf("a = %e \n b = %f \n c = %lf \n d = %lE \n e = %lf \n f = %f \n", a, b, c, d, e, f);
	return 0;
}

结果:
在这里插入图片描述

六、C语言转义字符

  • 转移字符以\或者\x开头,以\开头表示后跟八进制形式的编码值,以\x开头表示后跟十六进制形式的编码值。
  • 对于转义字符来说,只能使用八进制或者十六进制。
  • 常用的转义字符如下:
    在这里插入图片描述

七、C语言标识符、关键字、注释、表达式和语句

  • 标识符

C语言规定,标识符只能由字母(A—Z, a—z)、数字(0~9)和下划线(_)组成,并且第一个字符必须是字母或下划线,不能是数字。

  • 关键字

标准 C 语言中一共规定了 32 个关键字

在这里插入图片描述

  • 注释
  • 单行注释以//开头,直到本行末尾(不能换行)
  • 多行注释以/开头,以/结尾,注释内容可以有一行或多行
  • 表达式和语句
  • 表达式可以看做一个计算的公式,往往由数据、变量、运算符等组成,例如 3*4+5、a=c=d 等,表达式的结果必定是一个值;
  • 语句的范围更加广泛,不一定是计算,不一定有值,可以是某个操作、某个函数、选择结构、循环等

八、C语言中的运算

  • 加减乘除
    在这里插入图片描述
    代码实现如下
#include<stdio.h>
int main()
{
	int a = 12;
	int b = 100;
	float c = 8.5;

	int m = a + b;
	float n = b * c;
	double p = a / c;
	int q = b % a;

	printf("m = % d,n = % f,p = % lf,q = % d \n", m, n, p, q);
	return 0;
}

结果:

在这里插入图片描述

  • 自增(++)自减(–)
    • 话不多说,直接上代码
#include<stdio.h>
int main()
{
	int a = 10, b = 20;
	printf("a = % d,b = %d \n", a, b);
	++a;
	--b;
	printf("a = % d,b = % d \n", a, b);
	a++;
	b--;
	printf("a = %d,b = %d \n", a, b);
	return 0;
}

结果:
在这里插入图片描述

  • 需要重点说明的是,++ 在变量前面和后面是有区别的:

++ 在前面叫做前自增(例如 ++a)。前自增先进行自增运算,再进行其他操作。
++ 在后面叫做后自增(例如 a++)。后自增先进行其他操作,再进行自增运算。
自减(–)也一样,有前自减和后自减之分。

九、数据类型转换

数据类型转换就是将数据(变量、数值、表达式的结果等)从一种类型转换为另一种类型,在C语言中,数据类型转换有两种方式,自动类型转换和强制类型转换

  • 自动类型转换

自动类型转换就是编译器默默地、隐式地、偷偷地进行的数据类型转换,这种转换不需要程序员干预,会自动发生。

  • 强制类型转换

如果需要,程序员也可以自己在代码中明确地提出要进行类型转换,这称为强制类型转换。

  • 强制类型转换的格式为:

(type_name) expression

type_name 为新类型名称,expression 为表达式。

(float)a; //将变量 a 转换为 float 类型
(int)(x + y); //把表达式 x+y 的结果转换为 int 整型
(float)100; //将数值 100(默认为int类型)转换为 float 类型
  • 但是类型转换只是临时的,无论是自动类型转换还是强制类型转换,都只是为了本次运算而进行的临时性转换,转换的结果也会保存到临时的
    内存空间,不会改变数据本来的类型或者值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值