C++高质量编程的一些经验.pdfVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C++高质量编程的一些经验.pdf

C++高质量编程的一些经验 一、你需要一个函数将一个数组赋值为等差数列,并将会在函数的外部使用它。 不合理: int *GetArray( int n ) { int *p = new int[n]; for ( int i = 0; i n; i++ ) { p[i] = i; } return p; } 合理: void GetArray( int *p, int n ) { for ( int i = 0; i n; i++ ) { p[i] = i; } } 解析: 检查内存泄露的最好办法,就是检查完全配对的申请和释放,在函数中申请而在外部释 放,将导致代码的一致性变差,难以维护。而且,你写的函数不一定是你自己使用的,这样 的函数别人会不知道该怎么适当的使用,如果它是一个DLL的导出函数,并且你在不同的平 台下使用了,便会导致系统崩溃。最好的解决办法就是在函数调用的外面将内存申请好,函 数只对数据进行复制。 二、你需要写一个类来为你管理一个指针,这个类将封装对指针的申请内存、释放和其 它一些基本操作。 不合理: class A { public: A( void ) {} ~A( void ) { delete []m_pPtr; } void Create( int n ){ m_pPtr = new int[n]; } private: int *m_pPtr; }; 合理: class A { public: A( void ) : m_pPtr(0){} ~A( void ) { Clear(); } bool Create( int n ){ if ( m_pPtr ) return false; m_pPtr = new int[n]; return ture; } void Clear( void ) { delete []m_pPtr; m_pPtr = 0; } private: int *m_pPtr; }; 解析: 不合理的代码就在于当你重复调用Create的时候就会造成内存泄露,解决的办法就是 在new之前判断一下指针是否为0。要能够有效的执行这个判断,则必须在构造的时候对指 针进行初始化,并为这个类添加一个Clear函数来释放内存。 三、接上题的Create函数,你现在需要根据传入的参数做一些比较复杂的算法操作, 并对申请的数组赋值。 不合理: bool Create(int *a, int n ) { if ( m_pPtr ) return false; m_pPtr = new int[n]; for ( int i = 0; i n; i++ ) { m_pPtr[i] = 3 / a[i]; } return true; } 合理: template class auto_array { public: eXPlicit auto_array(_Ty *pPtr=0)throw():m_Ptr(pPtr){} ~auto_array(){delete[]m_Ptr;} void reset(_Ty *pPtr=0){if(pPtr!=m_Ptr){delete[]m_Ptr;m_Ptr=pPtr;}} _Ty* release(void){_Ty *pTemp=m_Ptr;m_Ptr=0;return pTemp;} private: auto_array(const auto_arrayother){} auto_array operator=(const auto_array other){} _Ty *m_Ptr; }; bool A::Create(int *a, int n ) { if ( m_pPtr ) return false; auto_array PtrGuard( new int[n] ); for ( int i = 0; i n; i++ ) { if ( 0 == a[i]

文档评论(0)

xingkongwd + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档