C语言学习“数据类型、运算符与表达式”这一篇就够了(14700多字超详解)

3.1 C语言的数据类型(理解)

 首先,对变量的定义可以包括三个方面:

数据类型

存储类型

作用域

所谓数据类型是按被定义变量的性质,表示形式,占据存储空间的多少,构造特点来划分的。在C语言中,数据类型可分为:基本数据类型,构造数据类型,指针类型,空类型四大类。

熟记下面这个导图即可

 1.基本数据类型:基本数据类型最重要的特点是,其值不可以再分解为其它类型。也就是说,基本数据类型是自我说明的。

2.构造数据类型:构造数据类型是根据已定义的一个或多个数据类型用构造的方法来定义的。也就是说,一个构造类型的值可以分解成若干个“成员”或“元素”。每个“成员”都是一个基本数据类型或又是一个构造类型。在C语言中,构造类型有以下几种:

数组类型

结构体类型

共用体(联合)类型

3.指针类型:指针是一种特殊的,同时又是具有重要作用的数据类型。其值用来表示某个变量在内存存储器中的地址。虽然指针变量的取值类似于整型量,但这是两个类型完全不同的量,因此不能混为一谈。

4.空类型:在调用函数值时,通常应向调用者返回一个函数值。这个返回的函数值是具有一定的数据类型的,应在函数定义及函数说明中给以说明,例如在例题中给出的max函数定义中,函数头为:int max(int a,int b);其中“int”类型说明符即表示该函数的返回值为整型量。又如在例题中,使用了库函数sin,由于系统规定其函数返回值为双精度浮点型,因此在赋值语句s=sin(x);中,s也必须是双精度浮点型,以便与sin函数的返回值一致。所以在说明部分,把s说明为双精度浮点型。但是,也有一类函数,调用后并不需要向调用者返回函数值,这种函数可以定义为“空类型”。其类型说明符为void。在后面函数中还要详细介绍。

3.2 常量与变量(理解)

 对于基本数据类型量,按其取值是否可改变又分为常量和变量两种。在程序执行过程中,其值不发生改变的量称为常量,其值可变的量称为变量。它们可与数据类型结合起来分类。例如,可分为整型常量、整型变量、浮点常量、浮点变量、字符常量、字符变量、枚举常量、枚举变量。在程序中,常量是可以不经说明而直接引用的,而变量则必须先定义后使用。

整型量包括整型常量、整型变量。

 3.2.1 常量和符号变量

在程序执行过程中,其值不发生改变的量称为常量。

直接常量(字面常量):

整型常量:12,0,-4;

实型常量:4.6、-1.23;

字符常量:‘a’、'b'。

标识符:用来标识变量名、符号常量名、函数名、数组名、类型名、文件名的有效字符序列。

符号常量:用标示符代表一个常量。在c语言中,可以用一个标识符来表示一个常量,称之为符号常量。

符号常量在使用之前必须先定义,其一般形式为:

#define 标识符 常量

其中#define也是一条预处理命令(预处理命令都以“#”开头),称为宏定义命令(在后面预处理程序中将进一步介绍),其功能是把该标识符定义为其后的常量值。一经定义,以后在程序中所有出现该标识符的地方均代之以该常量值。

习惯上符号常量的标识符用大写字母,变量标识符用小写字母,以示区别。

#include<stdio.h>
#define PRICE 30
int main()
{
    int num,total;
    num = 10;
    total = num * PRICE;
    printf("total = %d",total);
    return 0;
}

 用标识符代表一个常量,称为符号常量。

符号常量与变量不同,它的值在其作用域内不能改变,也不能再被赋值。

使用符号常量的好处是:

含义清楚;

能做到“一改全改”。

常量导图如图所示:

3.2.2 变量

其值可以改变的量称为变量。一个变量应该有一个名字,在内存中占据一定的存储单元。变量定义必须放在变量使用之前。一般放在函数体的开头部分。要区分变量名和变量值是两个不同的概念。

3.3 整型数据(掌握) 

3.3.1 整型常量的表示方法(必考点)

学习提示:

(1)掌握八进制、十六进制、十进制合法表示。要一眼看出来这个数是不是合法表示,是八进制还是十六进制还是十进制。

(2)掌握八进制、十六进制、十进制以及二进制的相互转换。

整型常量就是整常数。在c语言中,使用的整常数有八进制、十六进制和十进制三种。

1)十进制整常数:十进制整常数没有前缀。其数码为0~9。

以下是合法的十进制整常数:

230,-4512,65535、1258;

以下各数不是合法的十进制整常数:

