《c++ primer》读书笔记9

原创 2004年07月15日 14:19:00

笔记范围:2.6<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

 

每个程序员都知道,在程序运行过程中,一些情况是不可预料的,无论程序的设计看起来是多么完善,在某个特定的环境里同样会出错,但是这样的错误往往会有些共同之处,比如new的时候也许会空间不足。显然这样的错误。不能完全说是程序设计的问题,但是如果你的程序能对这些情况做出反应,那么这样的程序实用性就会更强。异常机制正是为此而生。

注意,这里用了“机制”这个词,也就意味者规则,正如本节开头所说的:对于异常各人都有自己的处理方式。比如就用if语句处理。本来这是没什么问题的,但是我们生活在一个不幸的时代,程序的规模大得远远超出了个人能力能够接受的程度。我们需要合作,因此统一的编码风格成了必要的事情了,这也是为什么程序员经常告诉初学者编程是最不具备个性化的东西之一的一个原因,

使用异常机制还有一个好处。他可以大大减少代码的长度和规模。对于相同的异常情况可以集中统一处理。这样说很空泛,我们来举一个小例子.,假设我们写个函数分别为,int char 的指针分配相同单位的空间,如不要异常机制,这样写:

bool new_space( int *&pev,char *&ch,int size ) {

      pev = new int[ size ];

      ch = new char[ size ];

      if( !pev )

        return false;

      if( !ch )

        retuen false;

     return true;

}

这样的东西恐怕没人喜欢,因为如果我们这样调用他,new_space( p, c, 6 ),无论空间分配成功与否。调用者都不知道( 问:你不会定义个bool量吗??答:会。烦。我用别的 ),恩,得让我们的东西人性化点。修改如下:


bool new_space( int *&pev,char *&ch,int size ){

      pev = new int[ size ];

      ch = new char[ size ];

      if( !pev ) {

        cerr << "err1" <<endl;//在帮助系统里把err1说明成空间不足

        return false;

      }

      if( !ch ) {

        cerr << "err1" <<endl;

        retuen false;

      }

return true;

}

呵呵,这下对得起可爱的用户了吧?可是发现有点对不起自己。cerr << "err1" <<endl;  retuen false; 我写了两遍,这是两个指针,如果十个呢?天哪。老板,加工资吧(回答你们一定知道),那好,试试异常机制,再改。

bool new_space( int *&pev,char *&ch,int size ){

    try

    {

       string word ( "err1" );

       pev = new int[ size ];

       ch = new char[ size ];

       if( !pev )

           throw word;

       if( !ch )

           throw word;

    }

    catch( string err )

    {

       cerr << err << endl;

       return false;

    }

     return true;

}

呵呵,这下比较舒服了。大家可能看到上面那函数好像并没有减少什么长度,yes,但如果处理的参数不只两个,很多,你就会发现他省了你很多力气,

   上面主要想说明异常机制的好处和用法(水平有限,可能例子并不好)在本节中还有个重要的内容,那就是程序处理异常的方式和顺序。比如上面的程序,我们想让它在当分配成功时显示ok,那么cout <<  “ok”  << endl;写在那儿呢?如果我们的try抛出的异常在函数里没有相应的catch怎么办呢?这些书上都说很详细。仔细看吧,一定收获不少。

数据结构基础系列(9):排序

数据结构课程是计算机类专业的专业基础课程,在IT人才培养中,起着重要的作用。课程按照大学计算机类专业课程大纲的要求,安排教学内容,满足需要系统学习数据结构的人。系列课程包含11个部分,本课为第9部分排序,介绍插入排序、交换排序、选择排序、归并排序、基数排序等各种排序算法,以及各种算法的性能分析。
  • 2015年11月25日 22:02

C++ primer plus读书笔记(一)

这一系列的blog主要是对以前学过的C++的特点,以及面向对象的相关内容的总结。 面向对象的三大特征:封装、继承、多态。 访问控制原则: public:使用类对象的程序可以直接访问公有成员。...
  • u012927281
  • u012927281
  • 2016-08-17 10:57:44
  • 364

【读书笔记:C++ primer plus 第六版 中文版】第2章:开始学习C++

转载请注明出处: 本章内容包括: 创建C++程序. C++程序的一般格式. #include编译指令. main()函数. 使用cout对象进行输出 在C++程序中加入注释. 何时以及如何使用endl...
  • enyusmile
  • enyusmile
  • 2015-06-21 10:33:59
  • 911

《c++ primer》读书笔记3

笔记范围:1.3节到1.4节   说来惭愧,在学c的时候对于1.3节中所讲的内容就没有好好读过,以至于在相当长的一段时间里,过得糊里糊涂的,当然,主要的责任在我自己。但是,背了这么大的罪,有点不甘心。...
  • owl2008
  • owl2008
  • 2004-07-15 14:04:00
  • 1779

《c++ primer》读书笔记5

笔记范围:2.1节到2.2节 很多人都会觉得第二章很难,作者在第一篇的引言中也提到:如果读者觉得第二章的内容难以理解,就跳过他。而个人认为这样做不是最好的选择,事实上,第一篇的目的在于对这语言有个很好...
  • owl2008
  • owl2008
  • 2004-07-15 14:09:00
  • 1900

C++ Primer中文版读书笔记

(注意,Lm 表示第 m 行,L-n 表示倒数第 n 行)■导读 p23原文:template T func( T p1, T p2, int p3 ) // ( T p1, T p2, int p3...
  • jaminwm
  • jaminwm
  • 2007-12-25 20:04:00
  • 2510

C++ primer读书笔记(1)

写在前面的话:
  • u013457107
  • u013457107
  • 2014-05-02 00:17:31
  • 475

C++ Primer(第五版)读书笔记(1)

从今天起,2018年2月27日,开始重读《C++ Primer(第五版中文)》,将思考和体会、问题均记录在此。第1章  开始1.1 编写一个简单的C++程序1.1.1 编译、运行程序       编写...
  • zhang669154
  • zhang669154
  • 2018-02-27 08:56:54
  • 42

c++primer读书笔记(5)

第九章的总结: 1.为了保持通用性,C++使用术语翻译单元,而不是文件,文件不是计算机组织信息时的唯一方式。2.C++允许编译器使用自己的名称修饰,因此不同的编译器编译出来的二进制模块(对象代码文件...
  • qq_31029351
  • qq_31029351
  • 2017-02-24 21:06:37
  • 108

C++ primer 读书笔记四

第六章 函数 传入引用参数 吐槽:c++ primer 这本书感觉不行,关于很多概念讲不清 同时代码存在不具备连续以及调测性 #include "a.hpp" #include #...
  • liu1020023862
  • liu1020023862
  • 2017-07-20 07:50:00
  • 170
收藏助手
不良信息举报
您举报文章:《c++ primer》读书笔记9
举报原因:
原因补充:

(最多只允许输入30个字)