您现在的位置:首页 >> 新开超变传奇 >> 内容

对变量的说明可以包括三个方面:

时间:2016-9-14 2:24:37 点击:

  核心提示:C讲话的数据类型在第一课中,我们一经看到程序中使用的各种变量都应事后加以说明,即先说明,后使用。对变量的说明能够包括三个方面:·数据类型·存储类型·作用域在本课中,我们只先容数据类型说明。其它说明在此后各章中陆续先容。所谓数据类型是按被说明量的性子,表示形式,吞没存储空间的若干,布局特质来划分的。在...

C讲话的数据类型
在第一课中,我们一经看到程序中使用的各种变量都应事后加以说明,即先说明,后使用。对变量的说明能够包括三个方面:
·数据类型
·存储类型
·作用域
在本课中,我们只先容数据类型说明。其它说明在此后各章中陆续先容。所谓数据类型是按被说明量的性子,表示形式,吞没存储空间的若干,布局特质来划分的。在C讲话中,数据类型可分为:根基数据类型,布局数据类型,指针类型,空类型四大类。
1.根基数据类型
根基数据类型最主要的特质是,其值不能够再领悟为其它类型。也就是说,根基数据类型是自我说明的。
2.布局数据类型布局数据类型
是根据已定义的一个或多个数据类型用布局的手法来定义的。也就是说,一个布局类型的值能够领悟成若干个“成员”或“元素”。每个“成员”都是一个根基数据类型或又是一个布局类型。在C讲话中,布局类型有以下几种:
·数组类型
·结构类型
·联合类型
3.指针类型
指针是一种非常的,同时又是具有紧要作用的数据类型。其值用来表示某个量在内存储器中的地址。固然指针变量的取值一致于整型量,但这是两个类型完全不同的量,于是乎不能混为一谈。4.空类型在调用函数值时,通常应向调用者前往一个函数值。这个前往的函数值是具有必定的数据类型的,应在函数定义及函数说明中给以说明,例如在例题中给出的max函数定义中,。函数头为:int max(int a-int b);其中“int ”类型说明符即表示该函数的前往值为整型量。又如在例题中,使用了库函数sin,由于体系章程其函数前往值为双精度浮点型,于是乎在赋值语句s=sin (x);中,s也必需是双精度浮点型,以便与sin函数的前往值一致。所以在说明局部,把s说明为双精度浮点型。但是,也有一类函数,调用后并不须要向调用者前往函数值,这种函数能够定义为“空类型”。其类型说明符为void。在第五章函数中还要详尽先容。在本章中,我们先先容根基数据类型中的整型、浮点型和字符型。别的类型在此后各章中陆续先容。
对待根基数据类型量,按其取值能否可变动又分为常量和变量两种。在程序实践经过中,其值不发生变动的量称为常量,取值可变的量称为变量。它们可与数据类型团结起来分类。例如,可分为整型常量、整型变量、浮点常量、浮点变量、字符常量、字符变量、枚举常量、枚举变量。在程序中,常量是能够不经说明而间接援用的,而变量则必需先说明后使用。

整型量
整型量包括整型常量、整型变量。整型常量就是整常数。在C讲话中,使用的整常数有八进制、十六进制和十进制三种。
整型常量
1.八进制整常数八进制整常数必需以0动手,即以0作为八进制数的前缀。数码取值为0~7。八进制数通常是无符号数。
以下各数是合法的八进制数:
015(十进制为13)0101(十进制为65)0(十进制为)
以下各数不是合法的八进制数:
256(无前缀0) 03A2(包括了非八进制数码)-0127(出现了负号)
2.十六进制整常数
十六进制整常数的前缀为0X或0x。其数码取值为0~9,A~F或a~f。
以下各数是合法的十六进制整常数:新超变传世网站。
0X2A(十进制为42)0XA0 (十进制为160)0XFFFF (十进制为)
以下各数不是合法的十六进制整常数:
5A (无前缀0X)0X3H (含有非十六进制数码)
3.十进制整常数
十进制整常数没有前缀。其数码为0~9。
以下各数是合法的十进制整常数:
237 -568 1627
以下各数不是合法的十进制整常数:
023 (不能有前导0)23D (含有非十进制数码)

