【面试总结】C++手写智能指针shared_ptr

在这里插入图片描述

简介

Hello!
非常感谢您阅读海轰的文章,倘若文中有错误的地方,欢迎您指出~
 
ଘ(੭ˊᵕˋ)੭
昵称:海轰
标签:程序猿|C++选手|学生
简介:因C语言结识编程,随后转入计算机专业,获得过国家奖学金,有幸在竞赛中拿过一些国奖、省奖…已保研
学习经验:扎实基础 + 多做笔记 + 多敲代码 + 多思考 + 学好英语!
 
唯有努力💪
 
本文仅记录自己感兴趣的内容

shared_ptr

代码

#include <iostream>
#include <memory>
using namespace std;

namespace smart_pointer
{
   

    template <typename T>
    struct defaultDeleter
    {
   
        void operator()(const T *ptr)
        {
   
            if (ptr)
            {
   
                delete ptr;
                ptr = nullptr;
            }
        }
    };

    template <typename T, typename Deleter = defaultDeleter<T>>
    class shared_ptr
    {
   
    public:
        shared_ptr();
        shared_ptr(T *ptr);
        shared_ptr(const shared_ptr &sp); // 拷贝构造
        shared_ptr(shared_ptr &&sp);      // 移动构造
        ~shared_ptr();

        T *operator->() const;
        T &operator*() const;
        operator bool() const;

        shared_ptr &operator=(const shared_ptr &sp);
        shared_ptr &operator=(shared_ptr &&sp);

        T *get() const;
        void reset(T *ptr);
        void swap(shared_ptr &sp);
        int count();

    private:
        atomic<int> *use_count;
        T *ptr;
    };

    template <typename T, typename Deleter>
    shared_ptr<T, Deleter>::shared_ptr()
    {
   
    }

    template <typename T, typename Deleter>
    shared_ptr<T, Deleter>::shared_ptr(T *_ptr)
        : ptr(_ptr), use_count(new atomic<int>(1))
    {
   
    }

    template <typename T, typename Deleter>
    shared_ptr<T, Deleter>::shared_ptr(const shared_ptr &sp)
        : ptr(sp.ptr), use_count(sp.use_count)
    {
   
        ++*use_count;
    }

    template <typename T, typename Deleter>
    shared_ptr<T, Deleter>::shared_ptr(shared_ptr &&sp)
    {
   
        std::swap(ptr, sp.ptr);
        std::swap(use_count, sp.use_count);
    }

    template <typename T, typename Deleter>
    shared_ptr<T, Deleter>::~shared_ptr()
    {
   
        if (ptr)
        {
   
            --*use_count;
            if (*use_count <= 0)
            {
   
                Deleter()(ptr);
                delete use_count;
                cout << "shared_ptr dctor" << endl;
            }
        }
    }

    template <typename T, typename Deleter>
    T *shared_ptr<T, Deleter>::operator->() const
    {
   
        return ptr;
    }

    template <typename T, typename Deleter>
    T &shared_ptr<T, Deleter>::operator*() const
    {
   
        return *ptr;
    }

    template <typename T, typename Deleter>
    shared_ptr<T, Deleter>::operator bool() const
    {
   
        return ptr != nullptr;
    }

    /* 异常安全赋值 */
    template <typename T, typename Deleter>
    shared_ptr<T, Deleter> &shared_ptr<T, Deleter>::operator=(const shared_ptr<T, Deleter> &sp)
    {
   
#if 1
        // copy and swap
        shared_ptr<T, Deleter> tmp(sp);
        swap(tmp);
        return *this;
#else
        // 自我赋值
        if (sp.ptr == ptr)
            return *this;

        ptr = sp.ptr;
        use_count = sp.use_count;
        ++*use_count;
        return *this;
#endif
    }

    template <typename T, typename Deleter>
    shared_ptr<T, Deleter> &shared_ptr<T, Deleter>::operator=(shared_ptr<T, Deleter> &&sp)
    {
   
        std::swap(ptr, sp.ptr);
        std::swap(use_count, sp.use_count);
        return *this;
    }

    template <typename T, typename Deleter>
    T *shared_ptr<T, Deleter>::get() const
    {
   
        return ptr;
    }

    template <typename T, typename Deleter>
    void shared_ptr<T, Deleter>::reset(T *_ptr)
    {
   
        shared_ptr<T, Deleter>().swap(*this);

        ptr = _ptr;
        use_count = new atomic<int>(1);
    }

    template <typename T, typename Deleter>
    void shared_ptr<T, Deleter>::swap(shared_ptr<T, Deleter> &sp)
    {
   
        std::swap(ptr, sp.ptr);
        std::swap(use_count, sp.use_count);
    }

    template <typename T, typename Deleter>
    int shared_ptr<T, Deleter>::count()
    {
   
        return *use_count;
    }

}; // namespace smart_pointer

int main(int argc, char *argv[])
{
   
    {
   
        smart_pointer::shared_ptr<int> p(new int(12));
        smart_pointer::shared_ptr<int> p1(p);
        *p1 = 2;
        cout << *p << endl;
        cout << p.count() << endl;

        // 异常安全测试
        p = p;
        cout << *p << endl;
        cout << p.count() << endl;
    }

    {
   
        smart_pointer::shared_ptr<int> p(new int(12));
        p.reset(new int(13));
        cout << *p << endl;

        // 右值赋值测试
        p = smart_pointer::shared_ptr<int>(new int(14));
        cout << *p << endl;

        // 移动构造测试
        smart_pointer::shared_ptr<int> p1(smart_pointer::shared_ptr<int>(new int(15)));
        cout << *p1 << endl;
    }

    return 0;
}

