C与C++知识补遗.docVIP

  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与C知识补遗

C/C++知识补遗 栈空间的分配方式对普通的程序开发来讲是没有意义的,有系统来完成相关操作,但有时栈空间的分配方式又会显得很重要。栈的分配方式有两种,其一是从高地址空间向低地址空间分配,其二是从低地址空间向高地址空间分配。那么如何确定栈空间的分配方式呢,下述代码可以用来确定栈的分配方式。 int fun(){ static int * pnt = 0; if(pnt == 0){ int abc; pnt = abc; fun(); } else{ int bcd; if(pnt bcd){ printf(从高地址向低地址分配); // Windows的分配方式 } else{ printf(从低地址向高地址分配); } } return 0; } + 成员指针的用法。指针可以算作C/C++的短刀利器了,指向类成员的指针包括指向类数据成员的指针和指向类方法(函数)的指针,下述代码演示了这两种指针的用法 class AClass{ public: AClass():m_name(0), m_age(0) { }; AClass(const char * name); ~AClass(); public: void SayHello(); void SayOkay(); private: char * m_name; int m_age; public: typedef char * AClass::*PACName; // 引入新的类型(指向数据成员的指针) operator PACName() { return AClass::m_name; } // 执行类型转换 typedef int AClass::*PACAge; operator PACAge() { return AClass::m_age; } typedef void (AClass::*Say)(); // 指向成员函数的指针 }; int fun(void){ AClass a(AClass); AClass::Say func = AClass::SayHello(); (a.*func)(); // 调用成员函数 AClass * p = a; func = AClass::SayOkay; (p-*.func)(); // 调用成员函数 printf(%s\t%d\n, a.*AClass::PACName(a), a.*AClass::PACAge(a)); // 数据成员指针的使用。PS:是不是有些啰嗦?! } + 对象在内存中的布局。了解对象在内存中的布局,可以很方便的通过数据成员找到包含该数据成员的对象的地址,续而执行更多的操作,这是C/C++的一个奇技淫巧。下面是示例代码 struct A{ int a; double b; char c; } int fun(void){ A x; printf(%x,%x,%x,%x,%d\n, x, (x.a), (x.b), (x.c), sizeof(x)); // 运行结果:0x27AC48,0X27AC48,0X27AC50,0x27AC58,24(结构的大小是24而不是13!请参考相关文档) // 如果知道了x.a的地址,那么x的地址也就知道了。 return 0; } + new和delete操作符重载。new和delete操作符会经常用到,但对这两个操作符进行重载的却很少,通过这两个操作符的重载,很容易实现把文件当内存来用。还可以通过这两个操作符的重载,来跟踪内存的使用情况,诸如,是否有内存泄露等。 //完成内存使用的跟踪(通过重载全局new/delete操作符) void * operator new (size_t size, char * file, int line){ // 此处可以填写记录日志代码 return malloc(size); } void * operator delete(void * p){ // 此处可以填写记录日志代码 free(p); } #define NEW ::new #define DELETE ::delete // 接下来

文档评论(0)

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

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

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档