Cprogramming 简明教程

C - Literals

计算机编程术语中的“文字”是指要分配给变量的值的文本表示。

在 C 中,你可以通过两种方式向一个变量分配一个值 ——

  1. Using literal representation

  2. Using an expression

C 中变量的初始化如下进行 ——

int x = 10;

另一方面,通过将一个表达式的结果分配给一个变量,对变量进行间接初始化如下所示 ——

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

在第一个例子中,10 是一个被分配给“x”的整数字面量。在第二个例子中,“x*2” 表达式的结果被分配给了“y”。

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

字面量本身不形成任何编程元素。不同的符号用于表示不同数据类型的值。

Integer Literals in C

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

下面的例子将十进制字面量分配给 int 变量 ——

int x = 200;
int y = -50;

一个整数字面量还可以有一个后缀,它是“U”和“L”的组合,分别代表“无符号”和“长”。后缀可以是大写或小写,并且可以按任何顺序排列。

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

C 允许你用八进制和十六进制数字系统表示一个整数。对于一个八进制的字面量表示,使用 0 作为前缀(确保数字仅使用八进制数字,从 0 到 7)。

对于一个十六进制字面量,使用 0x 或 0X 作为前缀。十六进制数字必须有 0 到 9,以及 A 到 F(或 a 到 f)符号。

Example

请看以下示例:

#include <stdio.h>

int main(){

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

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

Octal to decimal: 21
Hexadecimal to decimal: 161

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

Example

请看以下示例:

#include <stdio.h>

int main(){

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

运行代码并检查其输出:

binary to decimal: 16

以下是整数文本的一些示例:

212      /* valid */
215u     /* valid */
0xFeeL   /* valid */
078      /* invalid: 8 is not an octal digit */
032UU    /* invalid: cannot repeat a suffix */

以下是其他一些各种类型的整数字面量示例−

85       /* decimal */
0213     /* octal */
0x4b     /* hexadecimal */
30       /* int */
30u      /* unsigned int */
30l      /* long */
30ul     /* unsigned long */

Floating-point Literals in C

C 中的浮点字面量是一个实数,它有一个整数部分和小数部分,其范围为所用编译器接受的范围之内,并用数字表示,小数点带有一个可选的指数符号(e 或 E)。

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

Example

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

#include <stdio.h>

int main(){

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

你将获得以下输出 -

x and y are: 10.550000, -1.333000

具有高度精度的浮点字面量可以用指数符号“e”或“E”表示。这称为 scientific notation of a float literal

在表示十进制形式时,您必须包括小数点、指数或两者。在表示指数形式时,您必须包括整数部分、小数部分或两者。

Example

请看以下示例:

#include <stdio.h>

int main(){

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

当你运行这段代码时,它将产生以下输出:

x: 1000000.000000
y: -0.001300

以下是浮点数文本的一些示例:

3.14159     /* valid */
314159E-5L  /* valid */
510E        /* invalid: incomplete exponent */
210f        /* invalid: no decimal or exponent */
.e55        /* invalid: missing integer or fraction */

Character Literals in C

C 中的字符字面量是单引号符号中包含的单个字符。请注意,C 仅识别直引号。因此,使用 ' 形成字符字面量,而不是 )。以下是示例−

char x = 'I';

字符字面量通常分配给一个占一个字节的 char 变量。使用 %c 格式说明符输出字符。使用 %d ,您将获得字符的 ASCII 值。

Example

请看以下示例:

#include <stdio.h>

int main(){

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

运行代码并检查其输出:

x: I
x: 73

Escape Sequences in C

C 将许多转义序列定义为以“\”开头的字符序列,并且附加到后续字符的备用含义。

即使转义序列包括多个字符,它也会放在单引号中。转义序列产生单个不可打印字符的效果。例如, '\n' 是代表换行符的转义序列,其效果与按下 Enter 键相同。

Example

请看以下示例:

#include <stdio.h>

int main(){

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

在这里,您将获得此输出−

x: I
y: J

我们将在后面的章节中详细了解转义序列。

字符字面量也可以是字符的UNICODE表示。此类字面量在开头有 /u

Example

请看以下示例:

#include <stdio.h>

int main(){

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

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

x: ⌐
y: -87

String Literals in C

放在双引号符号中的字符序列形成字符串字面量。C 不提供字符串变量。相反,我们需要使用 char 类型数组来存储字符串。

Example

请看以下示例:

#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};

后面章节中我们将详细了解数组和结构。