C 语言编程教程

C 语言 - 首页

C 语言基础

C 语言 - 概述 C 语言 - 特性 C 语言 - 发展历史 C 语言 - 环境设置 C 语言 - 程序结构 C 语言 - Hello World C - 编译过程 C - 注释 C - 标记 C - 关键字 C - 标识符 C - 用户输入 C - 基本语法 C - 数据类型 C - 变量 C - 整数提升 C - 类型转换 C - 类型转换 C - 布尔值

C 语言中的常量和文字

C - 常量 C - 字面量 C - 转义序列 C - 格式说明符

C 语言中的运算符

C - 运算符 C - 算术运算符 C - 关系运算符 C - 逻辑运算符 C - 位运算符 C - 赋值运算符 C - 一元运算符 C - 递增和递减运算符 C - 三元运算符 C - sizeof 运算符 C - 运算符优先级 C - 其他运算符

C 语言中的决策

C - 决策 C - if 语句 C - if...else 语句 C - 嵌套 if 语句 C - switch 语句 C - 嵌套 switch 语句

C 语言中的循环

C - 循环 C - While 循环 C - For 循环 C - Do...while 循环 C - 嵌套循环 C - 无限循环 C - Break 语句 C - Continue 语句 C - goto 语句

C 语言中的函数

C - 函数 C - Main 函数 C - 按值调用函数 C - 按引用调用函数 C - 嵌套函数 C - 可变参数函数 C - 用户定义函数 C - 回调函数 C - return 语句 C - 递归

C 语言中的作用域规则

C - 作用域规则 C - 静态变量 C - 全局变量

C 语言中的数组

C - 数组 C - 数组的属性 C - 多维数组 C - 将数组传递给函数 C - 从函数返回数组 C - 可变长度数组

C 语言中的指针

C - 指针 C - 指针和数组 C - 指针的应用 C - 指针运算 C - 指针数组 C - 指向指针的指针 C - 将指针传递给函数 C - 从函数返回指针 C - 函数指针 C - 指向数组的指针 C - 指向结构体的指针 C - 指针链 C - 指针 vs 数组 C - 字符指针和函数 C - NULL 指针 C - void 指针 C - 悬垂指针 C - 解引用指针 C - Near、Far 和 Huge 指针 C - 指针数组的初始化 C - 指针与多维数组

C 语言中的字符串

C - 字符串 C - 字符串数组 C - 特殊字符

C 语言的结构体和联合

C - 结构体 C - 结构体和函数 C - 结构体数组 C - 自引用结构 C - 查找表 C - 点 (.) 运算符 C - 枚举(或 enum) C - 结构填充和打包 C - 嵌套结构 C - 匿名结构和联合 C - 联合 C - Bit 位字段 C - Typedef

C 语言中的文件处理

C - 输入和输出 C - 文件 I/O(文件处理)

C 语言中的预处理器

C - 预处理器 C - #pragma 编译指示 C - 预处理器操作符 C - 宏 C - 头文件

C 语言中的内存管理

C - 内存管理 C - 内存地址 C - 存储类

C 其他主题

C - 错误处理 C - 可变参数 C - 命令执行 C - 数学函数 C - static 静态关键字 C - 随机数生成 C - 命令行参数

C 语言编程资源

C语言问题与解答答案 C语言快速指南 C语言速查表 C语言实用资源 C语言讨论


C - 字面量

计算机编程术语中的"字面量"是指要赋给变量的值的文本表示形式。

在 C 语言中,可以通过两种方式为变量赋值 -

  • 使用字面量表示
  • 使用表达式

C 语言中变量的初始化如下 -

int x = 10;

另一方面,通过将表达式的结果赋给变量来间接初始化变量的方式如下 -

int x = 10;
int y = x*2;

在第一种情况下,10 是一个赋值给"x"的整数字面值。在第二种情况下,表达式"x*2"的结果赋值给"y"。

因此,字面值是直接在源代码中表示的特定数据类型的值。通常,字面值用于设置变量的值。

字面值本身不构成任何编程元素。不同类型的值使用不同的表示法来表示。

C 语言中的整数字面值

在上面的例子中,10 是一个整数字面值。用 0 到 9 表示的正整数或负整数,不带小数部分,则为十进制整数字面值。它必须在给定操作系统平台的可接受范围内。

以下示例将十进制文字赋值给 int 变量 -

int x = 200;
int y = -50;

整数字面值也可以带有"U"和"L"组合的后缀,分别代表"unsigned"和"long"。后缀可以是大写或小写,也可以是任意顺序。

int c = 89U;
long int d = 99998L;

C 语言允许用八进制和十六进制表示整数。对于八进制的字面量表示,请在数字前添加 0(确保该数字仅使用八进制数字,范围从 0 到 7)。

对于十六进制字面量,请在数字前添加 0x 或 0X。十六进制数必须包含 0 到 9 以及 A 到 F(或 a 到 f)的符号。

示例

请看以下示例 -

#include <stdio.h>