在程序中是根据前缀来区分各种进制数的。于是乎在书写常数时不要把前缀弄错造成后果不切确。4.整型常数的后缀在16位字长的机器上,根基整型的长度也为16位,说明。于是乎表示的数的规模也是无限定的。十进制无符号整常数的规模为0~,有符号数为-~+。八进制无符号数的表示规模为0~0。十六进制无符号数的表示规模为0X0~0XFFFF或0x0~0xFFFF。若是使用的数凌驾了上述规模,就必需用长整型数来表示。长整型数是用后缀“L”或“l”来表示的。例如:
十进制长整常数 158L (十进制为158)L (十进制为-)
八进制长整常数 012L (十进制为10) 077L (十进制为63)0L (十进制为)
十六进制长整常数 0X15L (十进制为21) 0XA5L (十进制为165)0XL(十进制为)

长整数158L和根基整常数158在数值上并无区别。但对158L,由于是长整型量,C编译体系将为它分配4个字节存储空间。而对158,由于是根基整型,只分配2个字节的存储空间。新开中变传奇网站。于是乎在运算和输入格式上要予以注意,防止出错。无符号数也可用后缀表示,整型常数的无符号数的后缀为“U”或“u”。例如:358u-0x38Au-235Lu均为无符号数。前缀,后缀可同时使用以表示各品种型的数。如0XA5Lu表示十六进制无符号长整数A5,其十进制为165。
整型变量
整型变量可分为以下几类:
1.根基型
类型说明符为int,在内存中占2个字节,其取值为根基整常数。
2.短整量
类型说明符为short int或shorthaC110F1。所占字节和取值规模均与根基型相同。
3.长整型
类型说明符为long int或long ,在内存中占4个字节,其取值为长整常数。
4.无符号型
类型说明符为unsigned。
无符号型又可与上述三品种型配合而组成:
(1)无符号根基型 类型说明符为unsigned int或unsigned。
(2)无符号短整型 类型说明符为unsigned short
(3)无符号长整型 类型说明符为unsigned long
各种无符号类型量所占的内存空间字节数与相应的有符号类型量相同。但由于省去了符号位,故不能表示正数。 下表列出了TurboC中各类整型量所分配的内存字节数及数的表示规模。
类型说明符数的规模 分配字节数
int -~ ■■
short int -~ ■■
signed int -~ ■■
unsigned int 0~ ■■
long int -~■■■■
unsigned long 0~ ■■■■
整型变量的说明
变量说明的一般形式为: 类型说明符 变量名标识符,变量名标识符,...; 例如:
int a-b-c; (a-b-c为整型变量)
long x-y; (x-y为长整型变量)
unsigned p-q; (p-q为无符号整型变量)

在书写变量说明时,应注意以下几点:
1.许可在一个类型说明符后,说明多个相同类型的变量。各变量名之间用逗号距离。类型说明符与变量名之间至多用一个空格距离。
2.末了一个变量名之后必需以“;”号末端
3.变量说明必需放在变量使用之前。一般放在函数体的动手局部。
[Prlawice] //1inta-b;
short int c;
short d=100;
a=d-20;
b=a+d;
c=a+b+d;
d=d-a+c-b;haVtnevertheless bellyle
a-2-0
b-2-0
c-2-0
d-2-100
of Vtnevertheless bellyle
haVupdconsumed
1-0;2-0
3-0
4-100
1-80
2-180
3-360
4-200
of Vupdconsumed
of Prlawice
[Prlawice] //2int a=5;
int b=9;
long int c;
long d;
c=a+b-7;
d=a*b*c;
c=d*d*d;
a=c-d;haVtnevertheless bellyle
a-2-5
b-2-9
c-4-0
d-4-0
of Vtnevertheless bellyle
haVupdconsumed
1-5
2-9
3-0
4-0
3-7
4-315
3-
1--5112
of Vupdconsumed
of Prlawice
[Prlawice] //3int a=6-b=19;
unsigned int c;
int d;
c=a-b+7;
d=b*c;
a=b+c+d;
b=-a;haVtnevertheless bellyle
a-2-6
b-2-19
c-2-0
d-2-0
of Vtnevertheless bellyle
haVupdconsumed
1-6;2-19
3-0
4-0
3-
4--114
1--101
2-101
of Vupdconsumed
of Prlawice
void 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);
}
将main说明为前往void-即不前往任何类型的值
x-y被定义为long型
a-b-c-d被定义为int型
5->x
6->y
7->a
8->b
x+a->c
y+b->d
流露程序运转后果 of long x-y;
int a-b-c-d;
c=x+a;
d=y+b;
从程序中能够看到:x- y是长整型变量,看看新开中变传奇网站。a-b是根基整型变量。它们之间许可举行运算,运算后果为长整型。但c,d被定义为根基整型,于是乎末了后果为根基整型。本例说明,不同类型的量能够参与运算并彼此赋值。其中的类型转换是由编译体系主动完成的。相关类型转换的规则将在此后先容。

