C 语言基础教程(我的C之旅开始了)[八]

19. 基本数据类型:复数类型和虚数类型

C99 新增了复数类型_Complex)和虚数类型_Imaginary)。简单来说,C99 提供了三种复数类型:float _Complexdouble _Complex,和 long double _Complex。对于 float _Complex 类型的变量来说,它包含两个 float 类型的值,一个用于表示复数的实部real part),另一个用于表示虚部imaginary part)。类似地,
double _Complex 包含两个 double 类型的值。以此类推。C99 也提供了三种虚数类型:float _Imaginarydouble _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 类型在任何环境下都是可选的。目前的编译器对这两种类型的支持都不太好,故而我在此就不对这两种类型进行更深入的讨论了。

至此,基本数据类型就全部讨论完了。






20. 转义字符使用实例

下面这个例子演示了 \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.
这是因为 \t 使活跃位置向后移动了若干个位置(通常是八个),然后输出
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。

2. 除法运算符(Division Operator):/

C 使用 / 作为除法运算符。/ 左边的操作数除以右边的操作数。也就是说,/ 左边是被除数,右边是除数。例如:

var = 6/2;

6 除以 2 得 3,然后 3 被赋值给变量 var。

整数相除和浮点数相除有所不同。浮点数相除得到浮点数,整数相除得到整数。C 语言规定,整数相除产生的小数部分一律被抛弃,这就是所谓的截断(truncation)。例如:7/4 的结果是 1,而不是 1.75,也不是 2。

下面我们来看一个小程序。

/* divide.c */
        #include <stdio.h>

int main(void)
        {
            printf("integer division:  7/4   is %d \n", 7/4);
            printf("floating division: 7./4. is %f \n", 7./4.);
            printf("mixed division:    7./4  is %f \n", 7./4);

return 0;
        }

输出为:

integer division:  7/4   is 1
        floating division: 7./4. is 1.750000
        mixed division:    7./4  is 1.750000

最后一个 printf 中,我们用浮点数除以整数,得到的结果和第二个 printf 一样。这是因为 C 自动把这两个操作数的类型转换成了同一种类型。本例中,整数 4 被转换成了浮点类型,然后再和浮点数 7. 相除。

C99 之前,正整数和负整数相除,如果产生小数部分,则相除的结果是不确定的。例如:7/-4 的结果可能是 -2,也可能是 -1。C99 规定,正整数和负整数相除,产生的小数部分一律被抛弃。也就是说,C99 中,7/-4 的结果是确定的,一定是 -1。

Tags:C 语言基础教程(我的C之旅开始了)[八]

相关文章

  • 2013-05-05深入uCOS中全局变量的使用详解
  • 2014-10-10C++设计模式之享元模式
  • 2017-07-07KMP 算法实例详解
  • 2013-09-09二叉查找树的插入,删除,查找
  • 2013-12-12冒泡算法的改进具体实现
  • 2015-09-09C语言的isatty函数和ttyname函数以及sendmsg函数用法
  • 2013-09-09Linux vmstat命令实战详细解析
  • 2017-05-05C++ 中CloseHandle 函数--关闭一个句柄
  • 2013-07-07C语言中字符串和数字的相互转换实现代码
  • 2013-05-05C语言 数与串之间转换的方法

最新评论

(0)

