• ref引用不可以复制的对象

     void print(std::ostream &os, int i)
    {
    os << i << endl;
    } //ref引用不可以复制的对象
    void main1()
    {
    vector<int> myint = { ,,,, };
    //cout是不可以拷贝的对象,以下出错
    //boost::function<void(int)> pt = boost::bind(print, cout, _1);
    //ref可以引用不可以复制的对象
    boost::function<void(int)> pt = boost::bind(print,boost::ref(cout), _1);
    for_each(myint.begin(), myint.end(), pt);
    cin.get();
    }
  • 底层是基于hasn的unordered_set集合
     //底层是基于hasn的unordered_set集合
    void main5()
    {
    boost::unordered_set<string> myhash;
    myhash.insert("");
    myhash.insert("1234a");
    myhash.insert("1234b");
    for (auto ib = myhash.begin(), ie = myhash.end(); ib != ie; ib++)
    {
    cout << *ib << endl;
    }
    cin.get();
    }
  • 独享智能指针
     void main6()
    {
    boost::scoped_ptr<int> p1(new int());//智能指针
    boost::scoped_ptr<int> p2(new int[]);//智能指针,可以分配但是不推荐
    //不可以这样,因为是独享内存
    //boost::scoped_ptr<int> p3 = p2;
    //释放
    p2.reset();
    //重新分配内存
    p2.reset(new int());
    //获取第一个
    cout << *p2.get() << endl; //智能指针,存储数组
    boost::scoped_array<int> p(new int[]);
    p[] = ;
    *p.get() = ;
    //释放内存
    p.reset();
    //重新分配内存
    p.reset(new int[]);
    cin.get();
    }
  • 共享智能指针
     class AobjC
    {
    public:
    AobjC()
    {
    cout << "构造" << endl;
    }
    ~AobjC()
    {
    cout << "析构" << endl;
    }
    protected:
    private: }; void main7()
    {
    //共享内存
    boost::shared_ptr<AobjC> p1(new AobjC);
    boost::shared_ptr<AobjC> p2(new AobjC);
    //浅拷贝
    boost::shared_ptr<AobjC> p3(p2);
    p3.reset();
    p3.reset(new AobjC);
    //计数
    p3.use_count(); boost::shared_array<AobjC> p4(new AobjC[]);
    cin.get();
    }
  • 多线程不能用shared_ptr,要用weak_ptr
     //shared智能指针,多线程不安全
    //DWORD WINAPI printout(LPVOID p)
    //{
    // boost::shared_ptr<int> *pint = static_cast<boost::shared_ptr<int>*>(p);
    // for (int i = 0; i < 5; i++)
    // {
    // cout << **pint << endl;
    // Sleep(1000);
    // }
    // return 0;
    //}
    //
    //DWORD WINAPI reset(LPVOID p)
    //{
    // boost::shared_ptr<int>*pint = static_cast<boost::shared_ptr<int>*>(p);
    // //释放内存
    // pint->reset();
    // return 0;
    //} DWORD WINAPI printout(LPVOID p)
    {
    //weak_ptr接管指针
    //传递的是int指针的地址,所以要用boost::weak_ptr<int> *pw(多一个*保存)
       //传递地址要多加一个*(指针要多一级,便于多一次读取,第一次读存储的地址,第二次读内容)
    boost::weak_ptr<int> *pw = static_cast<boost::weak_ptr<int>*>(p);
    //弱指针可以锁定,防止多线程访问一个被释放的内存
    boost::shared_ptr<int> newp = pw->lock();
    for (int i = ; i < ; i++)
    {
    if (newp)
    {
    cout << *newp << endl;
    }
    else
    {
    cout << "内存释放无法访问" << endl;
    }
    Sleep();
    }
    return ;
    } DWORD WINAPI reset(LPVOID p)
    {
    Sleep();
    boost::shared_ptr<int>*pint = static_cast<boost::shared_ptr<int>*>(p);
    //释放内存
    pint->reset();
    return ;
    } void main()
    {
    boost::shared_ptr<int> p1(new int());
    //帮助在多线程中实现内存保护,没有重载*运算符
    boost::weak_ptr<int> p2 = p1;
    HANDLE threads[];
    threads[] = CreateThread(, , reset, &p1, , );
    threads[] = CreateThread(, , printout, &p2, , );
    //C++11也有weak_ptr
    //std::weak_ptr;
    cin.get();
    }
  • 正则表达式
     //正则表达式
    void main2()
    {
    string str = "china8848english";
    boost::regex expr("\\w+\\d+\\w+");//w+字符 d+数字
    cout << boost::regex_match(str, expr);
    cin.get();
    } //找出匹配的
    void main3()
    {
    string str = "china8engli5sh";
    boost::regex expr("(\\w+)\\d(\\w+)");
    //保存匹配的
    boost::smatch what;
    if (boost::regex_search(str, what, expr))
    {
    cout << what[] << endl;
    cout << what[] << endl;
    }
    else
    {
    cout << "fail";
    }
    } //替换
    void main4()
    {
    string str = "china8engli5sh";
    boost::regex expr("(\\w + )\\d(\\w + )");
    string rp = "--------";
    cout << boost::regex_replace(str, expr, rp);
    }

