- 1、本文档共67页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第7章 继承与生
* * * * * * * * * * * * * * * * * * * * * 类型转换时的注意事项(1) 基类对象一般无法被显式转换为派生类对象 对象到对象的转换,需要调用构造函数创建新的对象 派生类的拷贝构造函数无法接受基类对象作为参数 执行基类向派生类的转换时,一定要确保被转换的指针和引用所指向或引用的对象符合转换的目的类型: 对于Derived *pd = static_castDerived *(pb); 一定要保证pb所指向的对象具有Derived类型,或者是Derived类型的派生类。 * 深 度 探 索 类型转换时的注意事项(2) 如果A类型是B类型的虚拟基类,A类型指针无法通过static_cast隐含转换为B类型的指针 可以结合虚继承情况下的对象内存布局,思考为什么不允许这种转换 void指针参加的转换,可能导致不可预期的后果: 例:(Base2是Derived的第二个公共基类) Derived *pd = new Derived(); void *pv = pd; //将Derived指针转换为void指针 Base2 *pb = static_castBase2 *(pv); 转换后pb与pd有相同的地址,而正常的转换下应有一个偏移量 结论:有void指针参与的转换,兼容性规则不适用 更安全更灵活的基类向派生类转换方式——dynamic_cast,将在下一讲介绍 * 深 度 探 索 * 小结与复习建议 主要内容 类的继承、类成员的访问控制、单继承与多继承、派生类的构造和析构函数、类成员的标识与访问 达到的目标 理解类的继承关系,学会使用继承关系实现代码的重用。 实验任务 实验七 #include iostream #include string #include iomanip using namespace std; class Node{ //创建结点 private: int m_Data; //数据域 Node *m_Next; //,指向下一 个Node对象的指针域 public: Node(int data){ //构造函数 m_Data = data; m_Next = NULL; } Node(int data,Node *next){ m_Data = data; m_Next = next; } void SetData(int data){ //修改节点中的数据 m_Data = data; } int GetData( ){ //获得节点中的数据 return m_Data; } void SetNext(Node *next){ //修改节点中的指针 m_Next = next; } Node* GetNext( ){ //获得节点中的指针指向的对象引用 return m_Next; } } ; class LinkList { //定义链表类 private: Node *m_FirstNode; //链表中的第一个节点 public: LinkList( ){ //建立空链表 m_FirstNode = NULL; } LinkList(int data){ //建立只有一个节点的链表 m_FirstNode = new Node(data); } string VisitAllNode( ){ //遍历每个节点,将所有数据串成一个字符串 Node *next = m_FirstNode; //从第一个节点开始 string s = ; char stemp[20]; while(next != NULL){ //直到最后一个节点 itoa(next-GetData(),stemp,10); s = s + stemp + ; next = next-GetNext( ); //使next指向下一个节点 } return s; } void InsertAtBegin(int data){ //将数据data的节点插入在整个链表的前面 if(m_FirstNode == NULL) //对于空链表,直接插入 m_FirstNode = new Node(data); else //把新节点插在第一个节点前面,并指向原来的第一节点 m_FirstNode = new Node(data,m_FirstNode); } void InsertAfterI
您可能关注的文档
- 第7章 企业法遵从和信息资产管理.ppt
- 第7章 使用模和库批量制作风格统一网页.ppt
- 第7章 会计记(下)—账户记录.ppt
- 第7章 使用A Div元素.ppt
- 第7章 保真度则下的信源编码.ppt
- 第7章 信息分(新).ppt
- 第7章 信息检及发展.ppt
- 第7章 停车设规划.ppt
- 第7章 信用证上).ppt
- 第7章 信息资的宏观管理.ppt
- 河南省郑州市第一中学2017-2018学年高一下学期周测物理试题(325)扫描版含答案.doc
- 山西省怀仁县第一中学2017-2018学年高二下学期第一次月考生物试题扫描版.doc
- 河南省六市高三下学期第一次联考试题(3月)理科综合扫描版含答案.doc
- 四川省高三全国Ⅲ卷冲刺演练(一)文综地理试卷扫描版含答案.doc
- 河南省洛阳市高三第二次统考文综试卷扫描版含答案.doc
- 甘肃省靖远县高三下学期第二次联考理科综合试题扫描版含答案.doc
- 问题导学法在办公场景中的实施策略及效果评估.docx
- 退休后的个人品牌打造与传播策略.docx
- 问题解决在办公流程优化中的应用.docx
- 问题导向的办公环境创新设计.docx
最近下载
- 浅谈区域品牌云展馆交互体验设计.docx VIP
- FDA-21 CFR Part 820新版医疗器械质量管理体系法规(QMSR)征求意见稿(中文)-202202.pdf
- 2025年主管护师(外科护理学)考试(专业知识)真题选题卷完整版 .pdf VIP
- 餐饮管理系统需求规格说明书.docx
- 2019-2023年福建省中考语文试题卷【文言文阅读题题解及答案解析】汇集.docx VIP
- 女装短视频运营方案.docx
- 2019-2023年福建省中考语文试题卷【文学类文本阅读题解及答案解析】汇集.docx VIP
- 2023年福建省各地中考语文模拟卷【古诗词鉴赏题解及答案解析】汇集.docx VIP
- 主管护师(外科护理)专业代码370真题相关专业知识2025年真题试卷真题.pdf VIP
- 开题报告-箱体零件的工艺规程及夹具设计.docx
文档评论(0)