023(不能有前导0)、23D(含有非十进制数码)。

在程序中是根据前缀来区分各种进制数的。因此在书写常数时不要把前缀弄错造成结果不正确。

 2)八进制整常数:八进制整常数必须以0开头,即以0作为八进制数的前缀。数码取值为0~7。八进制数通常是无符号数。

以下各数是合法的八进制数:

015(十进制为13)、0101(十进制为65)、0177777(十进制为65535);

以下各数不是合法的八进制数:

256(无前缀0)、03A2(包含了非八进制数码A)、-0124(出现了负号)。

3)十六进制整常数:十六进制整常数的前缀为0X或0x。其数码取值为0~9,A~F或a~f。

以下各数是合法的十六进制整常数:

0X2A(十进制为42)、0XA0(十进制为160)、0XFFFF(十进制为65535);

以下各数不是合法的十六进制整常数:

5A(无前缀0X)、0X3H(含有非十六进制数码)。

4)整型常数的后缀:在16位字长的机器上,基本整型的长度也为16位,因此表示的数的范围也是有限定的。十进制无符号整常数的范围为0~65535,有符号数为-32768~+32767。八进制无符号数的表示范围为0~0177777。十六进制无符号数的表示范围为0X0~0XFFFF或0x0~0xFFFF。如果使用的数超过了上述范围,就必须用长整型数来表示。长整型数是用后缀“L”或“I”来表示的。

例如:

十进制长整常数:

158L(十进制为158)、358000L(十进制为358000)

八进制长整常数:

012L(十进制为10)、077L(十进制为63);、0200000L(十进制为65536);

十六进制长整常数:

0X15L(十进制为21)、0XA5L(十进制为165)、0X10000L(十进制为65536);

长整数158L和基本整常数158在数值上并无区别。但对158L,因为是长整型量,C编译系统将它分配4个字节存储空间。而对158,因为是基本整型,只分配2个字节的存储空间。因此在运算和输出格式上要予以注意,避免出错。

无符号数也可用后缀表示,整型常数的无符号数的后缀为“U”或“u”。

例如:

358u,0x38Au,235Lu均为无符号数。

前缀,后缀可同时使用以表示各种类型的数。如0XA5Lu表示十六进制无符号长整数A5,其十进制为165。

3.3.2 整型变量(理解)

1.整型数据在内存中的存放形式(了解)

定义了一个整型变量i:

int i;

i = 10;

0000000000001010

提示:

(1)任何数据的存放都是二进制形式。上图二进制1010表示10。

(2)原码补码相关概念,大家可以去搜一下,初学者了解即可。

数值是以补码表示的:

1:正数的补码和原码相同;

2:负数的补码:将该数的绝对值的二进制形式按位取反再加1。

例如:

求-10的补码:

10的原码:

0000000000001010

取反:

1111111111110101

再加上1,得-10的补码:

1111111111110110

 由此可知,左面的第一位是表示符号的。

2.整型变量的分类(理解)

(1)以下数据类型的字节数与计算机系统有关。16位、32位或者64位系统,int ,long等类型的字节数可能不同。

(2)如果感兴趣,可以自行编程计算手机环境中各类型的字节数。int a;sizeof(a)即可求出int类型的字节数。其他类型类似。

1基本型:类型说明符为int,在内存中占2个字节。

2短整量:类型说明符为short int或short。所占字节和取值范围均与基本型相同。

3长整型:类型说明符为long int 或long,在内存中占4个字节。

4无符号型:类型说明符为unsigned。

无符号型又可与上述三种类型匹配而构成:

1无符号基本型:类型说明符为unsigned int或unsigned。

2无符号短整型:类型说明符为unsigned short。

3无符号长整型:类型说明符为unsigned long。

各种无符号类型量所占的内存空间字节数与相应的有符号类型量相同。但由于省去了符号位,故不能表示负数。

3.整型变量的定义(理解)

变量定义的一般形式为:

类型说明符 变量名标识符,变量名标识符,。。。;

例如:

int a,b,c;(a,b,c为整型变量)

long x,y;(x,y为长整型变量)

unsigned p,q;(p,q为无符号整型变量)

在书写变量定义时,应注意以下几点:

(1)允许在一个类型说明符后,定义多个相同类型的变量。各变量名之间用逗号间隔。类型说明符与变量名之间至少用一个空格间隔。

(2)最后一个变量名之后必须以“;”号结尾。

(3)变量定义必须放在变量使用之前。一般放在函数体的开头部分。

例3.2 整型变量的定义与使用。

#include <stdio.h>