10.ref regex unordered_set smartpoint的更多相关文章

  1. 10 ref 和 out 之间的差别

    (1) 两者都是按地址传递的,使用后都将改变原来的数值 (2) ref传进去的參数必须在调用前初始化,out不必 (3) ref传进去的參数在函数内部能够直接使用,而out不可 (4) ref传进去的 ...

  2. .net正则表达式大全(.net 的 System.Text.RegularExpressions.Regex.Match()方法使用)

    正则表达式的本质是使用一系列特殊字符模式,来表示某一类字符串.正则表达式无疑是处理文本最有力的工具,而.NET的System.dll类库提供的System.Text.RegularExpression ...

  3. Vue学习笔记:Ref的使用

    官网上的说明 1.了解Vue中的$refs在Vue中是怎么访问到DOM元素的 <div id="app"> <h1>{{ message }}</h1 ...

  4. Regex分组与Pattern正则表达式对象

    1.正则规则:        1.String  regex  =  "[1-9]"          表示单个字符的取值范围是 1~9,注意是单个字符的取值范围        2 ...

  5. Django之Model操作

    Django之Model操作 本节内容 字段 字段参数 元信息 多表关系及参数 ORM操作 1. 字段 字段列表 AutoField(Field) - int自增列,必须填入参数 primary_ke ...

  6. django之一些feature

    前端之django一些feature 本节内容 cookie session 跨站请求保护 分页 序列化 model模块 CBV和FBV 模板渲染对象 1. cookie cookie 是一种发送到客 ...

  7. 【Django】--Model字段

    参考地址:http://www.cnblogs.com/wupeiqi/articles/6216618.html 所有字段 AutoField(Field) --int自增列,必须填入参数prima ...

  8. Python-Django进阶

    1. 路由系统 浏览器会自动给url后加一个"/" django会自动给路由的正则表达式前面加一个"/" django会给任何不带"/"结尾 ...

  9. 推荐的PHP编码规范

    推荐的PHP编码规范 发布时间: 2014-05-7 浏览次数:2754 分类: PHP教程 推荐的PHP编码规范 一 编辑器设置 1. 使用Tab缩进,不要使用空格 鉴于很多编辑器在保存文件时会自动 ...

随机推荐

  1. Linux就该这么学 20181008(第十三章BIND)

    参考链接https://www.linuxprobe.com Bind提供域名解析服务 DNS Domin Name Server 域名解析服务 功能模式 .正向解析,将域名解析为IP地址 .反向解析 ...

  2. 从极大似然估计的角度理解深度学习中loss函数

    从极大似然估计的角度理解深度学习中loss函数 为了理解这一概念,首先回顾下最大似然估计的概念: 最大似然估计常用于利用已知的样本结果,反推最有可能导致这一结果产生的参数值,往往模型结果已经确定,用于 ...

  3. CaffeNet用于Flickr Style数据集上的风格识别

    转自 http://blog.csdn.net/liumaolincycle/article/details/48501423 微调是基于已经学习好的模型的,通过修改结构,从已学习好的模型权重中继续训 ...

  4. Spark编程模型几大要素

    不多说,直接上干货! Spark编程模型几大要素 Driver Program 输入-Transformation-Action 缓存 共享变量

  5. 一.Windows I/O模型之选择(select)模型

    1.选择(select)模型:选择模型:通过一个fd_set集合管理套接字,在满足套接字需求后,通知套接字.让套接字进行工作.避免套接字进入阻塞模式,进行无谓的等待.选择模型的核心的FD_SET集合和 ...

  6. [ios] 如何调用其他app h5界面调用打开app

    参考资料:app唤醒app h5唤醒app 有趣的URL Scheme 被唤起端需要做的工作(demoApp): 1.设置URL Scheme  只是一个app的标识  具体是什么自己定  一个Sch ...

  7. Sentry: Python 实时日志平台

    Links https://docs.getsentry.com/on-premise/quickstart/ https://docs.getsentry.com/on-premise/server ...

  8. Android dex ,xml 文件反编译方法

    Dex 文件是Android上运行于delvik的java二进制文件,如果你对其中的内容感兴趣而开发人员没有公布源代码,你可以用如下方法反编译dex文件: 1 解压system.img 用xyaffs ...

  9. codeforces 567 E. President and Roads 【 最短路 桥 】

    给出一个有向图,从起点走到终点(必须走最短路),问一条边是否一定会被经过,如果不经过它,可以减小它的多少边权使得经过它(边权不能减少到0) 正反向建图,分别求出起点到每个点的最短距离,终点到每个点的最 ...

  10. nginx 日志配置不生效的问题

    log_format 有个默认的日志格式: log_format combined '$remote_addr - $remote_user [$time_local] ' ' "$requ ...