zoukankan      html  css  js  c++  java
  • 第61课.智能指针类模板

    1.智能指针模板

    STL(头文件memory)中的智能指针模板:auto_ptr
    a.生命周期结束时,销毁指向内存的空间
    b.不能指向堆数组,只能指向堆对象(变量)
    c.一片堆空间只属于一个智能指针对象
    d.多个智能指针对象不能指向同一片堆空间(当多个智能指针指向同一堆空间时,auto_ptr会把之前的指针置为空,最后只保留最后一个智能指针指向这个空间)

    eg:

    #include <iostream>
    #include <string>
    #include <memory>
    
    using namespace std;
    
    class Test
    {
        string m_name;
    public:
        Test(const char* name)
        {
            cout << "Hello, " << name << ". " << endl;
            
            m_name = name;
        }
        
        void print()
        {
            cout << "I'm " << m_name << ". " << endl;
        }
        
        ~Test()
        {
            cout << "Goodbye, " << m_name << ". " << endl;
        }
    };
    
    int main()
    {
        auto_ptr<Test> pt(new Test("D.T.Software"));        // 智能指针类创建一个Test类型的指针pt
        
        cout << "pt = " << pt.get() << endl;        // 得到pt指针的地址
    
        pt->print();
        
        cout << endl;
        
        auto_ptr<Test> pt1(pt);     // 用pt来初始化pt1这个智能指针,理论上来说这里               
                                    // 应该是两个指针指向同一段内存空间,但事实上不是那样的
        cout << "pt  = " << pt.get() << endl;
        cout << "pt1 = " << pt1.get() << endl;
        
        return 0;
    }
    

    STL中的其他智能指针类

    share_ptr

     带有引用计数机制,支持多个指针对象指向同一内存空间

    weak_ptr

     配合share_ptr而引入的一种智能指针类

    unique_ptr

     一个指针对象指向一片内存空间,不能拷贝构造和赋值(即当多个指针指向同一片内存空间时,只是第一个有效)

  • 相关阅读:
    《淘宝技术这十年》读书总结
    广告:互联网公司的纽带
    广告:互联网公司的纽带
    定期存款要及时
    定期存款要及时
    Java实现蓝桥杯VIP算法训练 自行车停放
    Java实现蓝桥杯VIP算法训练 自行车停放
    Java实现蓝桥杯VIP算法训练 自行车停放
    Java实现蓝桥杯VIP算法训练 数组逆序排列
    Java实现蓝桥杯VIP算法训练 数组逆序排列
  • 原文地址:https://www.cnblogs.com/huangdengtao/p/12017612.html
Copyright © 2011-2022 走看看