int main()
{
   int a,b,c,d;
	unsigned u;
	a = 12;
	b = -24;
	u = 10;
	c = a + u;
	d = b + u;
   printf("a + u = %d,b + u = %d\n",c,d);
   return 0;
}

运行结果:

 

4.整型数据的溢出

例3.3 整型数据的溢出。

#include <stdio.h>

int main()
{
   int a,b;
	
	// 整数最大值16位时为32767,32位是2147483647,64位9223372036854775807。
	// 所以此题运行结果与编译器环境有关
	a = 2147483647;
	b = a+1;
   printf("%d,%d\n",a,b);
   return 0;
}

 编译结果

 可看出我使用的这个在线编译器是32位的

 例3.4 类型自动转换

#include <stdio.h>

int main()
{
   long x,y;
	int a,b,c,d;
	x = 5;
	y = 6;
	a = 7;
	b = 8;
	c = x+a;
	d = y+b;
   printf("c=x+a=%d,d=y+b=%d\n",c,d);
   return 0;
}

 运行结果:

从程序中可以看到:x,y是长整型变量,a,b是基本整型变量。它们之间允许进行运算,运算结果为长整型。但c,d被定义为基本整型,因此最后结果为基本整型。本例说明,不同类型的量可以参与运算并相互赋值。其中的类型转换是由编译系统自动完成的。有关类型转换的规则将在以后介绍。

3.4 实型数据

3.4.1 实型常量的表示方法(掌握)

实型也称为浮点型。实型常量也称为实数或者浮点数。在C语言中,实数只采用十进制。它有两种形式:十进制小数形式,指数形式。

1)十进制数形式:由数码0~9和小数点组成。

例如:

0.0、25.0、5.789、0.13、5.0、300、-267.8230

等均为合法的实数。注意:必须有小数点。

2)指数形式(考点):由十进制数,加阶码标志“e”或“E”以及阶码(只能为整数,可以带符号)组成。

其一般形式为:

a E n (a为十进制数,n为十进制整数)

其值为a*10^n(10^n意思为10的n次方,以下相同)。

如:

2.1E5(等于2.1*10^5)

3.7E-2(等于3.7*10^-2)

0.5E7(等于0.5*10^7)

-2.8E-2(等于-2.8*10-2)

以下不是合法的实数:

345(无小数点)

E7(阶码标志E之前无数字)

-5(无阶码标志)

53.-E3(负号位置不对)

2.7E(无阶码)

标准C允许浮点数使用后缀。后缀为“f”或“F”即表示该数为浮点数。如356f和356.是等价的。

例3.5说明了这种情况。

#include <stdio.h>

int main()
{
    printf("%f\n",356.);
    printf("%f\n",356);
    printf("%f\n",356f);
   
   return 0;
}

我在编译网站上编译这个的时候发现报错了

 

 网上找的答案,可能这个网站不是标准C吧,不允许这样用?有了解的朋友可以在评论区回答一下

 3.4.2实型变量

1.实型数据在内存中的存放形式(了解)

实型数据一般占4个字节(32位)内存空间。按指数形式存储。

实数3.14159在内存中的存放形式如下:

+0.314161
数符小数部分指数

(1) 小数部分占的位(bit)数愈多,数的有效数字愈多,精度愈高。

(2)指数部分占的位数愈多,则能表示的数值范围愈大。

ps:这个内存存放形式我有点看不懂。搜了一下答案如下:

不同类型的实数变量在内存中占据不同的字节和位数。例如,单精度浮点数(float型)通常占用4个字节(32位)的内存空间,其中1位用于符号,23位用于存储小数部分,剩下的8位用于指数。这样的分配使得单精度浮点数既有适度的精度又有一定的数值范围。对于需要更高精度的计算,双精度浮点数(double型)提供了更优的选择,它使用8个字节(64位)的内存空间,以提供更高的精度和更广泛的数值范围

2.实型变量的分类(掌握)

实型变量分为:单精度(float型)、双精度(double型)和长双精度(long double型)三类。

在Turbo C中单精度型占4个字节(32位)内存空间,其数值范围为3.4E-38~3.4E+38,只能提供七位有效数字。双精度型占8个字节(64位)内存空间,其数值范围为1.7E-308~1.7E+308,可提供16位有效数字。

类型说明符比特数(字节数)有效数字数的范围
float32(4)6-7(10E-37)-(10E-38)
double64(8)15-16(10E-307)-(10E308)
long double128 (4)18-19(10E-4931)-(10E4932)

实型变量定义的格式和书写规则与整型相同。

例如:

float x,y;(x,y为单精度实型量)