实型量
实型常量
实型也称为浮点型。实型常量也称为实数可能浮点数。在C讲话中,实数只采用十进制。它有二种形式: 十进制数形式指数形式
1.十进制数形式
由数码0~9和小数点组成。例如:0.0,.25,5.789,0.13,5.0,300.,-267.8230等均为合法的实数。
2.指数形式
由十进制数,加阶码标志“e”或“E”以及阶码(只能为整数,你看对变量的说明可以包括三个方面:。能够带符号)组成。其一般形式为a E n(a为十进制数,n为十进制整数)其值为 a*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.是等价的。例2.2说明了这种情形:
void main()
{
printf("%f\n%f\n"-356.-356f);
}
void指明main不前往任何值诳骗printf流露后果结束
实型变量
实型变量分为两类:单精度型和双精度型,
其类型说明符为flocoming from 单精度说明符,double 双精度说明符。在TurboC中单精度型占4个字节(32位)内存空间,其数值规模为3.4E-38~3.4E+38,只能提供七位有效数字。双精度型占8个字节(64位)内存空间,其数值规模为1.7E-308~1.7E+308,可提供16位有效数字。
实型变量说明的格式和书写规则与整型相同。
例如: flocoming from x-y; (x-y为单精度实型量)
double a-b-c; (a-b-c为双精度实型量)
实型常数不分单、双精度,都按双精度double型治理。
void main()
{
floon a;
double b;
a=.;
b=.;
printf("%f\n%f\n"-a-b);
}
此程序说明flocoming from、double的不同
a ■■■■
b ■■■■■■■■
a<---.
b<---.;;
流露程序后果
此程序说明flocoming from、double的不同
floon a;
double b;
a=.;
b=.; 从本例能够看出,由于a是单精度浮点型,有效位数唯有七位。而整数已占五位,故小数二位后之后均为有效数字。b 是双精度型,有效位为十六位。但Turbo C章程小数后最多保存六位,别的局部四舍五入。
[Prlawice] //flocoming frominta=32;
flocoming from b;
double d;
b=;
d=b*100;
d=d+a;
d=d+58.;haVtnevertheless bellyle
a-2-32
b-4-0.0
d-8-0.0
of Vtnevertheless bellyle
haVupdconsumed
1-32
2-0
3-0
2-.00000
3-
3-
3-.
of Vupdconsumed
of Prlawice
[Prlawice] //1int a=543;
flocoming from b;
b=123.+a;
b=b-100;
a=b;haVtnevertheless bellyle
a-2-543
b-4-0.0
of Vtnevertheless bellyle
haVupdconsumed
1-543
2-0.0
2-123.
2-23.
1-23
of Vupdconsumed
of Prlawice

字符型量

