grpc python异步实现_gRPC异步处理应答

下面代码经測试表明能够使用。

// Grpc异步应答处理。线程中执行.

void HandleGrpcResponses()

{

...

grpc::CompletionQueue & rCq = rMgr.GetCq();

for (;;)

{

void * pTag;

bool ok = false;

// Block until the next result is available in the completion queue "cq".

rCq.Next(&pTag, &ok);

// Act upon the status of the actual RPC.

std::unique_ptr pCb(static_cast(pTag));

const grpc::Status & rStatus = pCb->GetStatus();

if (rStatus.ok())

(*pCb)();  // run callback

}

}

IGrpcCb是回调类。定义例如以下:

class IGrpcCb

{

public:

explicit IGrpcCb(...) {};

virtual ~IGrpcCb(void) {};

grpc::ClientContext & GetContext() { return m_context; }

grpc::Status & GetStatus() { return m_status; }

public:

virtual void operator()() {};

protected:

grpc::ClientContext m_context;

grpc::Status m_status;

...

};

// R is response class like rpc::CreateRoomResponse.

template

class GrpcCb final : public IGrpcCb

{

public:

explicit GrpcCb(...)

: IGrpcCb(...)

{};

virtual ~GrpcCb(void) override {};

public:

typedef std::unique_ptr<:clientasyncresponsereader> > RpcPtr;

public:

R & GetResp() { return m_resp; }

void SetRpcPtrAndFinish(RpcPtr pRpc)

{

m_pRpc.swap(pRpc);

m_pRpc->Finish(&m_resp, &m_status, (void*)this);

}

public:

virtual void operator()() override

{

// Deal m_resp...

}

private:

RpcPtr m_pRpc;

R m_resp;

};

异步请求代码示比例如以下:

grpc::CompletionQueue & cq = GetCq();

rpc::CreateRoomRequest req;

// pGcb will be deleted in HandleGrpcResponses().

auto pGcb = new GrpcCb<:createroomresponse>(...);

pGcb->SetRpcPtrAndFinish(

m_pStub->AsyncCreateRoom(&pGcb->GetContext(), req, &cq));

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值