double a,b,c;(a,b,c为双精度实型量)

3.实型数据的舍入误差(理解)

由于实型变量是由有限的存储单元组成的,因此能提供的有效数字总是有限的。如下例。

例3.6实型数据的舍入误差。

#include <stdio.h>

int main()
{
    float a,b;
	a = 123456.789e5;
	b = a + 20;
	printf("%f\n",a);
   	printf("%f\n",b);
   return 0;
}

运行结果: 

 注意:1.0/3*3的结果并不等于1.

#include <stdio.h>

int main()
{
    float a;
	double b;
	a = 33333.33333;
	b = 33333.33333333333333;
	printf("%f\n%f\n",a,b);
   return 0;
}

 运行结果:

 

从本例可以看出,由于a是单精度浮点型,有效位数只有七位。而整数已占五位,故小数二位后之后均为无效数字。

b是双精度型,有效位为十六位。但Turbo C规定小数后最多保留六位,其余部分四舍五入。

 3.4.3 实型常数的类型

实型常数不分单、双精度,都按双精度double型处理。

 3.5 字符型数据

字符型数据包括字符常量和字符变量。

3.5.1 字符常量(掌握)

字符常量是用单引号括起来的一个字符。

例如:

‘a’、‘b’、‘=’、‘+’、‘?’

都是合法字符常量。

在C语言中,字符常量有以下特点:

1)字符常量只能用单引号‘’指出,不能用双引号“”或其他括号。

2)字符常量只能是单个字符,不能是字符串。

3)字符可以是字符集中任意字符。但数字被定义为字符型之后就不能参与数值运算。如‘5’和5是不同的。‘5’是字符常量,不能参与运算。

3.5.2 转义字符(理解)

转义字符是一种特殊的字符常量。转义字符以反斜线“\”开头,后跟一个或几个字符。转义字符具有特定的含义,不同于字符原有的意义,故称“转义”字符。例如,在前面各例题printf函数的格式串中用到的“\n”就是一个转义字符,其意义是“回车换行”。转义字符主要用来表示那些用一般字符不便于表示的控制代码。

广义的讲,C语言字符集中的任何一个字符均可用转义字符来表示。表中的\ddd和\xhh正是为此而提出的。ddd和hh分别为八进制和十六进制的ASCLL代码。如\101表示字母“A”,\102表示字母“B”,\134表示反斜线,\XOA表示换行等。

例3.8 转义字符的使用。

#include <stdio.h>

int main()
{
   int a,b,c;
   a = 5;b = 6;c = 7;
   printf("  ab  c\tde\rf\n");
   printf(" hijk\tL\bM\n");
   return 0;
}

 运行结果:

 其中\t代表横向跳到下一制表位置

\r:回车        \f:走纸换页        \b:退格(输出的结果为一个正方形,不太懂)

3.5.3 字符变量(理解)

字符变量用来存储字符常量,即单个字符。

字符变量的类型说明符为char。字符变量类型定义的格式和书写规则都与整型变量相同。

例如:

char a,b;

3.5.4 字符数据在内存中的存储形式及使用方法(理解)

每个字符变量被分配一个字节的内存空间,因此只能存放一个字符。字符值是以ASCLL码的形式存放在变量的内存单元之中的。

如x的十进制ASCLL码是120,y的十进制ASCLL码是121。

对字符变量a,b赋予‘x’和'y'值:

a = 'x';b = 'y';

实际上是在a,b两个单元内存放120和121的二进制代码:

a:

01111000

 b:

01111001

 所以也可以把它们看成整型量。C语言允许对整型变量赋以字符值,也允许对字符变量赋以整型值。在输出时,允许把字符变量按整型量输出,也允许把整型量按字符量输出。

整型量为二字节量,字符量为单字节量,当整型量按字符型量处理时,只有低八位字节参与处理。

例3.9向字符变量赋以整数。

#include <stdio.h>

int main()
{
   char a,b;
   a = 120;b = 121;
   printf("a = %c,b = %c\n",a,b);
    printf("a = %d,b = %d\n",a,b);
   return 0;
}

 运行结果:

 

 本程序中定义a,b为字符型,但在赋值语句中赋以整型值。从结果看,a,b值的输出形式取决于printf函数格式串中的格式符,当格式符为“c”时,对应输出的变量值为字符,当格式符为“d”时,对应输出的变量值为整数。

#include <stdio.h>

int main()
{
   char a,b;
   a = 'a';
	b = 'b';
	a = a-32;
	b = b-32;
   printf("%c,%c\n%d,%d",a,b,a,b);
   return 0;
}

 运行结果:

 

 本例中,a,b被说明为字符变量并赋予字符值,C语言允许字符变量参与数值运算,即用字符的ASCLL码相差32,因此运算后把小写字母换成大写字母。然后分别以整数和字符型输出。