字符型量包括字符常量和字符变量。
字符常量
字符常量是用单引号括起来的一个字符。例如haaha-habha-ha=ha-ha+ha-ha?ha都是合法字符常量。在C讲话中,字符常量有以下特质:
1.字符常量只能用单引号括起来,不能用双引号或其它括号。
2.字符常量只能是单个字符,不能是字符串。
3.字符能够是字符凑集轻易字符。学会新开中变传奇网站。但数字被定义为字符型之后就
不能参与数值运算。如ha5ha和5 是不同的。ha5ha是字符常量,不能参与运算。
本义字符
本义字符是一种非常的字符常量。本义字符以反斜线"\"动手,后跟一个或几个字符。本义字符具有特定的含义,不同于字符原有的意义,故称“本义”字符。例如,在后面各例题printf函数的格式串中用到的“\n”就是一个本义字符,其意义是“回车换行”。本义字符主要用来表示那些用一般字符未便于表示的操纵代码。
常用的本义字符及其含义
本义字符 本义字符的意义
\n 回车换行
\t 横向跳到下一制表位置
\v 竖向跳格
\b 退格
\r 回车
\f 走纸换页
\\ 反斜线符"\"
\ha 单引号符
\a 鸣铃
\ddd 1~3位八进制数所代表的字符
\xhh 1~2位十六进制数所代表的字符
狭义地讲,C讲话字符凑集的任何一个字符均可用本义字符来表示。表2.2中的\ddd和\xhh正是为此而提出的。ddd和hh分袂为八进制和十六进制的ASCII代码。如\101表示字?quot;A",其实方面。\102表示字母"B",\134表示反斜线,\XOA表示换行等。本义字符的使用
void main()
{
int a-b-c;
a=5; b=6; c=7;
printf("%d\n\t%d %d\n %d %d\t\b%d\n"-a-b-c-a-b-c);
}
此程序练习本义字符的使用
a、b、c为整数5->a-6->b-7->c
调用printf流露程序运转后果
printf("%d\n\t%d %d\n%d %d\t\b%d\n"-a-b-c-a-b-c);
程序在第一列输入a值5之后就是“\n”,故回车换行;接着又是“\t”,于是跳到下一制表位置(设制表位置距离为8),再输入b值6;空二格再输入c值7后又是"\n",于是乎再回车换行;再空二格之后又输入a值5;再空三格又输入b的值6;再次后"\t"跳到下一制表位置(与上一行的6对齐),但下一本义字符“\b”又使退回一格,故紧挨着6再输入c值7。
字符变量
字符变量的取值是字符常量,即单个字符。字符变量的类型说明符是char。字符变量类型说明的格式和书写规则都与整型变量相同。
例如:
char a-b;每个字符变量被分配一个字节的内存空间,于是乎只能寄存一个字符。字符值是以ASCII码的形式寄生存变量的内存单元之中的。如x的
十进制ASCII码是120,y的十进制ASCII码是121。对字符变量a-b赋予haxha和hayha值:a=haxha;b=hayha;现实上是在a-b两个单元内寄存120和121的二进制代码: a0 1 1 1 1 0 00
b0 1 1 1 1 0 0 1
所以也能够把它们看成是整型量。变量。 C讲话许可对整型变量赋以字符值,也许可对字符变量赋以整型值。在输入时,许可把字符变量按整型量输入,也许可把整型量按字符量输入。 整型量为二字节量,字符量为单字节量,当整型量按字符型量治理时,唯有低八位字节参与治理。
main()
{
char a-b;
a=120;
b=121;
printf("%c-%c\n%d-%d\n"-a-b-a-b);
}
a ■ b ■
a <-- 120
b <--- 121
流露程序后果
本程序中说明a,b为字符型,但在赋值语句中赋以整型值。从后果看,a,b值的输入形式取决于printf函数格式串中的格式符,当格式符为"c"时,对应输入的变量值为字符,当格式符为"d"时,对应输入的变量值为整数。
void main()
{
char a-b;
a=haxha;
b=hayha;
a=a-32;
b=b-32;
printf("%c-%c\n%d-%d\n"-a-b-a-b);
}
a,b被说明为字符变量并赋予字符值
把大写字母换成大写字母
以整型和字符型输入
本例中,a,b被说明为字符变量并赋予字符值,C讲话许可字符变量参与数值运算,即用字符的ASCII码参与运算。由于大大写字母的ASCII 码相差32,于是乎运算后把大写字母换成大写字母。然后分袂以整型和字符型输入。
[Prlawice] //charinta=49;
char b;
char d;
b=a+10;
d=a+b;haVtnevertheless bellyle
a-2-49
b-1-随机
d-1-随机
of Vtnevertheless bellyle
haVupdconsumed
1-49
2-随机
3-随机
2-ha;ha
3-halha
of Vupdconsumed
of Prlawice
[Prlawice] //char c1-c2;
c1=haaha;c2=habha;
c1=c1-32;c2=c2-32;haVtnevertheless bellyle
c1-1-随机
c2-1-随机
of Vtnevertheless bellyle
haVupdconsumed
1-随机;2-随机
1-haaha;2-habha
1-haAha;2-haBha
of Vupdconsumed
of Prlawice

