C 语言基础教程(我的C之旅开始了)[八]
19. 基本数据类型:复数类型和虚数类型
C99 新增了复数类型(_Complex)和虚数类型(_Imaginary)。简单来说,C99 提供了三种复数类型:float _Complex,double _Complex,和 long double _Complex。对于 float _Complex 类型的变量来说,它包含两个 float 类型的值,一个用于表示复数的实部(real part),另一个用于表示虚部(imaginary part)。类似地,
double _Complex 包含两个 double 类型的值。以此类推。C99 也提供了三种虚数类型:float _Imaginary,double _Imaginary,以及 long double _Imaginary。虚数类型只有虚部,没有实部。
包含标准头文件 complex.h 后,我们就可以用 complex 来代表 _Complex,用
imaginary 来代表 _Imaginary,以及用 I 来代表虚数单位 i,也就是 -1 的平方根。例如:
#include <complex.h>
double _Complex x = 5.2; /* 实部等于 5.2,虚部为 0 */
double complex y = 5.0 * I; /* 实部为 0,虚部为 5.0 */
double complex z = 5.2 – 5.0 * I; /* 实部为 5.2,虚部为 5.0 */
注意:_Complex 类型对于独立式环境(freestanding environment)来说是可选的。可选的意思是,不强制必须支持这种类型。而所谓独立式环境,是指 C 程序可以在没有操作系统的情况下运行。_Imaginary 类型在任何环境下都是可选的。目前的编译器对这两种类型的支持都不太好,故而我在此就不对这两种类型进行更深入的讨论了。
至此,基本数据类型就全部讨论完了。
下面这个例子演示了 \a、\b、\t、\r,以及 \n 的作用。其中 \b,\t 和 \r 的概念可以追溯到电脑仍然使用打字机作为输出设备的时候,所以对于现代的一些电脑来说,它们可能不起作用。在某些麦金托什机(Macintosh)上,它们的作用就和我们下面所说的不一样。首先请认真看一下以下程序,然后编译运行一下,看看运行结果和您想象的是否一样,然后再看后面的详细解说。 /* esc_sq.c -- 使用转义字符 */ #include <stdio.h> int main(void) { float height; printf("\aPlease enter your height: _____ cm\b\b\b\b\b\b\b\b"); scanf("%f", &height); printf("\tYour height is %.2f.\rOh!\n", height); return 0; } 第一个 printf 通常会引起一声鸣响(\a),同时显示以下提示 Please enter your height: _____ cm 其中活跃位置(光标)在下划线的开端。活跃位置之所以会位于下划线的开端,是因为那八个 \b 把活跃位置后退了八个位置。顺带一题,下划线 _____ 由五个 _ 构成。注意:一般来说,\b 不会擦除前面输出的字符,但是在某些系统,\b 却会擦除前面输出的字符,导致显示结果为 Please enter your height: 。\a 产生的效果取决于硬件。一般来说,输出 \a 会产生鸣响。但是在某些系统,输出 \a 不会产生任何效果,或者仅仅显示一个特殊字符。 输入一个数后(比如输入 180.5),屏幕的显示会变成 Please enter your height: 180.5 cm 第二个 printf 运行结束后,屏幕显示如下: Please enter your height: 180.5 cm Oh! Your height is 180.50.20. 转义字符使用实例 我们输入的数字取代了原来的下划线。接着我们需要按回车确定我们的输入。按下回车键后,
活跃位置会移动到下一行的开端。
Your height is 180.50. 。接着 \r 使活跃位置返回当前行的开端,然后输出 Oh! ,
最后 \n 引起换行。
加法运算符使它左右两边的值相加。例如: printf("%d", 9 + 11); 输出结果为 20。加法运算符的操作数可以是常量,也可以是变量。例如: var = var_1 + var_2; 这个语句先把 var_1 的值和 var_2 的值相加,然后把相加的结果赋值给 var。 2. 减法运算符(Subtraction Operator): – 减法运算符导致左边的操作数减去右边的操作数。例如: var = 100 – 40; 100 – 40 的值是 60,然后这个 60 被赋值给 var。 加法运算符和减法运算符被称为二目运算符(binary operator),因为它们需要两个操作数。 3. 正负运算符(Sign Operator): – 和 + 例如: var_1 = -5;var_2 = -var_1;var = +5 var_1 的值是 -5,var_2 的值是 5,var 的值是 5。 正负运算符被称为单目运算符(unary operator),因为它们只需要一个操作数。
23. 乘法运算符和除法运算符 |
1. 乘法运算符(Multiplication Operator):* * 是乘法运算符。以下语句: meter = 100 * cm; 常量 100 和变量 cm 相乘,乘积被赋值给变量 meter。
C 使用 / 作为除法运算符。/ 左边的操作数除以右边的操作数。也就是说,/ 左边是被除数,右边是除数。例如: var = 6/2; 6 除以 2 得 3,然后 3 被赋值给变量 var。 整数相除和浮点数相除有所不同。浮点数相除得到浮点数,整数相除得到整数。C 语言规定,整数相除产生的小数部分一律被抛弃,这就是所谓的截断(truncation)。例如:7/4 的结果是 1,而不是 1.75,也不是 2。 下面我们来看一个小程序。 /* divide.c */ int main(void) return 0; 输出为: integer division: 7/4 is 1 最后一个 printf 中,我们用浮点数除以整数,得到的结果和第二个 printf 一样。这是因为 C 自动把这两个操作数的类型转换成了同一种类型。本例中,整数 4 被转换成了浮点类型,然后再和浮点数 7. 相除。 C99 之前,正整数和负整数相除,如果产生小数部分,则相除的结果是不确定的。例如:7/-4 的结果可能是 -2,也可能是 -1。C99 规定,正整数和负整数相除,产生的小数部分一律被抛弃。也就是说,C99 中,7/-4 的结果是确定的,一定是 -1。 |
相关文章
- _Bool 型是 C99 添加的,用于表示布尔值,亦即是表示逻辑真(true)和逻辑假(false)。因为 C 用 1 表示 true ,0 表示 false...2020-04-25
- C99 新增了复数类型(_Complex)和虚数类型(_Imaginary)。简单来说,C99 提供了三种复数类型:float _Complex,double _Complex......2020-04-25
- C 程序由一个以上的函数组成,而且必须有 main 函数。此外,C 程序一般还有一些预处理指令。例如 #include 指令。当然并不是必须要有 #include 指令。...2020-04-25
- Lua 的语法比较简单,学习起来也比较省力,但功能却并不弱。所以,我只简单的归纳一下Lua的一些语法规则,使用起来方便好查就可以了。估计看完了,就懂得怎么写Lua程序了。...2020-06-30
- VBS(VBScript的进一步简写)是基于Visual Basic的脚本语言. Microsoft Visual Basic是微软公司出品的一套可视化编程工具, 语法基于Basic. 脚本语言, 就是不编译成二进制文件, 直接由宿主(host)解释源代码并执行...2020-06-30
- C语言是一门通用计算机编程语言,应用广泛。C语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。...2020-04-25
- 字符型(char)用于储存字符(character),如英文字母或标点。严格来说,char 其实也是整数类型(integer type)......2020-04-25