3.5.5 字符串常量(掌握)

字符串常量是由一对双引号括起来字符序列。例如:“CHINA”,“C program”,"$12.5"等都是合法的字符串常量。

字符串常量和字符常量是不同的量。它们之间主要有以下区别:

1)字符常量由单引号括起来,字符串常量由双引号括起来。

2)字符常量只能是单个字符,字符串常量则可以含一个或多个字符。

3)可以把一个字符常量赋予一个字符变量,但不能把一个字符串常量赋予一个字符变量。在C语言中没有相应的字符串变量。这是与BASIC语言不同的。但是可以用一个字符数组来存放一个字符串常量。在数组一章予以介绍(ok等我学到数组哈)

4)字符常量占一个字节的内存空间。字符串常量占的内存字节数等于字符串中字节数加1。增加的一个字节中存放字符“\0”(ASCLL码为0)。这是字符串结束的标志。

字符常量‘a’和字符串常量“a”虽然都只有一个字符,但在内存中的情况是不同的。

‘a’在内存中占一个字节,可表示为:

a

“a”在内存中占两个字节,可表示为:

a\0

 3.6变量赋初值(理解)

在程序中常常需要对变量赋初值,以便使用变量。语言程序中可有多种方法为变量提供初值。本小节先介绍在作变量定义的同时给变量赋初值的方法。这种方法称为初始化。在变量定义中赋初值的一般形式为:类型说明符 变量1=值1,变量2=值2,。。。;

例如:

int a=3;

int b,c=5;

float x=3.2,y=3f,z=0.75;

char ch1='g',ch2='p';

应注意,在定义中不允许连续赋值,如a=b=c=5是不合法的。

#include <stdio.h>

int main()
{
   int a = 3,b,c = 5;
	b = a+c;
	
   printf("a=%d,b=%d,c=%d\n",a,b,c);
   
   return 0;
}

 运行结果:

 3.7 各类数值型数据之间的混合运算(理解)

变量的数据类型是可以转换的。转换的方法有两种,一种是自动转换,一种是强制转换。自动转换发生在不同数据类型的量混合运算时,由编译系统自动完成。自动转换遵循以下规则:

1)若参与运算量的类型不同,则先转换成同一类型,然后进行运算。

2)转换按数据长度增加的方向进行,以保证精度不降低。如int型和long型运算时,先把int量转成long型后再进行运算。

3)所有的浮点运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要先转换成double型,再作运算。

4)char型和short型参与运算时,必须先转换成int型。

5)在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边量的类型将转换为左边量的类型。如果右边量的数据类型长度左边长时,将丢失一部分数据,这样会降低精度,丢失的部分按四舍五入向前舍入。

下图表示了类型自动转换的规则。

 

例3.12 求圆面积

#include <stdio.h>

int main()
{
	float PI = 3.14159;
	
   int s,r = 5;
	s = r*r*PI;
	
   printf("s=%d\n",s);
   
   return 0;
}

 运行结果:

 本例程序中,PI为实型;s,r为整型。在执行s=r*r*PI语句时,r和PI都转换成double型计算,结果也为double型。但由于s为整型,故赋值结果仍为整型,舍去了小数部分。

强制类型转换

强制类型转换是通过类型转换运算来实现的。

其一般形式为:

(类型说明符)(表达式)

其功能是把表达式的运算结果强制转换成类型说明符所表示的类型。

例如:

(float)a 把a转换为实型

(int) (x+y) 把x+y的结果转换为整型

在使用强制转换时应注意以下问题:

1)类型说明符和表达式都必须加括号(单个变量可以不加括号),如把(int)(x+y)写成(int)x+y则成了把x转换成int型之后再与y相加了。

2)无论是强制转换或是自动转换,都只是为了本次运算的需要而对变量的数据长度进行的临时性转换,而不改变数据说明时对该变量定义的类型。

#include <stdio.h>

int main()
{
	float f = 5.75;
	
   printf("(int)f=%d,f=%f\n",(int)f,f);
   
   return 0;
}

 运行结果:

 本例表明,f虽然强制转为int型,但只在运算中起作用,是临时的,而f本身的类型并不改变。因此,(int)f的值为5(删去了小数)而f的值仍为5.75

 3.8算术运算符和算术表达式(掌握)

C语言中运算符和表达式数量之多,在高级语言中是少见的。正是丰富的运算符和表达式使C语言功能十分完善。这也是C语言的主要特点之一。