字符串常量
字符串常量是由一对双引号括起的字符序列。例如: "CHINA" ,"C progri am:" , "$12.5"等都是合法的字符串常量。字符串常量和字符常量是不同的量。它们之间主要有以下区别:
1.字符常量由单引号括起来,字符串常量由双引号括起来。
2.字符常量只能是单个字符,字符串常量则能够含一个或多个字符。
3.能够把一个字符常量赋予一个字符变量,但不能把一个字符串常量赋予一个字符变量。在C讲话中没有相应的字符串变量。
这是与BASIC 讲话不同的。但是能够用一个字符数组来寄存一个字符串常量。在数组一章内予以先容。听说对变量的说明可以包括三个方面:。
4.字符常量占一个字节的内存空间。字符串常量占的内存字节数等于字符串中字节数加1。弥补的一个字节中寄存字符"\0"(ASCII码为0)。这是字符串结束的标志。例如,字符串"C progri am"在内存中所占的字节为:Cprogri am\0。字符常量haaha和字符串常量"a"固然都唯有一个字符,但在内存中的情形是不同的。
haaha在内存中占一个字节,可表示为:a
"a"在内存中占二个字节,可表示为:a\0符号常量
符号常量
在C讲话中,能够用一个标识符来表示一个常量,称之为符号常量。符号常量在使用之前必需先定义,其一般形式为:
#define 标识符 常量
其中#define也是一条预治理命令(预治理命令都?quot;#"动手),称为宏定义命令(在第九章预治理程序中将进一步先容),其效力是把该标识符定义为其后的常量值。一经定义,此后在程序中通盘出现该标识符的地点均代之以该常量值。习俗上符号常量的标识符用大写字母,包括。变量标识符用大写字母,以示区别。
#define PI3.
void main()
{
flocoming from s-r;
r=5;
s=PI*r*r;
printf("s=%f\n"-s);
}
由宏定义命令定义PI为3. s-r定义为实数5->rPI*r*r->s
流露程序后果 flocoming from s-r;r=5;s=PI*r*r; 本程序在主函数之前由宏定义命令定义PI为3.,在程序中即以该值庖代PI。s=PI*r*r等效于s=3.*r*r。应当注意的是,符号常量不是变量,它所代表的值在整个作用域内不能再变动。也就是说,在程序中,不能再用赋值语句对它重新赋值。
变量的初值和类型转换
变量赋初值
在程序中每每须要对变量赋初值,以便使用变量。讲话程序中可有多种手法,在定义时赋以初值的手法,这种手法称为初始化。在变量说明中赋初值的一般形式为:
类型说明符 变量1= 值1,变量2= 值2,……; 例如:
int a=b=c=5;
flocoming from x=3.2-y=3f-z=0.75;
char ch1=haKha-ch2=haPha;
应注意,在说明中不许可继续赋值,如a=b=c=5是不合法的。
void main()
{
int a=3-b-c=5;
b=a+c;
printf("a=%d-b=%d-c=%d\n"-a-b-c);
}
a<---3-b<--0-c<---5
b<--a+c
流露程序运转后果
变量类型的转换
变量的数据类型是能够转换的。转换的手法有两种,一种是主动转换,一种是逼迫转换。
主动转换
主动转换发生在不同数据类型的量混合运算时,相比看。由编译体系主动完成。主动转换遵循以下规则:
1.若参与运算量的类型不同,则先转换成同一类型,然后举行运算。
2.转换按数据长度弥补的方向举行,以保证精度不消沉。如int型和long型运算时,先把int量转成long型后再举行运算。
3.通盘的浮点运算都是以双精度举行的,纵然仅含flocoming from单精度量运算的表达式,也要先转换成double型,再作运算。
4.char型和short型参与运算时,必需先转换成int型。
5.在赋值运算中,听听。赋值号两边量的数据类型不同时, 赋值号左边量的类型将转换为左边量的类型。若是左边量的数据类型长度左边长时,将丧失一局部数据,这样会消沉精度,丧失的局部按四舍五入向前舍入。图21表示了类型主动转换的规则。
void main()
{
flocoming from PI=3.;
int s-r=5;
s=r*r*PI;
printf("s=%d\n"-s);
}
PI<--3.
s<--0-r<--5
s<--r*r*PI
流露程序运转后果
flocoming from PI=3.;
int s-r=5;
s=r*r*PI;
本例程序中,PI为实型;s,r为整型。在实践s=r*r*PI语句时,r和PI都转换成double型计算,后果也为double型。但由于s为整型,故赋值后果仍为整型,舍去了小数局部。

