【C语言】第一期——数据类型变量常量
- 手机
- 2025-09-07 01:33:02

目录
1 字面量
2 整数类型
2.1 整数类型的取值范围
2.1.1 sizeof 运算符
2.2 GB、MB、KB、B之间的关系
2.3 定义整数类型的变量并打印
2.4 整数类型代码演示
3 浮点类型
3.1 浮点类型的取值范围
3.2 定义浮点类型变量并打印
3.3 保留2位小数点
4 char字符型
4.1 char类型的取值范围
4.2 ASCII码表(了解)
4.3 C语言中的字符串
4.3.1 %s 用户字符串的输出
5 C语言中的变量和常量
5.1 变量
5.1.1 一次定义多个变量
5.2 常量
5.2.1 字符常量 (转义字符)
5.2.2 const 和 #define 定义常量(重要)
5.2.2.1 #define 预处理器定义常量
5.2.2.2 const 关键字定义常量
5.2.2.3 #define 与 const 区别
6 C语言中标识符的命名规则以及注释
6.1 标识符的命名规则
6.2 C语言关键字
6.3 C语言的注释
7 C语言中printf与数据类型占位符
C 中的类型可分为以下几种:
类型名称描述基本数据类型它们是算术类型,包括整型(int)、字符型(char)、浮点型(float)和双精度浮点型(double)。枚举类型它们也是算术类型,被用来定义在程序中只能赋予其一定的离散整数值的变量。void 类型类型说明符 void 表示没有值的数据类型,通常用于函数返回值。派生类型包括数组类型、指针类型和结构体类型。这里我们首先给大家讲解一下基本数据类型,后期教程会详细讲解一下其他类型,在全部更新完后,会在此页面标记相应期数
1 字面量
在C语言中,字面量是一种不可变的数据类型,通过字面量可以存储数字、字符、布尔值和其他特殊值,如文件路径、日期和时间等 。
C语言中字面量主要分为下面几种:
❗注意:字符型是单引号,字符串是双引号
类型示例格式符(占位)整型100、314、0、-200%d浮点型3.14、12.2、0.618、-1.7%f字符型'a'、'1'、'='、'?'、'#'%c字符串"124"、"hello"、" .qq "%s2 整数类型 2.1 整数类型的取值范围
下表列出了关于标准整数类型的存储大小和值范围的细节:
类型存储大小值范围char1 字节-128 到 127 或 0 到 255unsigned char1 字节0 到 255signed char1 字节-128 到 127int4 字节-2,147,483,648 到 2,147,483,647unsigned int4 字节0 到 4,294,967,295short2 字节-32,768 到 32,767unsigned short2 字节0 到 65,535long4 字节-2,147,483,648 到 2,147,483,647unsigned long4 字节0 到 4,294,967,295❗注意:char 类型是否有符号取决于编译器和系统。
有些编译器将 char 视为 signed char,而有些则将其视为 unsigned char。
如果编译器将 char 视为 signed char:其取值范围就是 -128 到 127。 如果编译器将 char 视为 unsigned char:其取值范围就是 0 到 255。
各种类型的存储大小与系统位数有关,但目前通用的以64位系统为主。
2.1.1 sizeof 运算符
为了得到某个类型或某个变量在特定平台上的准确大小,可以使用 sizeof 运算符得到对象或类型的存储字节大小。
表达式:sizeof(type)
下面的实例演示了获取 int 类型的大小:
#include <stdio.h> int main() { printf("int 存储大小 : %d 个字节\n", sizeof(int)); return 0; }2.2 GB、MB、KB、B之间的关系 单位名称英文全称与下一级单位换算关系比特bit-字节byte1B = 8 bit千字节Kilobyte1KB = 1024B兆字节Megabyte1MB = 1024KB吉字节Gigabyte1GB = 1024MB
1bit=8位 00000 00000 ~ 1111 11111
2.3 定义整数类型的变量并打印
变量:顾名思义就是可以改变的量。变量本质上是一块有名字的内存空间,用来存放数据。
C语言中变量可以定义的时候赋值,也可以先定义后赋值
下面定义了一个int类型的变量 a,并且给a赋值了200
#include<stdio.h> int main() { int a = 200; printf("%d\n", a); return 0; }下面首先定义了一个int类型的变量 a,然后给a赋值了200
#include <stdio.h> int main() { int a; a = 200; printf("%d\n", a); return 0; }2.4 整数类型代码演示 #include <stdio.h> int main() { int a = 65; printf("a的值:%d\n", a); short b = 2; printf("b的值:%d\n", b); long c = 12345; printf("c的值:%d\n", c) unsigned short s = 12; printf("int 占用%d个字节\n", sizeof(int)); printf("short 占用%d个字节\n", sizeof(short)); printf("long 占用%d个字节\n", sizeof(long)); printf("s的值:%d\n", s); return 0; }
输出结果:
a的值:65 b的值:2 c的值:12345 int 占用4个字节 short 占用2个字节 long 占用4个字节 s的值:12
3 浮点类型 3.1 浮点类型的取值范围
下表列出了关于标准浮点类型的存储大小、值范围和精度的细节
类型存储大小值范围精度float4 字节1.2E-38 到 3.4E+386 位有效位double8 字节2.3E-308 到 1.7E+30815 位有效位long double16 字节3.4E-4932 到 1.1E+493219 位有效位头文件 float.h 定义了宏,在程序中可以使用这些值和其他有关实数二进制表示的细节。
下面的实例将 输出浮点类型占用的存储空间以及它的范围值:
3.4E+38表示的意思是 3.4*10^38
3.2 定义浮点类型变量并打印
示例1:通过float定义一个浮点数
#include <stdio.h> int main() { float f = 3.14f; printf("%f\n", f); return 0; }注意: float定义浮点数的时候,在数值后面需要加上f, 如果不加F,系统会默认把赋值的数字当作 double类型处理 ,然后在把这个double类型的值赋给float类型,这样就会出现精度丢失。
示例2:通过double定义一个浮点数
#include<stdio.h> int main() { double d = 3.14; printf("%lf\n", d); return 0; }示例3:float 以及double占用的字节数
#include <stdio.h> int main() { printf("float 存储最大字节数 : %d \n", sizeof(float)); printf("double 存储最大字节数 : %d \n", sizeof(double)); return 0; }输出结果:
float 存储最大字节数 : 4
double 存储最大字节数 : 8
3.3 保留2位小数点 #include <stdio.h> int main() { float a = 3.1415f; printf("%.2f", a); return 0; } #include <stdio.h> int main() { double d = 3.14135; printf("%.2lf\n", d); return 0; }
输出结果:
3.14
4 char字符型
C语言中,字符型只有一种:字符型(char)。char占用1个字节
C 语言中,char 类型既可以当作整数类型使用,也可以当作字符类型使用
4.1 char类型的取值范围下表列出了字符型的存储大小和值范围的细节:
存储大小类型值范围1 字节char-128 到 127 或 0 到 2551 字节unsigned char0 到 255如果想要明确指定有符号或无符号的字符类型,可以分别使用 signed char 和 unsigned char,这样在不同编译器下取值范围就确定了。
char字符类型数据在printf函数中一般采用c%格式进行输出
#include<stdio.h> int main() { char c = 'A'; printf("%c\n", c); return 0; }分析:
1.执行第 4 行程序时,先在内存中开 1字节空间,并标记为c,然后把字符A对应的ASCII码65,存储在c 标记的内存空间中。
2.执行第5行程序时,先读取变量c对应内存空间中的数据 65,然后替换 printf中的c,由于%c表示字符格式,因此不能直接输出整数65,而是输出65对应的字符A。
字符在内存中是按照其对应的 ASCII码进行存储,而ASCII码本质上也是整数。因此,字符型可以看作是整型的一种,当然也就可以按照 %d格式输出。
下面通过程序了解一下:
#include <stdio.h> int main() { char c = 'A'; printf("%c\n", c); printf("%d\n", c); return 0; }输出结果:
A
65
4.2 ASCII码表(了解) 编码字符编码字符编码字符编码字符0NUL32Space64@96`1SOH33!65A97a2STX34"66B98b3ETX35#67C99c4EOT36$68D100d5ENQ37%69E101e6ACK38&70F102f7BEL39'71G103g8BS40(72H104h9TAB41)73I105i10LF42*74J106j11VT43+75K107k12FF44,76L108l13CR45-77M109m14SO46.78N110n15SI47/79O111o16DLE48080P112p17DC149181Q113q18DC250282R114r19DC351383S115s20DC452484T116t21NAK53585U117u22SYN54686V118v23ETB55787W119w24CAN56888X120x25EM57989Y121y26SUB58:90Z122z27ESC59;91[123{28FS60<92|12429GS61=93]125}30RS62>94^126~31US63?95_127DEL
4.3 C语言中的字符串
在 C 语言中是没有字符串类型的,所谓的字符串本质上是由单个字符组成。
例如:
" USER_A001", 可以看做是由字符 'U'、'S'、'E'、'R'、'_'、'A'、'0'、'0'、'1'组成
#include <stdio.h> int main() { printf("我的名字是:%s", "USER_A001"); return 0; } 4.3.1 %s 用户字符串的输出在 C 语言中字符串实际上是使用空字符 \0 结尾的一维字符数组。
因此,\0 是用于标记字符串的结束。
#include <stdio.h> int main() { char name[10] = { 'U', 'S', 'E', 'R', '_', 'A', '0', '0', '1', '\0'}; printf("我的姓名是:%s", name); return 0; }5 C语言中的变量和常量 5.1 变量
变量是在程序运行过程中其值可以改变的量。
上文中的 char int float double定义的数据都是变量。
#include <stdio.h> int main() { //整型 int a; //声明 a = 123; //初始化赋值 a = 456; //修改值 int b = 123; //声明完直接赋值 //浮点型 float c; c = 3.14f; c = 3.14159f; float c = 3.14f; return 0; } 5.1.1 一次定义多个变量 #include <stdio.h> int main() { int a = 100, b = 200; // 定义int 变量 a、 b 且赋值 int c = 300; // 定义变量 c 且赋值 int d = 400; printf("a=%d\n", a); printf("b=%d\n", b); printf("c=%d\n", c); printf("d=%d\n", d); return 0; }5.2 常量
常量是指在程序执行过程中其值不能改变的量。
在 C语言中支持整型常量、浮点型常量、字符型常量和字符串型常量。
上文讲的字面量就属于常量
5.2.1 字符常量 (转义字符)在 C 中,有一些特定的字符,当它们前面有反斜杠时,它们就具有特殊的含义,被用来表示如换行符 (\n)或制表符(\t)等。
转义序列1含义1转义序列2含义2\\\字符\''字符\""字符\??字符\a警报铃声\b退格键\f换页符\n换行符\r回车\t水平制表符\v垂直制表符\ooo一到三位的八进制数\xhh...一个或多个数字的十六进制数 #include <stdio.h> int main() { printf("C:\Windows\System32\n"); //错误写法 printf("C:\\Windows\\System32"); // 正确写法 return 0; }5.2.2 const 和 #define 定义常量(重要)
在 C 中,有两种简单的定义常量的方式: 1. 使用 #define 预处理器: #define 可以在程序中定义一个常量,它在编译时会被替换为其对应的值。
5.2.2.1 #define 预处理器定义常量在C语言中,#define命令可以用于创建宏定义。宏定义是在编译时直接替换源文件中的字符串,而不 是在运行时替换它们 。
下面是使用 #define 预处理器定义常量的形式:
❗注意:宏定义后边不要加分号
#define 常量名 常量值下面的代码定义了一个名为 PI 的常量:
在程序中使用该常量时,编译器会将所有的 PI 替换为 3.14159
#define PI 3.14159实例:
#include <stdio.h> #define LENGTH 10 #define WIDTH 5 #define NEWLINE '\n' int main() { int area; area = LENGTH * WIDTH; printf("value of area : %d", area); printf("%c", NEWLINE); return 0; }运行结果:value of area : 50
5.2.2.2 const 关键字定义常量
可以使用 const 前缀声明指定类型的常量,如下所示:
❗注意,把常量定义为大写字母形式,是一个很好的编程习惯。
const 数据类型 常量名 = 常量值;下面的代码定义了一个名为MAX_VALUE的常量:
在程序中使用该常量时,其值将始终为100,并且不能被修改。
const int MAX_VALUE = 100;❗注意:const 声明常量要在一个语句内完成
错误写法:
const int var;
const int var; var=5;
正确写法: const int var = 5;
实例:
#include <stdio.h> int main() { const int LENGTH = 10; const int WIDTH = 5; const char NEWLINE = '\n'; int area; area = LENGTH * WIDTH; printf("value of area : %d", area); printf("%c", NEWLINE) return 0; }运行结果:value of area : 50
5.2.2.3 #define 与 const 区别
#define 与 const 这两种方式都可以用来定义常量,选择哪种方式取决于具体的需求和编程习惯。通常 情况下,建议使用 const 关键字来定义常量,因为它具有类型检查和作用域的优势,而 #define 仅进 行简单的文本替换,可能会导致一些意外的问题。
#define 预处理指令和 const 关键字在定义常量时有一些区别:
替换机制: #define 是进行简单的文本替换,而 const 是声明一个具有类型的常量。 #define 定义的常量在编译时会被直接替换为其对应的值,而 const 定义的常量在程序运行时会分配内 存,并且具有类型信息。
类型检查: #define 不进行类型检查,因为它只是进行简单的文本替换。而 const 定义的常量 具有类型信息,编译器可以对其进行类型检查。这可以帮助捕获一些潜在的类型错误。
作用域: #define 定义的常量没有作用域限制,它在定义之后的整个代码中都有效。而const定义的常量具有块级作用域,只在其定义所在的作用域内有效。
调试和符号表:使用 #define 定义的常量在符号表中不会有相应的条目,因为它只是进行文本替 换。而使用 const 定义的常量会在符号表中有相应的条目,有助于调试和可读性。
6 C语言中标识符的命名规则以及注释 6.1 标识符的命名规则
1) 只能由26个英文字母、数字或下划线3种字符组成。 2) 第1个字符只能是字母或下划线。 3) 大小写敏感的。 4) 不能是关键字(关键词参考下面介绍的《C语言关键字》)。 合法标识符:Abc、a1、_max、day 非法标识符:1a、%abc、#33、a<b、1_2_5、in
6.2 C语言关键字
在c语言里面所谓的关键字,就是在我们编写代码时,颜色不一样的字。
而这些关键字,我们可以大致将其分为几类:存储类型、数据类型、控制语句、其他关键字。
类别关键字存储类型auto、static、register、extern数据类型int、short、long、char、float、double、signed、unsigned、struct、enum、union、void控制语句if、else、switch、case、default、break、for、while、do、goto、continue其他关键字const、sizeof、typedef、volatile、return6.3 C语言的注释 /* 这是一个多行注释, 它将在编译时被自动忽略 */ int width = 20; // 这是一个单号注释 int x = 10; // 这是一个变量声明,它的值将被初始化为10 double y = 3.14; // 这是一个浮点数赋值语句,它将被转换为一个双精度浮点数
7 C语言中printf与数据类型占位符
在上文中我们给大家介绍过printf,为了方便记忆我们列出了printf中常用的占位符
占位符类型说明%dint以十进制输出整数,%i 是以前的用法%ffloat输出单精度浮点数,可以指定精度,%2f 就是保留 2 位小数%lfdouble输出双精度浮点数,也可以指定精度%cchar也可以使用 % d 输出 char,此时输出的是字符的 ASCII 码%s字符串输出字符串❗注意:printf中数据类型一定不能用错,这涉及到数据在内存中表示格式的问题
另外,在printf 中也可以同时使用多个占位符,只要前后和参数的类型、个数能够对得上就行
例如:
printf("name=%s, age=%d, height=%f", "itying", 18, 3.14);补充:volatile关键字
在 C 中,volatile 关键字主要用于告诉编译器,被修饰的变量可能会以编译器未知的方式被修改,因此编译器在对该变量进行优化时需要特殊处理,不要对该变量的访问进行不必要的优化。
举例:
a += 1;
a += 2;
经过编译器优化后,会直接变成
a += 3;
有了关键字volatile,则会分步进行,不会进行合并优化
好处:嵌入式的每一个步骤可能都有相应的作用,而合并会导致过程或结果不同
【C语言】第一期——数据类型变量常量由讯客互联手机栏目发布,感谢您对讯客互联的认可,以及对我们原创作品以及文章的青睐,非常欢迎各位朋友分享到个人网站或者朋友圈,但转载请说明文章出处“【C语言】第一期——数据类型变量常量”