com组件 C语言基础

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

C++Overview潘爱民panaimin@icst.pku.edu.cn内容简介C++语言基础Object-BasedProgrammingObject-OrientedProgrammingSTLC++之我见C++语言在变化,我们的概念也要调整变化最能反映OO思想的语言,掌握C++有助于理解OO区分C和C++,C++不是C语言,不要用看待C语言的方式来看待C++掌握C++语言的基础知识操作系统的基础知识–文件API、内存管理…infrastructures计算机原理–汇编语言–C/C++是产生ASM代码的framework编译和执行过程–编译过程–执行过程许多概念–进程、heap、stack,...程序开发过程开发编辑编译出错?链接执行结果正确?结束源程序file.cpp目标程序file.obj库函数和其它OBJ可执行程序file.exeYesYesNoNoBuild过程:compiletimeCompile+link如何对待错误和警告–错误:一定要排除,从第一个错误找起–警告:或者排除,或者确实理解不会对程序造成危害学会设置compileoptions和linkoptions–IDE中如何设置?——一定要知道!–命令行如何设置?–程序代码中如何设置?执行过程:runtimeLoad、重定位、初始化、main如何调试–断点–assertion程序对环境的依赖性–系统环境–CRT–内存影像C++语言内容数据类型–内置(built-in)、标准库、自定义的表达式控制语句函数(模板)异常处理函数模板例子:templateclassTypeTypemin(Typea,Typeb){returnab?a:b;}min(10,20);min(10.0,20.0);模板实例化——由参数决定–隐式实例化–显式实例化–minint(10,20);函数模板(续)两种编译模式:–inclusion模式–separation模式(export关键字)模板特化重载函数模板异常处理(exceptionhandling)错误处理机制、错误代码隔离Throw(raise)anexception–Throwexpression–类似于return语句Try、catch语句(handler)–try{}–catch(type){}或catch(typeobj){}类似于函数调用–但是类型匹配发生在runtime异常处理(续)嵌套机制,如果最外层没有处理,则由terminate来处理Localobject正常析构rethrow–在catch子句中仍然可以throwCatchallhandler–catch(…)声明函数时指定函数可能的异常–intfunc(int)throw(string);–如果没有指定的异常发生,调用unexpected()Object-BasedProgrammingclass实现数据封装对象构造函数与析构函数访问控制、友元嵌套类类中成员初始化虚拟函数类中运算符重载类模板this指针在类的内部指向类自身的指针在每个成员函数中,this指针提供了使用上的方便this指针把类的多个实例对象区分开来模板函数模板即以数据类型为“参数”的函数例如:templateclassTSwap(T&a,T&b){Ttemp;temp=a;a=b;b=temp;}类模板(模板类或类生成器)即以数据类型为“参数”的类例如:templateclassTclassStack{private:Tpool[maxNum];intsp;public:Stack();voidPush(Tx);TPop();BOOLIsEmpty()const;BOOLIsFull()const;};使用:StackintintStack;StackfloatfloatStack;模板(续)定义模板实例化模板参数:类型参数、非类型参数两种编译模式:–inclusion模式–separation模式(export关键字)类模板特化(classtemplatespecializations)类模板部分特化(classtemplatepartialspecializations)从面向过程转换到面向对象面向过程以功能为组织单元在C语言中以函数作为功能单元;通过数据结构来描述具体的问题;数据在功能(函数)之间以参数的形式被传送。面向对象用类class封装数据以及与数据相关的操作;用类的继承性来实现类的重用性;多态性。Object-OrientedProgrammingCShapeCPointCLineCCircleCArcCTextCShapeCPointCLineCCircleCArcCText多态性和虚拟函数多态性是面向对象的一个支柱允许程序在实施对象的操作时,允许对象按不同的方式完成不同类型对象的操作;不同类型对象有自己实现操作的方法。虚拟函数虚拟函数实现了多态性。说明:在函数说明之前加上关键字virtual在基类的说明中,定义虚拟函数:virtualvoidDisplay();调用:CShape*pShape=GetCurrentShape();pShape-Display();对象的内存分布图Vptr指针和vtab表classA{private:intvalue;public:virtualvoidFunc1(void)virtualvoidFunc2(void)};变量偏移量vptr0value4A::Func1A::Func2vtab对象的内存分布图(续一)classB:pulicA{private:intvalue1;public:virtualvoidFunc1(void)virtualvoidFunc2(void)};变量偏移量vptr0value4value18B::Func1B::Func2vtab对象的内存分布图(续二)classB:pulicA{private:intvalue1;public:virtualvoidFunc1(void)};变量偏移量vptr0value4value18B::Func1A::Func2vtab继承关系Public继承–“is-a”关系private继承–“has-a”关系–可以用复合类或者嵌套类来表示protected继承–比private继承放宽限制virtual继承–单个共享实例–虚基类的构造由themostderivedclass完成类型转换Static_castDynamic_cast–向下转换voidDraw(CShape*shape){//shape-DrawRect()//shape-DrawCircle()if(dynamic_castCRect*(shape)){…}}RTTI:typeidStatic_cast类型转换classB{...};classD:publicB{...};voidf(B*pb,D*pd){D*pd2=static_castD*(pb);//notsafe,pbmay//pointtojustBB*pb2=static_castB*(pd);//safeconversion...}Static_cast类型转换(续)classB{...};classD:publicB{...};voidf(B*pb){D*pd1=dynamic_castD*(pb);D*pd2=static_castD*(pb);}C++标准库C标准库iostreamlibrary–cin、cout、cerr–ostream&operator(ostream&os,constMyClass)–istream&operator(istream&os,MyClass&)STL(StandardTemplateLibrary)GenericProgramming作者:AlexanderStepanov目标:高效、灵活地实现各种算法思想:对算法进行抽象,与数据表示分开以模板技术为基础–函数模板–类模板C++的发展使得这种思想得以实现STL基础Object-BasedProgramming–有关class的各种设计技术函数对象(functionobjects)–重载了函数调用操作符()的类模板–函数模板–类模板–模板特化STL思想数据类型算法容器STL实现Iterator对象容器(Container)算法(Algorithm)Iterator对象Iterator对象STL容器顺序容器(SequenceContainer)–vector–deque–list关联容器(AssociativeContainer)–set–multiset–map–multisetSTL迭代器迭代器(Iterator)是指针(pointer)的泛化任意访问双向迭代器向前迭代器输入迭代器输出迭代器STL算法改变顺序的操作–reverse、replace不改变顺序的操作–for_each、find排序及相关操作–sort、rotate常用的数字操作–count、sum_up使用STL#includefunctional#includelist#includeiostream#includealgorithmusingnamespacestd;templatetypenameTvoidprint_elements(Telem){coutelem;}void(*pfi)(int)=print_elements;voidmain(){intia[7]={0,1,2,3,4,5,6};listintilist(ia,ia+7);//以陣列做為list的初值for_each(ilist.begin(),ilist.end(),pfi);//0123456ilist.push_back(7);ilist.push_back(0);ilist.push_back(7);ilist.push_back(9);for_each(ilist.begin(),ilist.end(),pfi);//01234567079ilist.remove_if(bind2nd(modulusint(),2));//去除所有奇數for_each(ilist.begin(),ilist.end(),pfi);//02460}C++参考书“C++ProgrammingLanguage”“C++Primer”(3/e)“DesignandEvolutionofC++”“InsidetheC++ObjectModel”“EffectiveC++”(2/e)“MoreEffectiveC++”“ExceptionalC++”“C++StrategiesandTactics”“GenericProgrammingandtheSTL”……

1 / 36
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功