逼迫类型转换
逼迫类型转换是经过议定类型转换运算来完成的。其一般形式为: (类型说明符) (表达式)其效力是把表达式的运算后果逼迫转换成类型说明符所表示的类型。例如: (flocoming from) a 把a转换为实型(int)(x+y)把x+y的后果转换为整型在使用逼迫转换时应注意以下题目:
1.类型说明符和表达式都必需加括号(单个变量能够不加括号),如把(int)(x+y)写成(int)x+y则成了把x转换成int型之后再与y相加了。
2.非论是逼迫转换或是主动转换,都只是为了本次运算的须要而对变量的数据长度举行的姑且性转换,而不变动数传闻明时对该变量定义的类型。
main()
{
flocoming from f=5.75;
printf("(int)f=%d-f=%f\n"-(int)f-f);
}
f<--5.75
将flocoming fromf逼迫转换成int f flocoming from f=5.75;printf("(int)f=%d-f=%f\n"-(int)f-f);本例证据,f虽逼迫转为int型,但只在运算中起作用, 是姑且的,而f自身的类型并不变动。于是乎,(int)f的值为5(删去了小数)而f的值仍为5.75。
根基运算符和表达式
运算符的品种、优先级和团结性
C讲话中运算符和表达式数量之多, 在初级讲话中是少见的。新超变传世网站。正是雄厚的运算符和表达式使C讲话效力很是完竣。这也是C讲话的主要特质之一。
C讲话的运算符不单具有不同的优先级, 而且还有一个特质,就是它的团结性。在表达式中,各运算量参与运算的先后次序不单要遵守运算符优先级别的章程,还要受运算符团结性的限制, 以便肯定是自左向右举行运算还是自右向左举行运算。这种团结性是其它初级讲话的运算符所没有的,于是乎也弥补了C讲话的庞杂性。
运算符的品种C讲话的运算符可分为以下几类:
1.算术运算符
用于各类数值运算。包括加(+)、减(-)、乘(*)、除(/)、求余(或称模运算,%)、自增(++)、自减(--)共七种。
2.相关运算符
用于角力计算运算。包括大于(>)、小于(<)、等于(==)、大于等于(>=)、小于等于(<=)和不等于(!=)六种。
3.逻辑运算符
用于逻辑运算。包括与(&firm;&firm;)、或(||)、非(!)三种。
4.位操作运算符
参与运算的量,按二进制位举行运算。包括位与(&firm;)、位或(|)、位非(~)、位异或(^)、左移(<<)、右移(>>)六种。
5.赋值运算符
用于赋值运算,分为轻易赋值(=)、复合算术赋值(+=--=-*=-/=-%=)和复合位运算赋值(&firm;=-|=-^=->>=-<<=)三类共十一种。
6.条件运算符
这是一个三目运算符,用于条件求值(?:)。
7.逗号运算符
用于把若干表达式组分解一个表达式(,)。
8.指针运算符
用于取形式(*)和取地址(&firm;)二种运算。
9.求字节数运算符
用于计算数据类型所占的字节数(sizeof)。
10.非常运算符
有括号(),下标[],成员(→,.)等几种。
优先级和团结性
C讲话中,运算符的运算优先级共分为15级。1级最高,15级最低。在表达式中,优先级较高的先于优先级较低的举行运算。而在一个运算量两侧的运算符优先级相同时, 则按运算符的团结性所章程的团结方向治理。C讲话中各运算符的团结性分为两种,学习超变。即左团结性(自左至右)和右团结性(自右至左)。例如算术运算符的团结性是自左至右,即先左后右。如有表达式x-y+z则y应先与“-”号团结,实践x-y运算,然后再实践+z的运算。这种自左至右的团结方向就称为“左团结性”。而自右至左的团结方向称为“右团结性”。最典型的右团结性运算符是赋值运算符。如x=y=z-由于“=”的右团结性,应先实践y=z再实践x=(y=z)运算。C讲话运算符中有不少为右团结性,应注意区别,以防止理解舛误。
算术运算符和算术表达式根基的算术运算符
1.加法运算符“+”加法运算符为双目运算符,即应有两个量参与加法运算。如a+b-4+8等。具有右团结性。
2.减法运算符“-”减法运算符为双目运算符。但“-”也可作负值运算符,此时为单目运算,相比看。如-x--5等具有左团结性。
3.乘法运算符“*”双目运算,具有左团结性。
4.除法运算符“/”双目运算具有左团结性。参与运算量均为整型时,后果也为整型,舍去小数。若是运算量中有一个是实型,则后果为双精度实型。
void main(){
printf("\n\n%d-%d\n"-20/7--20/7);
printf("%f-%f\n"-20.0/7--20.0/7);
}
双目运算具有左团结性。参与运算量均为整型时,后果也为整型,舍去小数。若是运算量中有一个是实型,则后果为双精度实型。printf("\n\n%d-%d\n"-20/7--20/7);
printf("%f-%f\n"-20.0/7--20.0/7);
本例中,20/7,-20/7的后果均为整型,小数全部舍去。而20.0/7和-20.0/7由于有实数参与运算,于是乎后果也为实型。
5.求余运算符(模运算符)“%”双目运算,具有左团结性。央求参与运算的量均为整型。求余运算的后果等于两数相除后的余数。
void main(){
printf("%d\n"-100%3);
}
双目运算,具有左团结性。求余运算符%央求参与运算的量均为整型。本例输入100除以3所得的余数1。
自增1,自减1运算符
自增1运算符记为“++”,其效力是使变量的值自增1。自减1运算符记为“--”,其效力是使变量值自减1。你知道新开超变传奇。自增1,自减1运算符均为单目运算,都具有右团结性。可有以下几种形式:++i i自增1后再参与其它运算。--i i自减1后再参与其它运算。
i++ i参与运算后,i的值再自增1。
i-- i参与运算后,i的值再自减1。
在理解和使用上容易出错的是i++和i--。特别是当它们出在较庞杂的表达式或语句中时,每每难于弄清,新开中变传奇网站。于是乎应仔细分析。
void 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--);
} i<--8
i<--i+1
i<--i-1
i<--i+1
i<--i-1
i<--i+1
i<--i-1 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--);
i的初值为8
第2行i加1后输入故为9;
第3行减1后输入故为8;
第4行输入i为8之后再加1(为9);
第5行输入i为9之后再减1(为8) ;
第6行输入-8之后再加1(为9);
第7行输入-9之后再减1(为8)
void 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);
}
i<--5-j<--5-p<--0-q<--0
i+i+i--->p-i+1-->i-i+1-->i-i+1-->i
j+1->j-j+1->j-j+1->j-j+j+j->q inti=5-j=5-p-q;
p=(i++)+(i++)+(i++);
q=(++j)+(++j)+(++j);
这个程序中,对P=(i++)+(i++)+(i++)应理解为三个i相加,故P值为15。然后i再自增1三次相当于加3故i的末了值为8。而对待q的值则不然,q=(++j)+(++j)+(++j)应理解为q先自增1,再参与运算,由于q自增1三次后值为8,三个8相加的和为24,j的末了值仍为8。算术表达式表达式是由常量、变量、函数和运算符组合起来的式子。一个表达式有一个值及其类型, 它们等于计算表达式所得后果的值和类型。表达式求值按运算符的优先级和团结性章程的次序举行。单个的常量、变量、函数能够看作是表达式的惯例。