实验结果

在这里插入图片描述

简化版

面试时上面代码很难在短时间内写完,可以参考下面的代码

#include <iostream>
#include <memory>
using namespace std;

namespace smart_pointer
{
   
    template <typename T>
    struct defaultDeleter
    {
   
        void operator()(const T *ptr)
        {
   
            if (ptr)
            {
   
                delete ptr;
                ptr = nullptr;
            }
        }
    };
    template <typename T, typename Deleter = defaultDeleter<T>>
    class shared_ptr
    {
   
    public:
        shared_ptr();
        shared_ptr(T *ptr);
        shared_ptr(const shared_ptr &sp);
        shared_ptr(shared_ptr &&sp);
        ~shared_ptr();
        // T *operator->() const;
        T &operator*() const;
        int count();
        // shared_ptr &operator=(const shared_ptr &sp);
        // shared_ptr &operator=(shared_ptr &&sp);
    private:
        atomic<int> *use_count;
        T *ptr;
    };
    template <typename T, typename Deleter>
    shared_ptr<T, Deleter>::shared_ptr()
    {
   
    }
    template <typename T, typename Deleter>
    shared_ptr<T, Deleter>::shared_ptr(T *_ptr)
        : ptr(_ptr), use_count(new atomic<int>(1))
    {
   
    }
    template <typename T, typename Deleter>
    shared_ptr<T, Deleter>::shared_ptr(const shared_ptr &sp)
        : ptr(sp.ptr), use_count(sp.use_count)
    {
   
        ++*use_count;
    }
    template <typename T, typename Deleter>
    shared_ptr<T, Deleter>::shared_ptr(shared_ptr &&sp)
    {
   
        std::swap(ptr, sp.ptr);
        std::swap(use_count, sp.use_count);
    }
    template <typename T, typename Deleter>
    shared_ptr<T, Deleter>::~shared_ptr()
    {
   
        if (ptr)
        {
   
            --*use_count;
            if (*use_count <= 0)
            {
   
                Deleter()(ptr);
                delete use_count;
                cout << "shared_ptr dctor" << endl;
            }
        }
    }

    template <typename T, typename Deleter>
    T &shared_ptr<T, Deleter>::operator*() const
    {
   
        return *ptr;
    }

    template <typename T, typename Deleter>
    int shared_ptr<T, Deleter>::count()
    {
   
        return *use_count;
    }
};

int main()
{
   
    smart_pointer::shared_ptr<int> p(new int(12));
    smart_pointer::shared_ptr<int> p1(p);

    *p = 33;
    cout << *p << endl;
    cout << p.count() << endl;
    return 0;
}

在这里插入图片描述

面试实战

智能指针被问到多次,一般都是先简单按照自己的理解解释c++智能指针,然后有些面试官会要求自己手写一遍,如果可以仔细研究此代码,还是可以学到很多知识点的。

手写智能指针在今年的大厂面试中,自己也是遇到了多次,基本上有会要求手写一点,时间大概10分钟左右,所以平时在复习的时候,一定要十分熟练。开始的时候,自己以为看懂了就行了,结果在面试中高压环境下写代码的时候,会犯很多的错误,所以平时一定要自己多练习,规定时间内熟练的写出来。

相关推荐

  1. 面试代码总结

    2024-01-09 12:58:01       29 阅读
  2. C++,智能指针详解(面试

    2024-01-09 12:58:01       26 阅读
  3. C++面向对象:智能指针讲解

    2024-01-09 12:58:01       18 阅读
  4. C++面试之线程池、智能指针、设计模式

    2024-01-09 12:58:01       32 阅读
  5. c++的bitset

    2024-01-09 12:58:01       8 阅读
  6. 面试题,soft_nms

    2024-01-09 12:58:01       44 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-09 12:58:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-09 12:58:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-09 12:58:01       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-09 12:58:01       20 阅读

热门阅读

  1. ubuntu18.04 添加python3.8环境

    2024-01-09 12:58:01       34 阅读
  2. VR思政情景实训教学

    2024-01-09 12:58:01       37 阅读
  3. 【计算机网络】网络层IP包头与路由原理

    2024-01-09 12:58:01       37 阅读
  4. 数据结构-怀化学院期末题(56)

    2024-01-09 12:58:01       31 阅读
  5. vue项目中px单位转rem插件

    2024-01-09 12:58:01       36 阅读
  6. 微服务架构+服务注册中心+Nacos和Eureka+比较分析

    2024-01-09 12:58:01       38 阅读
  7. Spring Boot CLI 中文文档

    2024-01-09 12:58:01       37 阅读
  8. 编程语言--C/C++、python

    2024-01-09 12:58:01       30 阅读
  9. C++类模板分文件编写

    2024-01-09 12:58:01       35 阅读
  10. 【复习】人工智能 第一章 绪论

    2024-01-09 12:58:01       28 阅读