第二周(Geek Band)

含有指针的类(经典案例  string)

Class with pointer member(s)    

拷贝构造 or 拷贝赋值

Big Three(凡带有指针类型,必须写的3个函数)

String(const String& str);  //拷贝构造

String& operator = (const String& str);  //拷贝复制

~String();  //析构函数(注意写法,与类名相同,前面加~;作用:将动态分配的内存释放掉)

编译器默认的  浅拷贝

                                                                                          深拷贝


如果没有自我赋值的检查,s2=s2,在第一步将自己的空间释放后,b也不存在了。这样程序出错。


输出函数的写法

stack与heap(栈与堆)


NEW(先分配内存 memory,再调用构造函数ctor)

DELETE(先调用析构函数 dtor,再释放内存 memory)


对于string而言,

上下cookie的作用——记录所给你的整个空间的大小;

灰色部分——debug状态下额外需要的空间;

string内只有一个指针,所以是4bit,加上灰色部分8×4,加上cookie2*4,共48,是16的倍数,所以没有pad;非debug状态,指针空间4,上下cookie 2×4,只有12,没有到16的边界,所以加一个pad(4),总共16



少了[ ],1的部分会被删掉,2,3没有被删掉,其他灰色部分最后清除了。结果2.3部分,造成了内存泄漏。

总结string(1-5 接口设计;6函数设计)

1.防卫式声明;

2.private中放指针,需求空间确定时,动态分配内存

private:char*  m_data;

3.构造函数(通常public,无返回类型!),一般给个默认值;

String(const char*  cstr=0);

4.big three:1.拷贝构造;2.拷贝复制;3.析构函数

String(const String&  str); 

String&  operator  =  (const String& str);

~ String(  );

5.考虑其它辅助函数情况(输出私有数据)

 char*   get_c_str( ) const { return m_data;}

6.将函数声明具体化

String::String(const char*  cstr=0);

构造函数



String::~String( );

析构函数


String::String(const String&  str);



拷贝构造


String&  operator  =  (const String& str);

拷贝复制(注意返回类型要写明,注意String::放的位置

定义输出函数

操作符重载

对类模板,函数模板及其它的进一步补充

1.static(静态)

语法:在静态数据 或 函数前加 static

静态函数,专为静态数据来准备。

成员函数自带 this point,写成员函数是()内一定不能写出this,但是{  } 内可以直接使用 this。调用对象,就是this


普通data members :如银行账户,每个人都是一个,static data members:如利率,所有账户的利率都是相同的,一份够了


static 使用方法(银行利率举例)


优化的 Singleton  设计模式,将a写在函数内的好处:没有人用的时候就不存在,产生调用后才出现a,不会消失,保证唯一1份

2.cout

3.类模板精华部分

template < typename T>
template <class T>  同template < typename T>相同


总结:前两个例子都是针对单一 class的 设计,即,基于对象的设计。

后面的内容都是针对 class 之间关系的探讨。

___________________________________________________________

关于指针(point)

关于空指针

p=NULL;p=0;p=nullptr; 三者相等。

C++标准规定,当一个指针类型的数值是0时,认为这个指针是空的。

空指针赋值分区

这一分区是进程的地址空间中从0x00000000 到 0x0000FFFF 的闭区间(64K 的内存大小),这 64K 的内存是一块保留内存,不能被程序动态内存分配器分配,不能访问,也不能使用,保留该分区的目的是为了帮助程序员捕获对空指针的赋值。如果进程中的线程试图读取或者写入位于这一分区内的内存地址,就会引发访问违规。

使用指针注意事项:

1.指针变量没有被初始化------(错误)

1、任何指针变量被刚创建时不会被自动初始化为NULL指针,它的缺省值是随机的。所以,指针变量在创建的同时应当被初始化,要么将指针设置为NULL,要么让它指向合法的内存。------(正确做法)

2.指针被free或者delete之后,没有设置为NULL,让人误以为这是一个合法指针------(错误)

2、free和delete只是把指针所指向的内存给释放掉,此时需手动将指针设置为null,否则可能引起程序错误------(正确做法)

3.指针操作超越了变量的作用范围------(错误)

3、由于C/C++中指针有++操作,因而在执行该操作的时候,稍有不慎,就容易指针访问越界,访问了一个不该访问的内存,结果程序崩溃;另一种情况是指针指向一个临时变量的引用,当该变量被释放时,此时的指针就变成了一个指向垃圾内存的指针------(正确做法)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • iOS面试小贴士 ———————————————回答好下面的足够了------------------------...
    不言不爱阅读 2,014评论 0 7
  • __block和__weak修饰符的区别其实是挺明显的:1.__block不管是ARC还是MRC模式下都可以使用,...
    LZM轮回阅读 3,387评论 0 6
  • ———————————————回答好下面的足够了---------------------------------...
    恒爱DE问候阅读 1,765评论 0 4
  • 多线程、特别是NSOperation 和 GCD 的内部原理。运行时机制的原理和运用场景。SDWebImage的原...
    LZM轮回阅读 2,043评论 0 12
  • 好久没有画石头了,久到我都不记得上一个石头是什么时候出生的。所以,今天花了一晚上画了三个萌萌哒~ 四个小...
    _aqu阅读 246评论 0 2