算术表达式
是由算术运算符和括号连接起来的式子,以下是算术表达式的例子:
a+b (a*2)/c(x+r)*8-(a+b)/7++isin(x)+sin(y)(++i)-(j++)+(k--)
赋值运算符和赋值表达式
轻易赋值运算符和表达式,轻易赋值运算符记为“=”。由“= ”连接的式子称为赋值表达式。其一般形式为: 变量=表达式例如:
x=a+b
w=sin(a)+sin(b)
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;都是赋值语句,在后面各例中我们已多量使用过了。
若是赋值运算符两边的数据类型不相同, 体系将主动举行类型转换,即把赋值号左边的类型换成左边的类型。简直章程如下:
1.实型赋予整型,舍去小数局部。后面的例2.9一经说明了这种情形。
2.整型赋予实型,数值不变,但将以浮点形式寄存, 即弥补小数局部(小数局部的值为0)。
3.字符型赋予整型,由于字符型为一个字节,而整型为二个字节,故将字符的ASCII码值放到整型量的低八位中,高八位为0。
4.整型赋予字符型,只把低八位赋予字符量。
void main(){
int a-b=322;
flocoming from x-y=8.88;
char c1=hakha-c2;
a=y;
x=b;
a=c1;
c2=b;
printf("%d-%f-%d-%c"-a-x-a-c2);
}
inta-b=322;
flocoming from x-y=8.88;
char c1=hakha-c2;
printf("%d-%f-%d-%c"-a=y-x=b-a=c1-c2=b);
本例证据了上述赋值运算中类型转换的规则。a为整型,赋予实型量y值888后只取整数8。x为实型,赋予整型量b值322,后弥补了小数局部。字符型量c1赋予a变为整型,整型量b赋予c2后取其低八位成为字符型(b的低八位为0,即十进制66,按ASCII码对应于字符B)。
复合赋值符及表达式
在赋值符“=”之前加上其它二目运算符可组成复合赋值符。如
+=--=-*=-/=-%=-<<=->>=-&firm;=-^=-|=。 组成复合赋值表达式的一般形式为:变量 双目运算符=表达式 它等效于 变量=变量 运算符 表达式 例如: a+=5 等价于a=a+5x*=y+7等价于x=x*(y+7)r%=p 等价于r=r%p
复合赋值符这种写法,对初学者可能不习俗,但很是有益于编译治理,能进步编译效率并爆发质量较高的对象代码。逗号运算符和逗号表达式在

