C11的新特性实在是太多了,这2个关键字关注的人倒是少了很多,其中有一个原因便是编译器支持得太慢了(VS到VS2013才支持上),不过这2个关键字那真是极为有用的,下面我们来看看。

【default关键字】
首先我们有一个字符串类:

  1. class CString
  2. {
  3. char* _str;
  4. public:
  5. //构造函数
  6. CString(const char* pstr) : _str(nullptr)
  7. {
  8. UpdateString(pstr);
  9. }
  10. //析构函数
  11. ~CString()
  12. {
  13. if (_str)
  14. free(_str);
  15. }
  16. public:
  17. void UpdateString(const char* pstr) throw()
  18. {
  19. if (pstr == nullptr)
  20. return;
  21. if (_str)
  22. free(_str);
  23. _str = (char*)malloc(strlen(pstr) + 1);
  24. strcpy(_str,pstr);
  25. }
  26. public:
  27. char* GetStr() const throw()
  28. {
  29. return _str;
  30. }
  31. };

我们可以这样使用:

  1. auto str = std::make_unique<CString>("123");
  2. printf(str->GetStr());

但是这样是不行的:

  1. auto str = std::make_unique<CString>(); //失败,因为没有一个无参构造函数

好,我们用default来:

  1. class CString
  2. {
  3. char* _str = nullptr;
  4. public:
  5. CString() = default;
  6. public:
  7. //构造函数
  8. CString(const char* pstr) : _str(nullptr)
  9. {
  10. UpdateString(pstr);
  11. }
  12. //析构函数
  13. ~CString()
  14. {
  15. if (_str)
  16. free(_str);
  17. }
  18. public:
  19. void UpdateString(const char* pstr) throw()
  20. {
  21. if (pstr == nullptr)
  22. return;
  23. if (_str)
  24. free(_str);
  25. _str = (char*)malloc(strlen(pstr) + 1);
  26. strcpy(_str,pstr);
  27. }
  28. public:
  29. char* GetStr() const throw()
  30. {
  31. return _str;
  32. }
  33. };

于是我们可以这样使用了:

  1. auto str_def = std::make_unique<CString>();
  2. str_def->UpdateString(“123”);
  3. printf(str_def->GetStr() == nullptr ? "None":str_def->GetStr());

【delete关键字】
假设我们有这样一个类,这个类是用于自动申请内存,进行RAII式管理:
(避免麻烦那些什么拷贝构造拷贝赋值移动构造什么的就不写了)

  1. template<typename T>
  2. class CStackMemoryAlloctor
  3. {
  4. mutable T* _ptr;
  5. public:
  6. explicit CStackMemoryAlloctor(size_t size) throw() : _ptr(nullptr)
  7. {
  8. _ptr = (T*)malloc(size);
  9. }
  10. ~CStackMemoryAlloctor()
  11. {
  12. if (_ptr)
  13. free(_ptr);
  14. }
  15. public:
  16. operator T*() const throw()
  17. {
  18. T* tmp = _ptr;
  19. _ptr = nullptr;
  20. return tmp;
  21. }
  22. public:
  23. T* GetPtr() const throw()
  24. {
  25. return _ptr;
  26. }
  27. };

我们这样使用这个类:

  1. CStackMemoryAlloctor<wchar_t> str(128);
  2. wchar_t* pstr = str.GetPtr();
  3. wcscpy(pstr,L"123\n");
  4. wprintf(pstr);

但是别人也可以这样使用:

  1. auto p = std::make_unique<CStackMemoryAlloctor<wchar_t>>(128);

因为这个类依然可以进行默认new,我们不想让人家进行new怎么办,老办法就是这样:

  1. private:
  2. void* operator new(std::size_t)
  3. {
  4. return nullptr;
  5. }

把new设置为private了,就行了,但是这样如果别人尝试new,那看到的错误提示简直惨不忍睹。。。
于是C11的delete人性化多了:

  1. public:
  2. void* operator new(std::size_t) = delete;

当尝试new的时候,提示十分友好,这个方法已被删除。
这个delete可以用来删任何你不爽的东西,比如拷贝构造,赋值拷贝什么鸡巴毛的东西。

原文转自:http://blog.csdn.net/a1875566250/article/details/40406883

原作者为 a1875566250. 请尊重原作者版权