相关推荐

  • C 语言基础教程(我的C之旅开始了)[八]

    19. 基本数据类型:复数类型和虚数类型 C99 新增了复数类型(_Complex)和虚数类型(_Imaginary).简单来说,C99 提供了三种复数类型:float _Complex,double _Complex,和 long double _Complex.对于 float _Complex 类型的变量来说,它包含两个 float 类型的值,一个用于表示复数的实部(real part),另一个用于表示虚部(imaginary part).类似地,double _Complex 包含两个

  • C 语言基础教程(我的C之旅开始了)[十]

    27. 表达式(Expression) 表达式由运算符和操作数组成.单独一个操作数是最简单的表达式.请看以下例子: 9                    -4                    +5                 3 + 6       a * ( b/c - d )             e = 9 / 3           f = ++e % 3 表达式中的表达式称为子表达式.例如:b/c 是 a * ( b/c - d ) 的子表达式. 每个表达式都有一个值,

  • C 语言基础教程(我的C之旅开始了)[六]

    14. 基本数据类型:字符型(上) 1.字符型(char)简介 字符型(char)用于储存字符(character),如英文字母或标点.严格来说,char 其实也是整数类型(integer type),因为 char 类型储存的实际上是整数,而不是字符.计算机使用特定的整数编码来表示特定的字符.美国普遍使用的编码是 ASCII(American    Standard    Code   for    Information   Interchange  美国信息交换标准编码).例如:ASCII

  • C 语言基础教程(我的C之旅开始了)[五]

    12. 基本数据类型:整型(下) 1. 输出各种整数类型的变量 输出不同类型的整数,需要使用不用的格式限定符.输出 unsigned int 类型的整数,要用 %u .输出 long ,要用 %ld:如果要以十六进制或者八进制形式输出,那就用 %lx(或者%lX)或者 %lo.注意:虽然整数常量的后缀使用大写或者小写英文字母都没关系,但是它们格式限定符必须使用小写!如果我们要输出 short 类型的整数,可以在 %d 中间加上前缀 h,也就是%hd:同理,%ho 和 %hx(或者 %hX )分别

  • C 语言基础教程(我的C之旅开始了)[四]

    10. 基本数据类型:整型(上) 1. 整型 int C 语言提供了很多整数类型(整型),这些整型的区别在于它们的取值范围的大小,以及是否可以为负.int 是整型之一,一般被称为整型.    int 代表有符号整数,也就是说,用 int 声明的变量可以是正数,可以是负数,也可以是零,但是只能是整数.标准规定 int 的最小取值范围是 -32767 到 32767.int 的取值范围因机器而异,但是一定要大于或者等于-32767到 32767.一般来说,int 占用一个字的内存空间.因此,字长为

  • C 语言基础教程(我的C之旅开始了)[三]

    7. 第三个 C 程序 首先请看下面这个小程序,试着自己编译运行一下.如果不懂怎么编译,请点击下面的超链接:      编译器使用方法    编译器Dev-C++下载&使用教程 /* circle.c  --  计算圆的面积 */ #include <stdio.h> int main( void )      {          float radius;    /* 圆的半径 */ printf( "Please enter the radius: " ); 

  • C 语言基础教程(我的C之旅开始了)[二]

    3. C 程序的结构 C 程序由一个以上的函数组成,而且必须有 main 函数.此外,C 程序一般还有一些预处理指令.例如 #include 指令.当然并不是必须要有 #include 指令.函数由函数头和函数体组成.函数头由返回值.函数名以及参数列表(可以是void)组成.函数体从 { 开始,以 } 结束.函数体里可以有一系列的语句,每个语句以分号(;)结束.例如: 预处理指令     --〉   #include <stdio.h> 函数头         --〉  int main( v

  • C 语言基础教程(我的C之旅开始了)[九]

    24. +.-.*./.= 的优先级 1. 优先级 和数学一样,C 语言规定先乘除后加减.也就是说,乘法运算符和除法运算符的优先级(Precedence)比加法运算符和减法运算符高.同时,C 语言也规定,如果两个运算符的优先级相同,并且它们之间没有被优先级比它们高或者低的运算符隔开,则它们的运算顺序根据它们在语句中出现的先后而定.大多数运算符都是从左向右进行运算的,不过也有从右向左进行运算的(例如赋值运算符).乘法运算符和除法运算符的优先级相同,加法运算符和减法运算符的优先级相同.因此,以下语句

  • C 语言基础教程(我的C之旅开始了)[七]

    17. 基本数据类型:布尔型(_Bool type) _Bool 型是 C99 添加的,用于表示布尔值,亦即是表示逻辑真(true)和逻辑假(false).因为 C 用 1 表示 true ,0 表示 false ,所以 _Bool 实际上是整数类型.理论上 _Bool 只需要 1 bit 存储单元,因为1 bit 就足以表示 0 和 1 .事实上,_Bool 是无符号整型,一般占用 1 字节.例如: _Bool flag = 1; flag = 0; 包含标准头文件 stdbool.h 后,我

  • C 语言基础教程(一)颜色加亮

    首先请看下面这个简单的 C 程序,猜猜它会做些什么.猜不出来也没关系,后面会有详细的解说.         #include <stdio.h> int main( void )            /* 一个简单的程序 */         {             int num;                  /* 定义一个名叫 num 的变量 */             num = 1;                  /* 将 1 赋值给 num         */ p

随机推荐