当前位置: 首页 > wzjs >正文

卖狗做网站什么关键词最好电商网站建设效果

卖狗做网站什么关键词最好,电商网站建设效果,wordpress用户站点,陕西省高速集团建设网站c11引入了三个智能指针,用来自动管理内存,使用智能指针可以有效地减少内存泄漏。 其中,shared_ptr是共享智能指针,可以被多次拷贝,拷贝时其内部的引用计数1,被销毁时引用计数-1,如果引用计数为…

c++11引入了三个智能指针,用来自动管理内存,使用智能指针可以有效地减少内存泄漏。

其中,shared_ptr是共享智能指针,可以被多次拷贝,拷贝时其内部的引用计数+1,被销毁时引用计数-1,如果引用计数为0,那么释放其所管理的资源

线程安全上,shared_ptr具有如下特点:

  • shared_ptr的引用计数是线程安全的
  • 修改shared_ptr不是线程安全的
  • 读写shared_ptr管理的数据不是线程安全的

具体可以参考:https://zhuanlan.zhihu.com/p/664993437

在网上找到的shared_ptr的手动实现都是线程不安全的,那么如何实现一个引用计数线程安全的shared_ptr呢?

参考:从零简单实现一个线程安全的C++共享指针(shared_ptr)-CSDN博客,本文在这篇博客的基础上增加了验证代码,并指出原有实现一个潜在的bug

#include <iostream>
#include <atomic>
#include <mutex>
#include <thread>
#include <vector>using namespace std;#define N 10000class Counter
{
public:Counter() { count = 1; }void add() {lock_guard<std::mutex> lk(mutex_);count++; }void sub() {lock_guard<std::mutex> lk(mutex_);count--;}int get() {lock_guard<std::mutex> lk(mutex_);return count; }private:int count;std::mutex mutex_;
};template <typename T>
class Sp
{
public:Sp();                           //默认构造函数~Sp();                          //析构函数Sp(T *ptr);                     //参数构造函数Sp(const Sp &obj);              //复制构造函数Sp &operator=(const Sp &obj);   //重载=T *get();                       //得到共享指针指向的类int getcount();                 //得到引用计数器
private:T *my_ptr;                      //共享指针所指向的对象Counter* counter;                   //引用计数器void clear();                   //清理函数
};//默认构造函数,参数为空,构造一个引用计数器
template<typename T>
Sp<T>::Sp()
{my_ptr = nullptr;counter = new Counter();
}//复制构造函数,新的共享指针指向旧的共享指针所指对象
template<typename T>
Sp<T>::Sp(const Sp &obj)
{//将所指对象也变为目标所指的对象my_ptr = obj.my_ptr;//获取引用计数器,使得两个共享指针用一个引用计数器counter = obj.counter;//使这个对象的引用计数器+1counter->add();	
};//重载=
template<typename T>
Sp<T> &Sp<T>::operator=(const Sp&obj)
{//清理当前所引用对象和引用计数器clear();//指向新的对象,并获取目标对象的引用计数器my_ptr = obj.my_ptr;counter = obj.counter;//引用计数器+1counter->add();//返回自己return *this;	
}//创建一个共享指针指向目标类,构造一个新的引用计数器
template<typename T>
Sp<T>::Sp(T *ptr)
{my_ptr = ptr;counter = new Counter();
}//析构函数,出作用域的时候,调用清理函数
template<typename T>
Sp<T>:: ~Sp()
{clear();
}//清理函数,调用时将引用计数器的值减1,若减为0,清理指向的对象内存区域
template<typename T>
void Sp<T>::clear()
{//引用计数器-1counter->sub();//如果引用计数器变为0,清理对象if(0 == counter->get()){// 这里有个bug,如果在此间隙处,有另外一个地方执行了share ptr的copy操作,则会crashif(my_ptr){delete my_ptr;}delete counter;}
}//当前共享指针指向的对象,被几个共享指针所引用
template<typename T>
int Sp<T>::getcount()
{return counter->get();	
};class A{
public:A(){ cout<<"A construct!"<<endl; };~A() { cout<<"A destruct!"<<endl; };
};Sp<A> sp(new A);
std::vector<Sp<A>> vec1(N);
std::vector<Sp<A>> vec2(N);Sp<A> sp1(new A);
Sp<A> sp2(new A);
Sp<A> sp3(new A);void thread_func1() {for(int i = 0; i < N; i++) {vec1[i] = sp;}
}void thread_func2() {for(int i = 0; i < N; i++) {vec2[i] = sp;}
}void test_crash_func1() {sp1 = sp2;
}void test_crash_func2() {sp3 = sp1;
}void test_crash() {for(int i = 0; i < 10 * N; i++) {std::thread t1(test_crash_func1);std::thread t2(test_crash_func2);t1.join();t2.join();}
}int main()
{std::thread t1(thread_func1);std::thread t2(thread_func2);t1.join();t2.join();std::cout<<"the count is:"<<sp.getcount()<<std::endl;test_crash();
}

按理说调用test_crash应该会导致crash才对,但是不知道为什么没有crash

TODO:使用原子操作实现,对比性能

http://www.dtcms.com/wzjs/587052.html

相关文章:

  • 行政机关单位网站建设要求电脑报价网站
  • 门户网站开发公司平台做网站什么时候要用到虚拟主机
  • 浅谈高校门户网站建设的规范标准舟山新闻最新消息
  • 温州小学网站建设开发网站需要什么硬件
  • 招聘网站有哪些易县做网站
  • 手机直播网站开发卡盟自助网站建设
  • 顺德网站制作案例平台360平台推广
  • 网站公告弹窗源码一级域名购买
  • 电商网站改版wordpress多用户商城系统
  • 网站公司做的网站经常打不开百度推广网页版
  • 基于django的电子商务网站开发成都网站seo报价
  • 没有主机怎么做自己的网站手机网站Com
  • 商业网站源码个人网站模板设计步骤
  • 做投票网站的系统优化是什么意思
  • 自学网站建设基本流程做外贸学英语的网站
  • 网站建站推荐巴中建网站的公司
  • 网站框架都有什么用东阳网站建设yw81
  • 如何增加企业网站被收录的几率网站关键词怎么优化排名
  • 购买网站空间的注意事项做h的游戏 迅雷下载网站
  • 眉山市做网站的公司山东东营市东营区
  • 如何建设微信网站视频拍摄公司推荐
  • 深圳网站提升排名关键词搜索工具有哪些
  • 国内无版权图片网站网站怎么设计
  • 如何注册一个网站wordpress更新需要连接ftp
  • 如何跟进网站建设的客户柳州最好的网站推广公司
  • 杭州网站建设公司联系方式天津网站制作专业
  • dw创建网站导航栏菜单怎么做江宁区住房建设局网站
  • 网站自己做流量江苏建设科技网
  • 网站推广排名教程下载百度导航最新版本
  • 有没有专业做效果图的网站交易链接