逗号运算符
C讲话中逗号“,”也是一种运算符,称为逗号运算符。 其效力是把两个表达式连接起来组成一个表达式, 称为逗号表达式。
其一般形式为:超变合击传奇网站。 表达式1,表达式2 其求值经过是分袂求两个表达式的值,并以表达式2的值作为整个逗号表达式的值。
void main(){
int a=2-b=4-c=6-x-y;
x=a+b-y=b+c;
printf("y=%d-x=%d"-y-x);
}
a<--2-b<--4-c<--6-x<--0-y<--0
x<--a+b-y<---b+c
本例中,y等于整个逗号表达式的值,也就是表达式2的值,x是第一个表达式的值。对待逗号表达式还要说明两点:
1.逗号表达式一般形式中的表达式1和表达式2 也能够又是逗号表达式。例如: 表达式1,(表达式2,超变合击传奇网站。表达式3)酿成了嵌套情形。于是乎能够把逗号表达式扩展为以下形式: 表达式1,表达式2,…表达式n整个逗号表达式的值等于表达式n的值。
2.程序中使用逗号表达式,通常是要分袂求逗号表达式内各表达式的值,并不必定央求整个逗号表达式的值。
3.并不是在通盘出现逗号的地点都组成逗号表达式,相比看超变。如在变量说明中,函数参数表中逗号只是用作各变量之间的距离符。
[Prlawice]//mcoming fromhsint a-b-c;
flocoming from d;
a=11;
b=235;
c=a+b-a*b;
d=(flocoming from)c/(flocoming from)a;
a=c/a;haVtnevertheless bellyle
a-2-0
b-2-0
c-2-0
d-4-0.0
of Vtnevertheless bellyle
haVupdconsumed
1-0;2-0;3-0
4-0.0
1-11
2-235
3--2339
4--212.
1--212
of Vupdconsumed
of Prlawice
[Prlawice] //1int a-b-c1-c2;
a=25;
b=3243;
c1=b/a;
c2=b%a;haVtnevertheless bellyle
a-2-0
b-2-0
c1-2-0
c2-2-0
of Vtnevertheless bellyle
haVupdconsumed
1-0;2-0;3-0;4-0
1-25
2-3243
3-129
4-18
of Vupdconsumed
of Prlawice
[Prlawice] //1int a-b-c;
a=25;
b=40;
c=a+b-c+35;haVtnevertheless bellyle
a-2-0
b-2-0
c-2-0
of Vtnevertheless bellyle
haVupdconsumed
1-0;2-0;3-0
1-25
2-40
3-65
of Vupdconsumed
of Prlawice
小结
1.C的数据类型
根基类型,布局类型,指针类型,空类型
2.根基类型的分类及特质
类型说明符 字节 数值规模
字符型char 1 C字符集
根基整型int 2 -~
短整型short int 2 -~
长整型 long int 4-~
无符号型 unsigned 20~
无符号长整型 unsigned long 4 0~
单精度实型 flocoming from 43/4E-38~3/4E+38
双精度实型 double81/7E-308~1/7E+308
3.常量后缀
L或l 长整型
U或u 无符号数
F或f 浮点数
4.常量类型
整数,长整数,无符号数,浮点数,字符,字符串,符号常数,本义字符。
5.数据类型转换
·主动转换
在不同类型数据的混合运算中,由体系主动完成转换, 由少字节类型向多字节类型转换。不同类型的量彼此赋值时也由体系主动举行转换,你知道超变。把赋值号左边的类型转换为左边的类型。
·逼迫转换
由逼迫转换运算符完成转换。
6.运算符优先级和团结性
一般而言,单目运算符优先级较高,赋值运算符优先级低。 算术运算符优先级较高,相关和逻辑运算符优先级较低。大都运算符具有左团结性,单目运算符、三目运算符、 赋值
7.表达式
表达式是由运算符连接常量、变量、函数所组成的式子。 每个表达式都有一个值和类型。表达式求值按运算符的优先级和团结性所章程的次序举行。


对于可以
听说超变盛大传世sf网站
看看三个

Tags:65535 
作者:seablade 来源:清水幽萍
相关评论
发表我的评论
  • 大名:
  • 内容:
  • 超级变态传奇65535(www.esdrake.com) © 2017 版权所有 All Rights Reserved.
  • 超变传奇网站|新开超变传奇 沪ICP备08114320号-1
  • Powered by laoy! V4.0.6