C语言的运算符不仅具有不同的优先级,而且还有一个特点,就是它的结合性。在表达式中,各运算量参与运算的先后顺序不仅要遵守运算符优先级别的规定,还要受运算符结合性的制约,以便确定是自左向右进行运算还是自右向左进行运算。这种结合性是其他高级语言的运算符所没有的,因此也增加了C语言的复杂性。

 3.8.1 C运算符简介(考点)

其实我一直不太懂这个考点是什么意思,可能就是c语言考试的考点吧,对我来说,了解掌握了就行

运算符优先级是C语言掌握的重难点,也是必考点。

C语言的运算符可分为以下几类:

1.算术运算符:用于各类数值运算。包括加(+)、减(-)、乘(*)、除(/)、求余(或称模运算,%)、自增(++)、自减(--)共七种。

2.关系运算符:用于比较运算。包括大于(>)、小于(<)、等于(==)、大于等于(>=)、小于等于(<=)和不等于(!=)六种。

3.逻辑运算符:用于逻辑运算。包括与(&&)、或(||)、非(!)三种。

4.位操作运算符:参与运算的量,按二进制位进行运算。包括位与(&)、位或(|)、位非(~)、位异或(^)、左移(<<)、右移(>>)六种。

5.赋值运算符:用于赋值运算,分为简单赋值(=)、复合算术赋值(+=,-=,*=,/=,%=)和复合位运算赋值(&=,|=,^=,>>=,<<=)三类共十一种。

6.条件运算符:这是一个三目运算符,用于条件求值(?:)。

7.逗号运算符:用于把若干表达式组合成一个表达式(,)。

8.指针运算符:用于取内容(*)和取地址(&)二种运算。

9.求字节数运算符:用于计算数据类型所占的字节数(sizeof)。

10.特殊运算符:有括号(),下标[],成员(->, .)等几种。

3.8.2 算术运算符和算术表达式

1.基本的算术运算符(掌握)

(1)加法运算符“+”:加法运算符为双目运算符,即应有两个量参与加法运算。如a+b,4+8等。具有右结合性。

(2)减法运算符“-”:减法运算符为双目运算符。但“-”也可作负值运算符,此时为单目运算,如-x,-5等具有左结合性。

(3)乘法运算符“*”:双目运算,具有左结合性。

(4)除法运算符“/”:双目运算具有左结合性。参与运算量均为整型时,结果也为整型,舍去小数。如果运算量中有一个是实型,则结果为双精度实型。

(5)求余运算符(模运算符)“%”:双目运算,具有左结合性。要求参与运算的量均为整型。求余运算的结果等于两数相除后的余数。

#include <stdio.h>

int main()
{
	printf("\n\n%d,%d\n",20/7,-20/7);
	
   printf("%f,%f\n",20.0/7,-20.0/7);
   
   return 0;
}

 运行结果:

 本例中,20/7,-20/7的结果均为整型,小数全部舍去。而20.0/7和-20.0/7由于有实数参与运算,因此结果也为实型。

(1)重点掌握除法“/”,当两侧都为整型时,结果也为整型。如10/3=3而不是3.3...这是新手常犯错误。

(2)求余运算符“%”;两侧必须为整型,其他类型错误。为常考点。

#include <stdio.h>

int main()
{
   printf("%d\n",100%3);
   
   return 0;
}

 运行结果:

出结果的时候我有点蒙,但一想到是“%”取余,就明白了。 

本例输出100除以3所得的余数为1。、

2.算术表达式和运算符的优先级和结合性(理解)

表达式是由常量、变量、函数和运算符组合起来的式子。一个表达式有一个值及其类型,它们等于计算表达式所得结果的值和类型。表达式求值按运算符的优先级和结合性规定的顺序进行。单个的常量、变量、函数可以看作是表达式的特例。

算术表达式是由算术运算符和括号连接起来的式子。

(1)算术表达式:用算术运算符和括号将运算对象(也称操作数)连接起来的、符合C语法规则的式子。

以下是算术表达式的例子:

a+b

(a*2)/c

(x+r)*8-(a+b)/7

++I

sin(x)+sin(y)

(++i)-(j++)+(k--)

(2)运算符的优先级(考点):C语言中,运算符的运算优先级共分为15级。1级最高,15级最低。在表达式中,优先级较高的先于优先级较低的进行运算。而在一个运算量两侧的运算符优先级相同时,则按运算符的结合性所规定的结合方向处理。