int main(){

   int oct = 025;
   int hex = 0xa1;
   printf("Octal to decimal: %d
", oct);
   printf("Hexadecimal to decimal: %d
", hex);
}

输出

运行此代码后,您将获得以下输出 -

Octal to decimal: 21
Hexadecimal to decimal: 161

现代 C 编译器也允许您将整数表示为二进制数,为此您需要添加 0b 前缀。

示例

请看以下示例 -

#include <stdio.h>

int main(){

   int x = 0b00010000;
   printf("binary to decimal: %d", x);
}

输出

运行代码并检查其输出 −

binary to decimal: 16

以下是一些整数文字的示例 -

212 	/* 有效 */
215u 	/* 有效 */
0xFeeL 	/* 有效 */
078 	/* 无效:8 不是八进制数字 */
032UU 	/* 无效:不能重复后缀 */

以下是其他一些不同类型的整数文字的示例 -

85 		/* 十进制 */
0213 	/* 八进制 */
0x4b 	/* 十六进制 */
30 		/* 整数 */
30u 	/* 无符号整数 */
30l 	/* 长整型 */
30ul 	/* 无符号长整型 */

浮点数C 语言中的字面量

C 语言中的浮点字面量是一个实数,它由整数部分和小数部分组成,小数部分在编译器可接受的范围内,以数字、小数点和可选的指数符号(e 或 E)表示。

浮点字面量通常用于初始化或设置 C 语言中浮点型或双精度型变量的值。

示例

以下赋值示例使用浮点字面量,用小数点分隔整数部分和小数部分 -

#include <stdio.h>

int main(){

   float x = 10.55;
   float y = -1.333;
   printf("x and y are: %f, %f", x, y);
}

输出

You will get the following output −

x and y are: 10.550000, -1.333000

高精度浮点字面量可以用指数符号"e"或"E"表示。这被称为浮点字面量的科学计数法

表示小数形式时,必须包含小数点、指数或两者。表示指数形式时,必须包含整数部分、小数部分或两者。

示例

请看以下示例 -

#include <stdio.h>

int main(){

   float x = 100E+4;
   float y = -1.3E-03;
   printf("x: %f
", x);
   printf("y: %f
", y);
}

输出

运行此代码时,将产生以下输出 -

x: 1000000.000000
y: -0.001300

以下是一些浮点文字的示例 -

3.14159 	/* 有效 */
314159E-5L 	/* 有效 */
510E 		/* 无效:指数不完整 */
210f 		/* 无效:没有小数或指数 */
.e55 		/* 无效:缺少整数或分数 */

C 语言中的字符文字

C 语言中的字符文字是用单引号括起来的单个字符。请注意,C 语言只识别直引号。因此,使用 ' 而不是 来构成字符文字。以下是一个例子 -

char x = 'I';

字符字面量通常赋值给一个占用单个字节的 char 变量。使用 %c 格式说明符输出该字符。使用 %d 则可获取该字符的 ASCII 值。

示例

请看以下示例 -

#include <stdio.h>

int main(){

   char x = 'I';
   printf("x: %c
", x);
   printf("x: %d
", x);
}

输出

运行代码并检查其输出 −

x: I
x: 73

C 语言中的转义序列

C 语言将许多转义序列定义为以"\"开头的字符序列,并在其后附加其他含义。

即使转义序列包含多个字符,也必须将其放在单引号中。转义序列的效果相当于一个不可打印的字符。例如,' ' 是一个表示换行符的转义序列,其效果与按下 Enter 键相同。

示例

请看以下示例 -

#include <stdio.h>

int main(){

   char x = 'I';
   char y = 'J';
   printf("x: %c
y: %c", x,y);
}

输出

您将获得以下输出 -

x: I
y: J

我们将在后面的章节中学习更多关于转义序列的知识。

字符字面量也可以是字符的 UNICODE 表示形式。这样的字面量以 /u 开头。

示例

请看以下示例 -

#include <stdio.h>

int main(){

   char x = '\u09A9';
   printf("x: %c
", x);
   printf("x: %d
", x);
}

输出

运行此代码后,您将获得以下输出 -

x: 
y: -87

C 语言中的字符串字面量

用双引号括起来的字符序列构成字符串字面量。C 语言不提供字符串变量。因此,我们需要使用 char 类型的数组来存储字符串。

示例

请看以下示例 -

#include <stdio.h>

int main(){

   char arr[] = "Hello World";
   printf("arr: %s", arr);
}

输出

运行代码并检查其输出 −

arr: Hello World

字符串字面量可以包含纯字符、转义序列和 Unicode 字符。例如:-

char arr[] = "Hello \
World";

你也可以通过将数组元素放在大括号 { 和 } 中来获得数组的字面量表示。例如:

int arr[] = {10, 20, 30, 40};

类似地,大括号也可以用于结构体值的字面量表示。例如:-

struct marks {
   int phy;
   int che;
   int math
};
struct marks m1 = {50, 60, 70};

我们将在本教程的后面详细了解数组和结构。