C++11的default和delete关键字的更多相关文章

  1. c++11 类默认函数的控制:"=default" 和 "=delete"函数

    c++11 类默认函数的控制:"=default" 和 "=delete"函数 #define _CRT_SECURE_NO_WARNINGS #include ...

  2. c++11 类默认函数的控制:"=default" 和 "=delete"函数 void fun() = default; void fun()=delete;

    转自:lsgxeva #define _CRT_SECURE_NO_WARNINGS #include <iostream> #include <string> #includ ...

  3. c++基础知识_c++11 类默认函数的控制:"=default" 和 "=delete"函数

    #define _CRT_SECURE_NO_WARNINGS #include <iostream> #include <string> #include <vecto ...

  4. C++ default 和delete的新用法

    C++中的默认函数与default和delete用法一. 类中的默认函数a.类中默认的成员函数1.默认构造函数2.默认析构函数3.拷贝构造函数4.拷贝赋值函数5.移动构造函数6.移动拷贝函数 b.类中 ...

  5. C++中 =default 和 =delete 使用

    编译器默认为一个类生成的默认函数 默认构造函数 默认析构函数 默认拷贝构造函数 默认赋值函数 移动构造函数 移动拷贝函数 class DataOnly { public: DataOnly () // ...

  6. 【译】ASP.NET MVC 5 教程 - 11:Details 和 Delete 方法详解

    原文:[译]ASP.NET MVC 5 教程 - 11:Details 和 Delete 方法详解 在教程的这一部分,我们将研究一下自动生成的 Details 和Delete 方法. Details ...

  7. 4.C++中的函数重载,C++调用C代码,new/delete关键字,namespace(命名空间)

    本章主要内容: 1)函数重载 2)C++调用C代码 3)new/delete关键字实现动态内存分配 4)namespace命名空间 大家都知道,在生活中,动词和不同的名词搭配一起,意义都会大有不同,比 ...

  8. 在论坛中出现的比较难的sql问题:11(字符分拆 多关键字匹配问题)

    原文:在论坛中出现的比较难的sql问题:11(字符分拆 多关键字匹配问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉 ...

  9. default和delete

    在C++中,有四类特殊的成员函数,分别为:默认构造函数,默认析构函数,默认拷贝构造函数,默认赋值运算符.他们的作用为创建.初始化.销毁.拷贝对象. 虽然在类A中什么都没有定义,但是编译会通得过,因为编 ...

随机推荐

  1. linux shell 之 crontab(定时任务)详解

    1.定义: crontab命令常见于Unix和类Unix的操作系统之中,用于设置周期性被执行的指令.该命令从标准输入设备读取指令,并将其存放于“crontab”文件中,以供之后读取和执行.该词来源于希 ...

  2. Medusa引擎开源了

    首先贴出 Github地址 然后博客地址 相比于市面上其他的著名游戏引擎,例如Unity,cocos2dx,Unreal,Medusa游戏引擎目前还非常的简陋,目前实现的功能还集中在2D部分,3D的虽 ...

  3. 使用jMeter测试Solr服务接口

    之前一直用ab做简单的服务接口测试,ab功能强悍,使用简单,但是没有生成专题图和表格等功能,因此,我们决定使用jmeter来作为我们测试工具.接下来,我们将详细介绍jmeter使用的步骤,主要包括:j ...

  4. No resource found that matches the given name 'Theme.AppCompat.Light 的完美解决方案

    No resource found that matches the given name 'Theme.AppCompat.Light 的完美解决方案 首先这个问题的产生是由于缺少Theme.App ...

  5. Core Dump [Linux]

    I have known Core-Dump for a long time. But I just know it little. Now, I am about to study it.

  6. 单机搭建Android开发环境(三)

    单机搭建Android开发环境,第一篇重点介绍了如何优化Windows 7系统,以提高开发主机的性能并延长SSD的使用寿命.第二篇重点介绍了基于VMWare安装64位版的Ubuntu 12.04,并安 ...

  7. Unity StartCoroutine 和 yield return 深入研究

    http://www.cnblogs.com/fly-100/p/3910515.html

  8. 添加事件及Event对象的兼容写法

    一.事件流 事件流描述的是从页面中接受事件的顺序. IE的事件流是事件冒泡流,而Netscape的事件流是事件捕获流 1.事件冒泡 事件冒泡,即事件最开始由最具体的元素(文档中嵌套层次最深的那个节点) ...

  9. tyvj1098[luogu 2365]任务安排 batch

    题目描述 N个任务排成一个序列在一台机器上等待完成(顺序不得改变),这N个任务被分成若干批,每批包含相邻的若干任务.从时刻0开始,这些任务被分批加工,第i个任务单独完成所需的时间是Ti.在每批任务开始 ...

  10. 备战NOIP每周写题记录(一)···不间断更新

    ※Recorded By ksq2013 //其实这段时间写的题远远大于这篇博文中的内容,只不过那些数以百记的基础题目实在没必要写在blog上; ※week one 2016.7.18 Monday ...