(3)运算符的结合性:C语言中各运算符的结合性分为两种,即左结合性(自左向右)和右结合性(自右向左)。例如算术运算符的结合性是自左至右,即先左后右。如有表达式x-y+z则y应先与“-”号结合,执行x-y运算,然后再执行+z的运算。这种自左至右的结合方向就称为“左结合性”。而自右至左的结合方向就称为“右结合性”。最典型的右结合性运算符是赋值运算符。如x=y=z,由于“=”的右结合性,应先执行y=z再执行x=(y=z)运算。C语言运算符中有不少为右结合性,应注意区别,以避免理解错误。

3.强制类型转换运算符(理解)

其一般形式为:

(类型说明符)(表达式)

其功能是把表达式的运算结果强制转换成类型说明符所表示的类型。

例如:

(float)a 把a装换为实型

(int)(x+y) 把x+y的结果转换为整型

4.自增、自减运算符(重点考点)

自增1,自减1运算符:自增1运算符记为“++”,其功能是使变量的值自增1。

自减1运算符记为“--”,其功能是使变量值自减1。

自增1,自减1运算符均为单目运算,都具有右结合性。可有以下几种形式:

++i         i自增1后再参与其它运算。

--i          i自减1后再参与其他运算。

i++        i参与运算后,i的值再自增1。

i--        i参与运算后,i的值再自减1。

在理解和使用上容易出错的是i++和i--。特别是当它们出在较复杂的表达式或语句中时,常常难于弄清,因此应仔细分析。

#include <stdio.h>

int main()
{
	int i = 8;
	
   	printf("%d\n",++i);
	printf("%d\n",--i);
	printf("%d\n",i++);
	printf("%d\n",i--);
	printf("%d\n",-i++);
	printf("%d\n",-i--);
   
   return 0;
}

 运行结果:

 

 i的初值为8,第2行i加1后输出故为9;第三行减1后输出故为8;第四行输出i为8之后再加1(为9);第5行输出i为9之后再减1(为8);第6行输出-8之后再加1(为9),第7行输出-9之后再减1(为8)。

例3.17

#include <stdio.h>

int main()
{
	int i = 5,j = 5,p,q;
	p=(i++)+(i++)+(i++);
	q=(++j)+(++j)+(++j);
	printf("%d,%d,%d,%d",p,q,i,j);
   
   return 0;
}

 运行结果:

 提示:此程序由于涉及到连续++,其结果在不同的编译器有可能不同,目前已有[18,21,8,8][18,22,8,8][15,24,8,8]三种结果。在实际使用过程中,要避免此用法

很神奇,我在手机编译软件上的结果是[18,21,8,8]。先学到这一步吧,至于编译器怎么做的,让我以后再去探究。

这个程序中,对p=(i++)+(i++)+(i++)应理解为三个i相加,故p值为15。然后i再自增1三次相当于加3故i的最后值为8。而对于q的值则不然,q=(++j)+(++j)+(++j)应理解为j先自增1,再参与运算,由于j自增1三次后值为8,三个8相加的和为24,j的最后值仍为8;ps(手机软件里的也有错误的,想要学好,真的要自己用心)

3.9 赋值运算符和赋值表达式(理解)

1.赋值运算符(理解)

简单赋值运算符和表达式:简单赋值运算符记为“=”。由“=”连接的式子称为赋值表达式。其一般形式为:

变量=表达式

例如:

x=a+b

w=sin(a)+sin(b)

y=i+++--j        // 这个我的理解是y=(i++)+(--j)

赋值表达式的功能是计算表达式的值再赋予左边的变量。赋值运算符具有右结合性。因此

a=b=c=5

可理解为

a=(b=(c=5))

在其它高级语言中,赋值构成了一个语句,称为赋值语句。而在C中,把“=”定义为运算符,从而组成赋值表达式。凡是表达式可以出现的地方均可出现赋值表达式。

例如,式子:

x=(a=5)+(b=8)

是合法的。它的意义是把5赋予a,8赋予b,再把a,b相加,和赋予x,故x应等于13。

在C语言中也可以组成赋值语句,按照C语言规定,任何表达式在其末尾加上分号就构成为语句。因此如

x=8;

a=b=c=5;

都是赋值语句,在前面各例中我们已大量使用过了。

// 前面3.6章变量赋初值说定义中不允许连续赋值,这里又可以。我本以为是它写错了,正在骂它,后来仔细一看,定义中不允许连续赋值,原来我才是小丑。我试过了,定义的时候会报错,调用的时候赋值不会报错,重点在“定义”两个字!

2.类型转换(理解)

如果赋值运算符两边的数据类型不相同,系统将自动进行类型转换,即把赋值号右边的类型换成左边的类型。具体规定如下:

