• 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. FastDFS分布式文件系统研究

    FastDFS分布式文件系统 这个主要是针对应用型的,很使用,特别是对于电商等 一.编译安装 ubuntu平台: apt-get install libevent(这个默认就有,没有就装下) libe ...

  2. 3.linux(ubuntu)常用服务器搭建

    1 ftp 1.1 ftp服务器 1.安装vsftpd服务器 sudo apt-get install vsftpd 2.配置vsftpd.conf文件 sudo vi /etc/vsftpd.con ...

  3. c/c++ 比较好的开源框架

    作者:EZLippi链接:https://www.zhihu.com/question/19823234/answer/31632919来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转 ...

  4. 枚举所有排列-STL中的next_permutation

    枚举排列的常见方法有两种 一种是递归枚举 另一种是STL中的next_permutation //枚举所有排列的另一种方法就是从字典序最小排列开始,不停的调用"求下一个排列"的过程 ...

  5. c#常量如何使用

    c#中类中定义一个常量,在其他地方使用的时候使用类名.常量

  6. redis简单的事务

    Redis与 mysql事务的对比 占位 Mysql Redis 开启 start transaction muitl 语句 普通sql 普通命令 失败 rollback 回滚 discard 取消 ...

  7. indexOf实际试用方法

    用于搜索和查找关键字个数或者位置 例如: package zifu; public class tianqi { public static void main (String args[]){ St ...

  8. heavy dark--读《《暗时间》》

    本书名为<<暗时间>>,个人觉得是一个非常好的名字:1.迷茫的大学生有多少的业余时间,但又浪费多少的业余时间,浪费的这莫多时间就如同人在黑夜中一样,大脑是在休息的状态.这是第一 ...

  9. (转)硬盘结构,主引导记录MBR,硬盘分区表DPT,主分区、扩展分区和逻辑分区,电脑启动过程

    硬盘结构硬盘有很多盘片组成,每个盘片的每个面都有一个读写磁头.如果有N个盘片.就有2N个面,对应2N个磁头(Heads),从0.1.2开始编号.每个盘片的半径均为固定值R的同心圆再逻辑上形成了一个以电 ...

  10. oracle错误ORA-00604 递归sql级别1出现错误 ora-00942 表或试图不存在 ORA-06512 在line 11

    错误截图如下: 搜索了很多方法,但是都没有办法解决,不过最终还是找到了一个好的解决办法, 多谢那位仁兄的博客[http://blog.itpub.net/519536/viewspace-689469 ...