1、shared_ptr

shared_ptr除了最基本的可以用new初始化以外,还可以使用其他方式初始化。在使用一些c的api时候,这种初始化方式非常有用,如下

boost::shared_ptr<CURL> curl_(curl_easy_init(), curl_easy_cleanup);

上面这段代码用来初始化一个curl的shared_ptr。

 

2、promise,future

#include <boost/thread.hpp>
#include <boost/thread/future.hpp>
#include <iostream>

using namespace std;

int main()
{
    boost::promise<int> pi;
    boost::unique_future<int> fi;
    fi=pi.get_future();
    //等待2s,超时返回0,被promise被set返回1
    cout << "wait over:" << fi.timed_wait(boost::posix_time::milliseconds(2000)) << endl;
    //检查promise是否被set
    cout << "is ready:" << fi.is_ready() << endl;
    
    pi.set_value(42);
    cout << "wait over:" << fi.timed_wait(boost::posix_time::milliseconds(2000)) << endl;
    cout << "is ready:" << fi.is_ready() << endl;
    cout << fi.get() << endl;
}   

上面代码运行结果为

image

future和promise配合可以应用在各种多线程环境下。

比如有些异步api(如zookeeper的watch),提高了编程难度。当我们想要并不要求效率,或者对时序有要求时,可以使用promise和future将这些异步api改为同步

int main()
{
    boost::promise<int> pi; 
    boost::unique_future<int> fi = pi.get_future();
    char content[1024] = "\0";
    int size = 1024;
    zoo_wget(zk_handle, path, callback, static_cast<void*>(&pi), content, &size, NULL));
    fi.get();
}

void callback(zhandle_t* zh, int type, int state, const char* path, void* watcherCtx)
{
    boost::promise<int>* pi = static_cast<boost::promise<int>*>(watcherCtx);
    pi->set_value(1);
}

3、regex

match

    boost::regex r("(a*)ddd(b*)ddd");
    boost::smatch m;
    if(boost::regex_match(string("aaaadddbbbddd"), m, r)) 
    {   
        cout << m.size() << endl;
        for(size_t i = 0; i < m.size(); ++i)
        {   
            //0表示匹配到的整个字符串,1以后的index表示括号中匹配的内容
            cout << m[i] << endl;
        }   
    }

search

    boost::regex r("(a+)");
    string content = "bbbaaaaacccaaaaddddaaaeeeaaa";
    boost::smatch m;
    string::const_iterator strstart = content.begin();
    string::const_iterator strend = content.end();
    while(boost::regex_search(strstart, strend, m, r))
    {
	//search到的结果,0表示整个,1以后表示括号的index匹配的结果
        cout << m[1] << endl;
	//从上次搜索到的地方接着搜索
        strstart = m[0].second;
    }

regex_token_iterator

 
    boost::regex r("(a)c");
    string content = "bbbaaaaacccaaaaddddaaaeeeaaa";
    //第四个参数0表示匹配到的整个字符串,1以后表示括号中的index,-1表示匹配除了本字符串以外的,可以用来分割字符串
    boost::sregex_token_iterator iter(content.begin(), content.end(), r, -1);
    boost::sregex_token_iterator end;

    for(; iter != end; ++ iter)
    {
        cout<< *iter << endl;
    }

regex_replace

class func {
    public:
        func(vector<string> vec){
            _vec = vec;
            _index = 0;
        }   
        string aaa(boost::match_results<std::string::const_iterator> match){
            string  aa = _vec[_index];
            cout <<_index<<endl;
            _index++;
            cout <<_index<<endl;
            return aa;
        }   
    private:
        vector<string> _vec;
        int _index;
};      


int main(int argc, char* argv[])
{
    vector<string> test;
    test.push_back("1");
    test.push_back("2");
    test.push_back("3");
    test.push_back("4");
    test.push_back("5");
    test.push_back("6");
    test.push_back("7");
    std::string s="a ? b ?b c? d? e?";
    std::string b="a ? b ?b c? d? e?";
    std::cout << s << std::endl; 
    boost::regex reg("\\?");
    
    func f(test);
    boost::function<std::string (boost::match_results<std::string::const_iterator>)> function1 =
        boost::bind(&func::aaa, &f, _1);
    //替换s中的所有符合r的字符串
    //第三个参数可以放一个函数对象或者boost::function类型,用来实现特殊逻辑
    s=boost::regex_replace(s,reg,function1);
    std::cout << s << std::endl;
    return 0;
}

4、path

    namespace bf = boost::filesystem;
    string my_path = "/";
    bf::path file_path(my_path);
    bf::directory_iterator end_iter;
    //遍历目录下的文件
    for (bf::directory_iterator file_itr(file_path); file_itr != end_iter; ++file_itr)
    {   
        string fname = file_itr->path().filename().string();
        cout << fname << endl;
    } 
posted on 2015-07-23 23:06  misakamisaka  阅读(3075)  评论(0编辑  收藏  举报