1)实型赋予整型,舍去小数部分。前面的例子已经说明了这种情况。

2)整型赋予实型,数值不变,但将以浮点形式存放,即增加小数部分(小数部分的值为0)。

3)字符型赋予整型,由于字符型为一个字节,而整型为两个字节,故将字符的ASCLL码值放到整型量的低八位中,高八位为0。整型赋予字符型,只把低八位赋予字符量。

例3.18

#include <stdio.h>

int main()
{
	int a,b = 322;
	float x,y=8.88;
	char c1='k',c2;
	a=y;
	x=b;
	a=c1;
	c2=b;
	printf("%d,%f,%d,%c",a,x,a,c2);
   return 0;
}

 本例表明了上述赋值运算中类型转换的规则。a为整型,赋予实型量y值8.88后只取整数8。x为实型,赋予整型量b值322,后增加了小数部分。字符型量c1赋予a变为整型,整型量b赋予c2后取其低八位成为字符型(b的低八位为01000010,即十进制66,按ASCLL码对应于字符B)。

3复合的赋值运算符(理解)

 在赋值符“=”之前加上其它二目运算符可构成复合赋值符。如+=,-=,*=,/=,%=,<<=,>>=,&=,^=,|=。

构成复合赋值表达式的一般形式为:

变量 双目运算符=表达式

它等效于

变量=变量 运算符 表达式

例如:

a+=5 等价于a=a+5

x*=y+7 等价于x=x*(y+7)

r%=p 等价于r=r%p

复合赋值符这种写法,对初学者可能不习惯,但十分有利于编译处理,能提高编译效率并产生质量较高的目标代码。

3.10 逗号运算符和逗号表达式(理解)

在c语言中逗号“,”也是一种运算符,称为逗号运算符。其功能是把两个表达式连接起来组成一个表达式,称为逗号表达式。

其一般形式为:

表达式1,表达式2

其求值过程是分别求两个表达式的值,并以表达式2的值作为整个逗号表达式的值。

例3.19

#include <stdio.h>

int main()
{
	int a=2,b=4,c=6,x,y;
	// 如果不加外层大括号,y=(x=a+b),(b+c);
	// 那么因为'='的优先级大于',',那么就会取第一个值
	y=((x=a+b),(b+c));
	printf("y=%d,x=%d",y,x);
   return 0;
}

 运行结果:

 本例中,y等于整个逗号表达式的值,也就是表达式2的值,x是第一个表达式的值。对于逗号表达式还要说明两点:

1)逗号表达式一般形式中的表达式1和表达式2也可以又是逗号表达式。

例如:

表达式1,(表达式2,表达式3)

形成了嵌套情形。因此可以把逗号表达式扩展为以下形式:

表达式1,表达式2,...表达式n

整个逗号表达式的值等于表达式n的值。

2)程序中使用逗号表达式,通常是要分别求逗号表达式内各表达式的值,并不一定要求整个逗号表达式的值。

并不是在所有出现逗号的地方都组成逗号表达式,如在变量说明中,函数参数表中逗号只是用作各变量之间的间隔符。

3.11小结

3.11.1 C的数据类型

基本类型,构造类型,指针类型,空类型

3.11.2 基本类型的分类及特点

3.11.3 常量后缀

L或l        长整型

U或u        无符号数

F或f        浮点数

3.11.4 常量类型

整数,长整数,无符号数,浮点数,字符,字符串,符号常数,转义字符。

3.11.5 数据类型转换

(1)自动转换:在不同类型数据的混合运算中,由系统自动实现转换,由少字节类型向多字节类型转换。不同类型的量相互赋值时也由系统自动进行转换,把赋值号右边的类型转换为左边的类型。

(2)强制转换:由强制转换运算符完成转换。

3.11.6 运算符优先级和结合性

一般而言,单目运算符优先级较高,赋值运算符优先级低。算术运算符优先级较高,关系和逻辑运算符优先级较低。多数运算符具有左结合性,单目运算符、三目运算符、赋值运算符具有右结合性。

3.11.7 表达式

表达式是由运算符连接常量、变量、函数所组成的式子。每个表达式都有一个值和类型。表达式求值按运算符的优先级和结合性所规定的顺序进行。

码字不易,看到这里的小伙伴,如果您觉得对您有帮助,请不要忘记点赞收藏加关注!您的支持和鼓励是我创作的最大动力。同时也欢迎各位小伙伴在评论区留言。让我们共同交流,学习进步。

  • 12
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

颈部者

感谢您对我的支持!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值