CAF(C++ actor framework)使用随笔(projection 用法)

Posted 浙江小麦

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了CAF(C++ actor framework)使用随笔(projection 用法)相关的知识,希望对你有一定的参考价值。

最近干活在写毕设,用到了CAF,看了文档,发现了一些小坑,自己摸索写点随笔。(CAF的github网站 https://github.com/actor-framework/actor-framework)里面的example文件夹例子不错。

但是感觉其实实际使用还是会有很多没讲到。

概念的东西可以看http://www.wfuyu.com/mvc/21278.html

我学习就看着http://www.actor-framework.org/manual/看下去看着不太会的就写例子,第一个坑就是3.5节的projection。

        

因为这个例子上的option是不对的,应该是optional(害我愣了一会~)

个人理解projection的意思就是 比如一个对象的回调函数期望获得一个int类型的参数传进来,但是别人给了它一个string类型的,那么projection机制就会先把他捕获,若它能够变为int就变成int被进入case1,如果不行,没关系,再用case2来捕获它就好了,毕竟人家传进来就不一定是要给case1用的。所以这个投影过程如果没成功也不是一个错误,只是说它匹配失败了。

下面贴上自己的代码 

#include <iostream>
#include "caf/all.hpp"
#include "caf/io/all.hpp"

using namespace std;
using namespace caf;

auto intproj = [](const string& str)-> optional<int> {
    char* endptr = nullptr;
    int result = static_cast<int>(strtol(str.c_str(), &endptr, 10));
    if (endptr != nullptr && *endptr == \'\\0\') 
        return result;
    return {};
};

message_handler fun(event_based_actor* self){
    return {
        on(intproj) >> [self](int i) {
        // case 1: successfully converted a string
        aout(self)<<"projection successfully\\n";
        return;
        },
        [self](const string& str) {
        // case 2: str is not an integer
        aout(self)<<"not projection \\n";
        return;
        },
        after(std::chrono::seconds(2))>>[self]{
            aout(self)<<"after 2 seconds fun self is quit\\n";
            self->quit();
        }
    };
}


void send_message(const actor& actor1){
    scoped_actor self;
    self->send(actor1,"1");
    self->send(actor1,"a");
}
int main(){
    auto actor1 = spawn(fun);
    send_message(actor1);    

    caf::await_all_actors_done();
    shutdown();
return 0; }

 

结果为

 

message_handler 和behavior 一样属于一种行为可以来生成一个actor。

CAF支持两种生成对象的方法,这里使用了最简单的以函数作为参数。

之前测试直接在main函数里用scoped_actor,那么程序就会永远等待,因为scoped_actor在函数结尾才会被quit,而

caf::await_all_actors_done();要等到所有此cpp文件中创建的actor都quit了才能继续执行下面的代码。

后来我又发现其实没必要把scoped_actor 另外搞一个函数 只要用{}把scoped_actor 包括起来就好。
就像

{
scoped_actor self;
self->send(actor1,"1");
self->send(actor1,"a");
}

在括号结束后self也会自动调用quit函数.

自己后来完了一下CAF序列,感觉功能非常的强大,直接传指针,C++中的类都不需要序列化。下次记录一下!

 

以上是关于CAF(C++ actor framework)使用随笔(projection 用法)的主要内容,如果未能解决你的问题,请参考以下文章

CAF(C++ actor framework)使用随笔(各种send通信用法)

C++ Actor并发模型框架 Actor Framework (CAF)

CAF(C++ actor framework)使用随笔(延迟发送,消息转发,消息优先级)

CAF(C++ actor framework)(序列化之类,无需序列化,直接传)

CAF(C++ actor framework)使用随笔(unbecome与keep_behavior用法)

我可以在 C++ Actor Framework 中使用 C++11 智能指针作为消息返回类型吗?