




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、1SE 422312面向对象技术与工具C+语言基础2C+语言基础oC+语言概貌o数据类型o函数o指针o数组31. C+程序概貌o第一个C+程序#include /包含ANSI C+库文件using namespace std; /使用预定义的名字空间std void main( void )cout “Hello, world!” endl; /输出字符串4ISO/ANSI C+库文件库文件o程序的第一行是#include 。#include是一条编译预处理指令,它的作用是在源文件中插入iostream文件所包含的所有源代码。iostream文件是标准标准C+的一个的一个库文件。 oC语言的头
2、文件都有后缀.h,C+语言可以直接使用这些带.h后缀的头文件。o为避免命名的冲突,ISO/ANSI C+标准将每一个C语言的头文件对应地改造为一个库文件(文件名仅仅是将原文件的.h去掉),并将该文件中定义的标识符定义在标准的名字std中。 5名字空间名字空间o包含头文件iostream的目的是为了使用标准输出流cout和endl 。通过using namespace std语句来引入名为std的名字空间。o解决问题的方案有两个:n使用名字限定符std:cout “Hello, world!” ”和“变量名; “”在C语言中是右移运算符,在C+语言中,如果第一个操作数为cin,它就是输入运算符。
3、o输出格式为: 变量 cout 表达式 常量(各种类型常量均可) “”在C语言中是左移运算符,在C+语言中,如果第一个操作数为cout,它就是输出运算符。o输入和输出运算符可以连用。9注释注释o为程序加入适当的注释是非常有价值的,因为这些注释可以为我们阅读程序提供帮助。C+具有C的多行风格注解。使用“/*”开始,直到“*/”结束,可以注解多行,但不允许嵌套。C+也提供一种新的表示注解的方法,Comment_to_end_of_line的结构,使用“/”开始,直到行尾结束。 102. 数据类型oC+的内建(Built-in)类型1. 整型 C+整数类型包括字符型char、短整型short、整型i
4、nt和长整型long。 下面的这些数的类型都属于整数类型:-128,-30,0,64,65535,680712可以用到的整数类型有8种:char, short, int, long, unsigned char, unsigned short, unsigned int, unsigned long其中,unsigned int可以简写为unsigned。11数据类型2. 字符型字符型char是一种特别的整数类型。 字符型数据在内存中是以ASCII码的形式存储的。由于字符的存储值ASCII码是个整数,因此在某些情况下我们会把字符数据当作整型数据来参与运算。C+的转意字符序列。比如,n并不代表字
5、符n,而是表示新行(new line)。这里符号(反斜杆)叫做转意字符,意思是跟在它后面的字符不再是原来的含义,而是有其它的含义。如果当要用到符号本身,需要把它写成。12数据类型3. 布尔型布尔型bool是一种特殊的内建整数类型,因为它采用与整数相同的存储方式。不过,布尔类型的表达范围非常有限,只能取false和true两个值。这是两个C+的关键字,而且是两个字符常量标识符,并不是字符串。应该注意的是,虽然这里把bool类型归为整数类型,但这并不等于我们可以把它当作整数使用。 bool类型主要用来表达一种逻辑真或假的状态,它的含义和用途与整数是完全不同的。13数据类型o浮点类型浮点类型浮点数指
6、的是带有小数部分的数,用来表示数学意义上的实数。实数的表示是:整数部分 . 小数部分其中小数部分看起来也是个整数。除了小数点,整数部分和小数部分可以缺省,但不能两者都缺。下面是一些浮点数的例子:3.14159,-123.45,0.957,6.,.2C+的浮点类型有三种:float、double、long double。143.变量和命名常量o标识符标识符 为了使C+程序更加易读易写,我们会用一些有意义的名字来标识程序元素,比如数据、函数等等。那些用来标识程序元素的名字就是标识符。使用自定义标识符也是所有高级语言的特征。 标识符是由字母A-Z,a-z和数字0-9混合而成的,另外可以加入下划线_。
7、不过,所有的标识符必须以字母或者是下划线_开头。153.变量和命名常量o标识符标识符命名一个标识符的时候,遵循一些常用的约定:n取一个有意义的名字。n如果名字由多个单词组成,那么每个单词的第一个字母用大写。(C+是大小写敏感的语言)n使用匈牙利记号。匈牙利记号是一种前缀,是在标识符的前面加上一个小写字母以示其数据类型。o变量声明变量声明 charcData;boolbFlag;intiPage, nCount;double fDelta;163.变量和命名常量o变量声明变量声明 一旦声明了一个变量,这个变量在运行时就会在内存中占据一定大小的空间。例如声明变量iPage在内存中的映像如下图所示:
8、16iPage0 x0013FF78内存单元的符号名内存单元的32位地址内存单元的大小在32位机上是4字节173.变量和命名常量o常量(常量(Named Constant)和)和const关键字关键字n常量 一些常量(字面常量)和所属类型的例子:10(int)077L(long)0 xABCDu (unsigned int)9.78f(float)7905.30 (double)A(char)17183.变量和命名常量n命名常量使用字面常量省掉了占用内存单元的开销,但也有一些缺点:n在多处使用了相同的字面常量,而后来又要对这个常量进行修改时就会显得非常麻烦;n字面常量没有明确的类型信息,它们的
9、类型采用编译器的约定。 为了解决上述的问题,可以使用C风格的没有参数的宏定义: #define PI 3.14 PI并不是真正的符号常量。 仅是一个字符串,没有类型,不占用存储空间,不能取它的地址。18193.变量和命名常量n命名常量C+提供灵活的命名常量方式来描述常数:const float PI = 3.14; PI成为一个真正的符号常量,有类型,需要占用存储空间(存放在常量数据区)。 PI的值不能被修改。 1920数据类型汇总20C+的数据类型地址类型简单类型结构类型整数类型布尔型 bool字符型 unsigned char短整型 unsigned short整型 unsigned in
10、t长整型 unsigned long浮点类型单精度浮点型 float双精度浮点型 double长双精度浮点型long double枚举类型 enum指针类型 pointer引用类型 reference数组 array结构 struct联合 union类 class214 用户自定义类型-枚举用宏来定义一系列表示状态的常量有明显的缺陷,就是没有类型信息。C+提供了一种更好的解决方案,就是使用枚举类型:enum TrafficLight RED, GREEN, AMBER ; 标识符RED、GREEN、AMBER被称为枚举常量,它们不是字符串,也不是整型常量。另外,枚举常量是有序的。 21224
11、用户自定义类型-数组数组n一维数组一维数组的定义如下:TYPE array整型常量;n二维数组在处理像矩阵这样的二维阵列(这正是array这个词汇的原意)时,使用二维数组 const int ROW = 3; const int COL = 5; int arrROWCOL;n一维字符数组 一维字符数组往往被用来表示字符串。不过,数组最后一个有效字符的后面必须是个结束标记。 这样的字符串被称为ASCIZ字符串。char szName = K, e, n, 0 ;22234 用户自定义类型-结构和联合结构和联合n结构 struct 数组是相同类型数据的集合。当要把不同类型的数据集合在一起时,会用
12、到结构struct。结构 的例子struct Employee intnID;/工号char szName30;/姓名charcGender;/性别short nDOB;/出生年份intnDeptID;/工作部门号; 23244 用户自定义类型-结构和联合结构和联合n联合union 联合的定义类似于结构的定义; 联合和结构的不同之处在于,联合变量的每个成员都共享同样的内存单元。一个联合变量的大小实际上是它占据内存最多的那个成员的大小。24254 用户自定义类型-指针指针o指针是另外一个变量的地址,通过这个地址可以间接地访问到那个变量。 int nUnit; int * pi = &nUnit;
13、 符号*表明了变量pi是一个指针变量;运算符&的功能是取变量nUnit的地址。这样,pi单元的内容就是nUnit单元的地址。25264 用户自定义类型-指针指针由于指针是地址,因此所有指针单元的大小都是一样的。但是,这并不意味的两个指针变量可以互相赋值,因为指针是有类型之分的。 指针类型可以看作有两部分组成:n首先它是个指针(值为地址);n其次,指针变量指向了一个特定类型的变量。 float * pf; 274 用户自定义类型-指针指针o 指针和常量修饰符const const也可以与指针一起使用,它们的组合情况复杂一些,可归结为三种: 指向常量的指针 常指针 指向常量的常指针。 27284
14、用户自定义类型-指针指针指向常量的指针 const TYPE * pc; pc指向的单元不能改变,但pc可以改变常指针 TYPE * const cp=; cp不能改变,但它指向的单元可以改变指向常量的常指针 const TYPE * const cpc=; cpc指向的单元不能改变,cpc不可以改变295 用户自定义类型-引用引用o引用就是给一个变量取一个别名。 也就是说,引用与它所引用的变量实际上是同一个单元(共享存储单元)共享存储单元)。o引用主要有以下三个用途:引用主要有以下三个用途:()独立引用;()独立引用; 例如:例如:int i; int i; int & j = i; int
15、 & j = i;()作为参数传递;()作为参数传递;()作为返回类型。()作为返回类型。后2者有意义。 2930引用作为函数参数oC语言采用传值(call by value)方式进行参数传递。o当一个函数需要修改对应的实参的值时,参数应明确声明为指针类型。void fun(int num) num=100;void main( ) int annum=10; fun(annum); coutannum;输出10实参与形参的传递方式为:int num=annum31引用作为函数参数void fun(int &num)num=100;void main( ) int annum=10; fun(
16、annum); coutannum;输出100实参与形参的传递方式为:int &num=annumvoid fun(int * p)*p=100;void main( ) int annum=10; fun(&annum); cout = = = !=(not_eq)逻辑运算符:! & | not and or位运算符: & | 移位运算符:赋值运算符:= += -= *= /= %= = |= &= =条件运算符:?:3738常用运算符常用运算符求字节运算符:sizeof指针运算符:* &成员选择运算符: - .* -*下标运算符: 函数运算符:( )域选择运算符::逗号运算符:,其它运算符
17、 38395 C+运算符-内存管理o动态存储分配和释放存储空间的功能,C语言是利用malloc和free函数完成的。 void * malloc(size_t size); void free(void * p);C+提供了新的运算符new和delete来完成动态存储分配和释放存储空间的工作:new的参数是待分配单元的数目,它自动计算要分配类型的大小,而不给出要分配的存储区的大小(字节数) ;new自动返回正确的指针类型,不必对返回指针进行类型转换;可以用new将分配的存储空间进行初始化;3940newo运算符运算符new用于内存分配的使用形式为用于内存分配的使用形式为 type * p; p
18、=new type;o其中,其中,type是一个数据类型名;是一个数据类型名; p是指向该数据类型的指针;是指向该数据类型的指针; new从堆的一块空闲内存区中分配一块内存,从堆的一块空闲内存区中分配一块内存, 其大小就是其大小就是type类型的数据长类型的数据长度,该内存地址被存于指针度,该内存地址被存于指针p中。中。如果分配失败,如果分配失败,new new 返回一个空指针。返回一个空指针。otypetype可以是任何类型,包括函数指针,但不允许函数类型。可以是任何类型,包括函数指针,但不允许函数类型。o当当typetype为数组类型时,为数组类型时,newnew返回的指针指向数组的第一个
19、元素,当用返回的指针指向数组的第一个元素,当用newnew创建创建多维数组时,必须提供所有维的大小。多维数组时,必须提供所有维的大小。o注意:注意: 使用使用newnew申请的存储空间是没有名字的,只能通过指针间接访问它们。申请的存储空间是没有名字的,只能通过指针间接访问它们。41deleteo运算符运算符delete释放释放new分配的存储空间,将其交还给堆。它的使用形式一般分配的存储空间,将其交还给堆。它的使用形式一般为为 delete p; 其中,其中,p必须是一个指针,保存着必须是一个指针,保存着new分配的内存的首地址。分配的内存的首地址。o动态分配管理的方法要求动态分配管理的方法要
20、求deletedelete的操作数必须是一个的操作数必须是一个newnew返回的指针,对不是返回的指针,对不是由由newnew得到的任何其他地址类型,使用得到的任何其他地址类型,使用deletedelete将导致严重错误。将导致严重错误。o这种错误是运行时的错误,很难调试,因此使用这种错误是运行时的错误,很难调试,因此使用deletedelete时请务必注意。时请务必注意。o回收回收newnew分配的数组空间,使用分配的数组空间,使用deletedelete进行进行 delete p; delete p;o表明一个由表明一个由 p p 指向的数组空间被回收了。指向的数组空间被回收了。42 ne
21、w和delete典型用法1 动态分配和释放单个数据的存储区语法为: type * p; p=new type; /通过*p方式访问new申请的空间。 delete p; 43 int main( ) int * p; p=new int; if (!p) cout“allocation failuren”;return 1; *p=20; delete p; return 0;442 用new运算符初始化单个数据的存储区 语法为: type * p; p=new type(); delete p; 45动态分配数组的存储空间(1)一维数组 语法为: type * p; p=new types;
22、 /通过pi的方式访问数组元素。 delete p; 46(2)n维数组o语法为: type (* p)常量1常量2常量n-1; p=new types常量1常量2常量n-1; /通过pi1i2in的方式访问数组元素。delete p;os指定数组中的第一维元素个数,可以是常量或表达式。o不能省略 。47C+运算符-类型转换运算符类型转换运算符n隐式转换隐式转换发生在下述的情况下:混合运算:级别低的类型向级别高的类型转换。将表达式的值赋给变量:表达式的值向变量类型的值转换。实参向函数形参传值:实参的值向形参的值进行转换。函数返回值:返回的值向函数返回类型的值进行转换。n显式类型转换显式类型转换
23、有几种风格:nC风格: (TYPE)表达式 (TYPE)(表达式)nC+风格: TYPE(表达式)4748C+运算符-类型转换运算符类型转换运算符显式类型转换n使用类型安全的显式类型转换运算符 float fnum = 5.8;const int icnum = 10;int inum = static_cast(fnum); int inum2 = const_cast(icnum);48496. 表达式C+的表达式是一种能计算出一个值的语法分量,它的形式化定义如下:表达式 := 变量名 | 常量名 | 字面常量表达式 := ( 表达式 )表达式 := 表达式 运算符 表达式49506. 表
24、达式-简单语句和复合语句简单语句和复合语句o在任何合法的C+表达式后面加上一个分号“;”就能使其构成一条合法的C+语句。甚至一个单独的分号也能成为语句,这叫空语句。 任何C+声明都是语句。 多条语句可以复合在一起完成一定的功能。这些语句构成了复合语句。复合语句必须放在一对花括号 之间。 50517.C+语句o流程控制语句流程控制语句nif-else语句 if (bool表达式)语句1 else语句2(ex2-11.cpp)51527.C+语句-流程控制语句流程控制语句oswitch-case语句switch (整型表达式)case 常量表达式1: 语句1; break;case 常量表达式2:
25、 语句2; break;default:语句n;(ex2-12.cpp)52537.C+语句-流程控制语句流程控制语句o循环语句while (bool表达式)语句do语句 while (bool表达式);for (表达式1; 表达式2; 表达式3)语句53547.C+语句-流程控制语句流程控制语句break和continue语句在循环控制语句当中,如果我们根据某个条件需要提前结束整个循环,我们可以利用break语句。不过,break语句只能终止包含它的那层循环语句。如果这层循环包含在另一个外层循环之内,那么break就鞭长莫及了。 忽略此后的包含在循环体中的语句而直接进入下一次的循环可以使用c
26、ontinue语句。54557.C+语句-流程控制语句流程控制语句goto语句很多的专家都认为应该取消goto语句,不过C+还是保留了它。现在goto语句的最大作用就是从嵌套很深的循环中直接跳出来。在其它的场合尽量少使用goto语句。其实goto语句也可以构成循环,不过在高级语言程序中我们都不这么做,除非有特别的理由。return语句return语句会引起函数立刻返回(结束),main函数也不例外。return语句的格式为:return 表达式;55567.C+语句-流程控制语句流程控制语句try-catch语句try-catch语句用于保护容易发生错误的语句块,并且能在错误发生时捕获错误,然
27、后对错误进行处理。它的语法如下:Try 语句*; catch (类型1 变量名1) 语句; catch (类型2 变量名2) 语句; catch (类型n 变量名3) 语句; 56578. 函数o函数原型声明和定义函数原型声明和定义函数原型是一个很重要的概念,函数原型担负着三个特殊的任务:n确定函数返回值的类型,使编译程序能产生函数返回数据类型的正确代码。n确定了函数使用的参数的类型、个数和顺序。n函数名代表该函数的函数体以及函数完成的功能。函数原型一般的语法形式为 返回类型 函数名(参数列表)57588. 函数o函数的参数函数的参数C+采用“传值”或“传地址”的方式来使实际参数和形式参数相结
28、合。n传值调用(Call by value) 实参和形参是两个不同的单元,在结合时,实参的值将会被拷贝到形参中。2、传地址 引用做参数。形参是实参的别名。 也就是说,形参就是实参本身。这样一来,对形参的改变也就直接改变了实参。58598. 函数-参数参数1. 用const修饰参数 使用指针和引用参数,实参存在被更改的潜在“危险”。为了避免这种危险,可以给形参加上const约束,这是形参/实参成为只读参数,从而避免了被更改的问题。2. 缺省参数缺省参数是另一种形式的重载(函数调用的重载)void fun(int num = 0) 其中:num称为缺省参数,0称为缺省值。可以用两种方式调用函数 f
29、un:fun(10); / 传递显式的值,则num的初始值为10fun(); / 无对应的实参,则num的初始值为0 59608. 函数-返回值函数是一个完成一定功能的程序块,在很多时候需要将计算的结果传递给调用该函数的程序块。 传递结果的方式之一就是让函数返回一个值。 实际上是将返回的值放到一个结果寄存器或临时单元中。1. 函数返回值函数返回的值类型,int strlen(const char *str) char *p = str; While (*p) p+; return p str;60618. 函数-返回值2. 函数返回指针函数返回指针,实际上也是返回一个值,不过这个值是某个单元的
30、地址。char * strcat(const char *str1, const char *str2)char * str=new char strlen(str1)+strlen(str2)+1;char * p = str;while (*p+ = *str1+); p-; while (*p+ = *str2+); return str;628. 函数o函数的返回值函数的返回值n函数返回引用 函数返回引用,实际上返回的是一个存储单元(即变量)。62638. 函数-内联函数内联函数许多C程序员使用带有参数的宏调用来完成简单函数的调用,但宏很受限,每个变元仅能被引用一次,有时会产生不可期望
31、的副作用。例如:#define abs(v) (v) 0 ? -(v): (v) 当调用为 abs(+a) 时,将不能正确工作!因为在程序中每次遇到宏替换名时,就用所定义的字符串去替换它,那么替换的结果将是(+a) 0 ? -(+a) : (+a)得到的是a + 2的绝对值,这产生不期望的结果。 63648. 函数-内联函数内联函数宏替换的好处是没有系统的调用开销。函数正相反。为结合两者的优点,C+语言允许定义内联函数。在函数原型前冠以“inline”表示一个内联函数。例如:inline void function(int a, int b);编译时,在调用 function的地方用函数体替换
32、,能够加快代码执行,减少调用开销。 64658. 函数-递归递归 函数递归调用是一个函数直接或者间接调用自己。 递归是非常有用的一种调用方式,因为它可以减少代码量。 不过,递归代码一般不容易理解,并且执行时对资源(主要的栈资源)消耗较大。65668. 函数-重载由于所有C+函数都有函数原型,因此C+容易表达重载(overload)一个函数名的概念。亦即它能区分多个函数,即使它们具有相同的名字但有不同的参数。C+允许进行函数重载:多个函数具有相同的函数名,但有不同的参数表和各自的函数体。只要编译能区分参数表(参数个数和类型),就可以重载一个函数名。66678. 函数-重载 double abs(double num) return (num 0 ) ? -num : num);long abs(long num) return (num 0) ? -num : num); 多个同名函数的原型中不允许只有返回类型不相同,而
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
评论
0/150
提交评论