stdex.coroutine

C++11 非对称协程库
授权协议 Apache
开发语言 C/C++
所属分类 开发工具、 C/C++开发工具
软件类型 开源软件
地区 不详
投 递 者 巫马磊
操作系统 跨平台
开源组织
适用人群 未知
 软件概览

C++11 非对称协程库(只需要单独一个.h文件)

支持几个必备的协程原语(命名空间coroutine):

  • 创建协程:routine_t  create( std::function<void()>  f );

  • 销毁协程:void  destroy( routine_t  id );

  • 恢复协程执行:int  resume( routine_t  id );

  • 放弃协程执行:void  yield();

  • 等待异步任务结果:TYPE  await(TYPE(*f)());

  • 获取当前协程的ID:routine_t current();

  • SPSC通信模板类:class Channel<T>:支持push()/pop()操作;

 

#include <iostream>
#include <chrono>
//只需下载include此文件
#include "coroutine.h"

//SPSC通道,多个生产者或消费者,协程调度行为不好控制
coroutine::Channel<int> channel; 

string async_func()
{
    std::this_thread::sleep_for(std::chrono::milliseconds(3000));
    return "21";
}

void routine_func1()
{
    //从通道中获取消息,如果没有消息会yield
    int i = channel.pop();
    std::cout << i << std::endl;
	
    i = channel.pop();
    std::cout << i << std::endl;
}

void routine_func2(int i)
{
    std::cout << "20" << std::endl;

    //放弃当前协程的执行,返回恢复点
    coroutine::yield();
	
    std::cout << "21" << std::endl;
    
    //异步执行任务,如果任务无法立即执行完毕,会yield
    string str = coroutine::await(async_func);
    std::cout << str << std::endl;
}

void thread_func()
{
    //创建协称,回调函数形式为:std::function<void()>
    coroutine::routine_t rt1 = coroutine::create(routine_func1);
    coroutine::routine_t rt2 = coroutine::create(std::bind(routine_func2, 2));
    	
    std::cout << "00" << std::endl;

    //恢复rt1
    coroutine::resume(rt1);

    std::cout << "01" << std::endl;

    //恢复rt2
    coroutine::resume(rt2);
	
    std::cout << "02" << std::endl;
    //向通道推送消息
    channel.push(10);
	
    std::cout << "03" << std::endl;
    coroutine::resume(rt2);
	
    std::cout << "04" << std::endl;
    channel.push(11);
	
    std::cout << "05" << std::endl;

    //销毁协程。
    //建议:协程在执行完毕后统一释放,这样协程栈空间中的对象能够安全的被到释放。
    coroutine::destroy(rt1);
    coroutine::destroy(rt2);
}

int main()
{
    std::thread t1(thread_func);
    std::thread t2([](){
        //不支持跨线程的协程调度
    });
    t1.join();
    t2.join();
    return 0;
}
 相关资料
  • 本文向大家介绍Android对称加密与非对称加密,包括了Android对称加密与非对称加密的使用技巧和注意事项,需要的朋友参考一下 凯撒密码 1. 介绍 凯撒密码作为一种最为古老的对称加密体制,在古罗马的时候都已经很流行,他的基本思想是:通过把字母移动一定的位数来实现加密和解密。明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文。例如,当偏移量是3 的时候,所有的字母

  • 介绍 对于非对称加密,最常用的就是RSA和DSA,在Hutool中使用AsymmetricCrypto对象来负责加密解密。 非对称加密有公钥和私钥两个概念,私钥自己拥有,不能给别人,公钥公开。根据应用的不同,我们可以选择使用不同的密钥加密: 签名:使用私钥加密,公钥解密。用于让所有公钥所有者验证私钥所有者的身份并且用来防止私钥所有者发布的内容被篡改,但是不用来保证内容不被他人获得。 加密:用公钥加

  • 在本章中,我们将详细讨论对称和非对称密码术。 对称密码学 在这种类型中,加密和解密过程使用相同的密钥。 它也被称为secret key cryptography 。 对称密码术的主要特征如下 - 它更简单,更快捷。 双方以安全的方式交换钥匙。 缺点 (Drawback) 对称加密的主要缺点是,如果密钥泄漏给入侵者,则可以轻松更改消息,这被视为风险因素。 Data Encryption Standa

  • 本文向大家介绍C#对称加密与非对称加密实例,包括了C#对称加密与非对称加密实例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了C#对称加密与非对称加密的原理与实现方法,分享给大家供大家参考。具体分析如下: 一、对称加密(Symmetric Cryptography) 对称加密是最快速、最简单的一种加密方式,加密(encryption)与解密(decryption)用的是同样的密钥(secr

  • 主要内容:1.对称加密,2.非对称加密,3.混合加密,4.常见的摘要算法1.对称加密 AES,密钥长度有128/256/192。高级加密标准,是下一代的加密算法标准,速度快,安全级别高; DES:密钥为56, 数据加密标准,速度较快,适用于加密大量数据的场合。 3DES: 密钥为168.是基于DES,对一块数据用三个不同的密钥进行三次加密,强度更高。 IDES: 密钥为128 SM1: 密钥为128 SM4: 密钥为128 RC4, RC5, RC6 DESX 两边用

  • 本文向大家介绍非对称和对称多处理之间的区别,包括了非对称和对称多处理之间的区别的使用技巧和注意事项,需要的朋友参考一下 非对称多处理 非对称多处理是使用由一个主处理器处理的两个或多个处理器。所有CPU都是互连的,但不是自调度的。AMP用于根据任务的优先级和重要性将特定任务调度到CPU。 对称多处理 对称多处理是使用两个或多个共享公共内存空间的自调度处理器。每个处理器都可以访问I / O和存储设备。

  • 我想问一下,在使用非对称加密时,我们使用客户端的公钥加密数据,因此客户端可以使用他们的私钥解密数据,对吗? 我刚刚找到了使用RSA签署JWT的教程,但我发现它们使用服务器私钥而不是客户端的公钥加密数据,并且服务器的公钥在客户端之间共享。 安全吗?因为如果公钥因为可共享而落入坏人之手,每个人都可以正确解密? 那么,这样签jwt可以吗? 参考:教程1教程2

  • 我试图创建一个Android应用程序,它可以动态加密数据并将其写入存储。已经实现了没有加密的应用程序,在stackoverflow上查看了100个加密示例/帖子,但无法决定使用哪种方法。 一开始想到使用AES,就在谷歌上搜索它的安全性。每次输入16或32个字符(我希望安全性更好)的密码似乎并不方便。作为一种替代的非对称加密方式,人们想到了。用一个密钥加密,用另一个密钥解密,这样我就可以将用于加密的