windows C++ 并行编程-异步代理库概述

异步代理库(简称代理库)提供了一个编程模型,该模型可提高支持并发的应用程序开发的可靠性。 代理库是一个 C++ 模板库,为粗粒度数据流和管道任务提升了基于角色的编程模型和进程内消息传递。 代理库构建在并发运行时的计划和资源管理组件上。

编程模型

代理库通过一个基于数据流而不是控制流的异步通信模型来连接隔离的组件,从而提供共享状态的替代方法。 数据流是指计算是在所有必需数据可用时进行的编程模型;控制流是指以预先确定的顺序进行计算的编程模型。

数据流编程模型与消息传递这一概念相关,其中程序的独立组件通过发送消息相互通信。

代理库由以下三个组件组成:异步代理、异步消息块和消息传递函数。 代理会维护状态,使用消息块和消息传递函数相互通信,并与外部组件通信。 消息传递函数使代理能够向外部组件发送消息,以及从其接收消息。 异步消息块可保存消息,并使代理能够以同步的方式进行通信。

下图显示了两个代理如何使用消息块和消息传递函数进行通信。 在此图中,通过使用 concurrency::send 函数和 concurrency::unbounded_buffer 对象,agent1 将消息发送到 agent2。 agent2 使用 concurrency::receive 函数读取消息。 agent2 使用相同的方法将消息发送到 agent1。 虚线箭头表示代理之间的数据流。 实心箭头将代理连接到可供写入内容或读取内容的消息块。

代理编程模型相对于其他并发和同步机制(例如事件)具有多项优势。 一项优势是,通过使用消息传递在对象之间传输状态更改,可以隔离对共享资源的访问,从而提高可伸缩性。 消息传递的优势是,它将同步绑定到数据,而不是将其绑定到外部同步对象。 这简化了组件之间的数据传输,可以消除应用程序中的编程错误。 

何时使用代理库

如果有多个必须以异步方式相互通信的操作,请使用代理库。 消息块和消息传递函数允许你编写并行应用程序,无不要求同步机制(例如锁)。 这使你可以专注于应用程序逻辑。

代理编程模型通常用于创建数据管道或网络。 数据管道是一系列组件,每个组件执行一个有助于实现更大目标的特定任务。 数据流管道中的每个组件会在收到来自另一组件的消息时执行工作。 该工作的结果将传递到管道或网络中的其他组件。

示例

以下示例实现本主题前面所示的插图:

// basic-agents.cpp
// compile with: /EHsc
#include <agents.h>
#include <string>
#include <iostream>
#include <sstream>using namespace concurrency;
using namespace std;// This agent writes a string to its target and reads an integer
// from its source.
class agent1 : public agent 
{
public:explicit agent1(ISource<int>& source, ITarget<wstring>& target): _source(source), _target(target){}protected:void run(){// Send the request.wstringstream ss;ss << L"agent1: sending request..." << endl;wcout << ss.str();send(_target, wstring(L"request"));// Read the response.int response = receive(_source);ss = wstringstream();ss << L"agent1: received '" << response << L"'." << endl;wcout << ss.str();// Move the agent to the finished state.done();}private:   ISource<int>& _source;ITarget<wstring>& _target;
};// This agent reads a string to its source and then writes an integer
// to its target.
class agent2 : public agent 
{
public:explicit agent2(ISource<wstring>& source, ITarget<int>& target): _source(source), _target(target){}protected:void run(){// Read the request.wstring request = receive(_source);wstringstream ss;ss << L"agent2: received '" << request << L"'." << endl;wcout << ss.str();// Send the response.ss = wstringstream();ss << L"agent2: sending response..." << endl;wcout << ss.str();send(_target, 42);// Move the agent to the finished state.done();}private:   ISource<wstring>& _source;ITarget<int>& _target;
};int wmain()
{// Step 1: Create two message buffers to serve as communication channels// between the agents.// The first agent writes messages to this buffer; the second// agents reads messages from this buffer.unbounded_buffer<wstring> buffer1;// The first agent reads messages from this buffer; the second// agents writes messages to this buffer.overwrite_buffer<int> buffer2;// Step 2: Create the agents.agent1 first_agent(buffer2, buffer1);agent2 second_agent(buffer1, buffer2);// Step 3: Start the agents. The runtime calls the run method on// each agent.first_agent.start();second_agent.start();// Step 4: Wait for both agents to finish.agent::wait(&first_agent);agent::wait(&second_agent);
}

该示例产生下面的输出:

agent1: sending request...
agent2: received 'request'.
agent2: sending response...
agent1: received '42'.
异步代理

异步代理(或简称为代理)是一个应用程序组件,它与其他代理异步工作以解决大型计算任务。 将代理视为具有固定生命周期的任务。 例如,一个代理可能会从输入/输出设备(例如键盘、磁盘上的文件或网络连接)读取数据,而另一个代理可能会在该数据可用时对其执行操作。 第一个代理使用消息传递来通知第二个代理有更多数据可用。 并发运行时任务计划程序提供了一种高效的机制,可以使代理协同阻止和暂停,而无需低效率的抢占。

代理库定义了 concurrency::agent 类来表示异步代理。 agent 是一个声明虚拟方法 concurrency::agent::run 的抽象类。 run 方法执行由代理执行的任务。 由于 run 是抽象的,因此必须在派生自 agent 的每个类中实现此方法。

代理生命周期

代理具有固定的生命周期。 concurrency::agent_status 枚举定义代理的各种状态。 下图是一个状态图,显示代理如何从一个状态发展到另一个状态。 在此图中,实线表示从应用程序调用的方法;虚线表示从运行时调用的方法。

下表描述了 agent_status 枚举中的每种状态。 

agent_created 是代理的初始状态,agent_runnable 和 agent_started 是活动状态,agent_done 和 agent_canceled 是终端状态。

使用 concurrency::agent::status 方法检索 agent 对象的当前状态。 尽管 status 方法是并发安全的方法,但代理的状态可能会在 status 方法返回时发生变化。 例如,调用 status 方法时,代理可能处于 agent_started 状态,但在 status 方法返回后立即转为 agent_done 状态。

方法和功能

下表显示了属于 agent 类的一些重要方法。 

创建代理对象后,调用 concurrency::agent::start 方法来计划它的执行。 运行时在计划代理并将其设置为 agent_runnable 状态后调用 run 方法。 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/143914.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

Windows系统通过部署wsl + Goland进行跨平台开发

1.背景 近期项目中因为用到了 Golang库中的 "log/syslog" 包,而这个包是禁止在windows平台上编译的. 并且在windows环境上开发也会有诸多不便,如执行makefile文件的make命令,本地开发环境中docker,etcd,redis的搭建等等,而这些通过部署wsl去搭建一个linux环境就很可以…

如何使用下拉字段创建WordPress表单(简单方法)

许多网站所有者在收集用户输入时&#xff0c;都会因为表单过长而让用户感到压迫。 下拉列表字段通过提供一个简洁的选项列表&#xff0c;使表单变得更简单。这意味着它们可以提高表单完成率&#xff0c;并改善用户体验。 在本文中&#xff0c;我们将向您展示如何创建带有下拉…

Kubernetes从零到精通(11-CNI网络插件)

Kubernetes网络模型 Kubernetes的网络模型&#xff08;Kubernetes Networking Model&#xff09;旨在提供跨所有节点、Pod和服务的统一网络连接。它的核心理念是通过统一的网络通信规则&#xff0c;保证集群中的所有组件能够顺畅地相互通信。Kubernetes网络模型主要有以下几个关…

专业学习|随机规划概观(性质、针对问题与分类)

一、随机规划概观 随机规划&#xff08;Stochastic Programming&#xff09;是一种用于处理决策问题中的不确定性的优化方法。它能够在决策过程中考虑到未来的不确定性&#xff0c;从而帮助找到在不同情境下都能较好表现的解决方案。以下是随机规划能解决的一些主要问题以及它的…

阿里巴巴搜索API返回值:电商市场竞争的新武器含

阿里巴巴搜索API返回值在电商市场竞争中扮演着至关重要的角色&#xff0c;它为企业提供了深入了解市场、分析竞争对手的宝贵资源。以下是对阿里巴巴搜索API返回值及其在电商市场竞争中应用的详细解析&#xff0c;并附上示例代码。 一、阿里巴巴搜索API返回值概述 阿里巴巴搜索…

超大酒店司机收布草-酒店分层管理--酒店布草洗涤

一、大酒店布草分层管理 1. 提高效率 - 对布草进行分层&#xff0c;可以更有针对性地安排收集和分发流程&#xff0c;减少混乱和等待时间&#xff0c;提高整体运营效率。 2. 质量控制 - 不同层级的布草可能有不同的质量标准和使用场景。分层管理有助于确保每个层级的…

2024年第五届“华数杯”全国大学生数学建模竞赛 A题详细思路+详细matlab代码

没有更新完之前,专栏价格为59,更新完毕之后恢复到99. 专栏内包含2024年所有数学建模比赛思路和代码,有些重要比赛着重更新(华数杯、国赛、美赛),小比赛可能会有chatgpt4更新,只需订阅一次。有些文章没有完整代码,请到专栏内查找最新代码和思路。如果比赛结束后没有更新…

Web后端开发技术:RESTful 架构详解

RESTful 是一种基于 REST&#xff08;表述性状态转移&#xff0c;Representational State Transfer&#xff09;架构风格的 API 设计方式&#xff0c;通常用于构建分布式系统&#xff0c;特别是在 Web 应用开发中广泛应用。REST 是一种轻量级的架构模式&#xff0c;利用标准的 …

大语言模型超参数调优:开启 AI 潜能的钥匙

前言 在人工智能的广袤领域中&#xff0c;大语言模型&#xff08;LLM&#xff09;凭借其强大的实力&#xff0c;不断重塑着我们对机器理解语言的认知。然而&#xff0c;要使这些模型在特定应用场景中发挥最大效能&#xff0c;关键在于巧妙调整其超参数。本文将引领你深入探究 …

【SSM-Day2】第一个SpringBoot项目

运行本篇中的代码&#xff1a;idea专业版或者idea社区版本&#xff08;2021.1~2022.1.4&#xff09;->这个版本主要是匹配插件spring boot Helper的免费版(衰) 【SSM-Day2】第一个SpringBoot项目 框架->Spring家族框架快速上手Spring BootSpring Boot的作用通过idea创建S…

Kettle报错:使用mysql向hive中插入数据只能插入两条的错误

错误展示 我们在用kettle&#xff0c;使用mysql向hive中插入数据的时候&#xff0c;创建好了一个转换&#xff0c;里面的操作也全部完成了之后&#xff0c;在执行时爆出一下错误 例如我这里写入的表输入为&#xff1a; 表输出为&#xff1a; 解决办法 看起来是一点问题也没有…

HFSS 常见仿真警告、报错及bug处理

目录 引言提示信息警告信息报错信息导入csv文件报错 内部bugHFSS切换工程文件&#xff0c;视图窗口卡顿 引言 本文主要用于收录HFSS仿真中常见的错误及处理方法。欢迎大家在评论区贴出自己的报错信息&#xff0c;一起讨论分享。 提示信息 提示信息&#xff1a;Port 7 suppor…

C++调用C# DLL之踩坑记录

C是非托管代码&#xff0c;C#则是托管代码&#xff0c;无法直接调用 CLR的介绍见CLR简介 MSDN提到了两种非托管-托管的交互技术&#xff1a;CLR Interop和COM Interop 后者要将C# 类库注册为COM组件&#xff0c;本文只探讨CLR&#xff0c;要通过C CLR写中间层代码 方式一&…

htaccess转换nginx工具

115工具网为您提供htaccess与nginx在线转换,apache伪静态文件转为nginx重写规则,htaccess伪静态规则换nginx,apache RewriteRule转rewrite,apache伪静态文件转nginx重写,apache转nginx重写规则&#xff0c;本工具支持所有的htaccess伪静态、基本的配置规则、重定向等转换为ngin…

Golang开发的OCR-身份证号码识别(不依赖第三方)

身份证号码识别&#xff08;golang&#xff09; 使用golang的image库写的身份证号码识别&#xff0c;还有用了一个resize外部库&#xff0c;用来更改图片尺寸大小&#xff0c;将每个数字所在的图片的大小进行统一可以更好的进行数字识别&#xff0c;库名 &#xff1a;“github…

C语言 ——— 编写函数,判断一个整数是否是回文整数

目录 题目要求 代码实现 题目要求 编写一个函数&#xff0c;用来判断一个整数是否是回文整数&#xff0c;如果是回文整数就返回 true &#xff0c;如果不是就返回 false 举例说明&#xff1a; 输入&#xff1a;121 输出&#xff1a;true 输入&#xff1a;1321 输出&#xf…

怎么把文件生成二维码活码?支持生成多种格式文件的二维码教程

怎么把文件做成二维码分享给其他人预览或下载呢&#xff1f;现在使用二维码来展示或者分享文件的使用场景越来越多&#xff0c;这种方式可以帮助其他人更快的获取文件内容&#xff0c;有利于提升文件传输的效率。二维码可以长期存储文件&#xff0c;获取文件会更加的灵活方便&a…

翻转对00

题目链接 翻转对 题目描述 注意点 给定数组的长度不会超过50000输入数组中的所有数字都在32位整数的表示范围内 解答思路 本题与区间和的个数类似&#xff0c;都是使用归并排序统计满足题意的数量&#xff0c;归并排序后可以有效减少比较的数量归并排序的思路为&#xff1…

心觉:成功学就像一把刀,有什么作用关键在于使用者(一)

Hi&#xff0c;我是心觉&#xff0c;与你一起玩转潜意识、脑波音乐和吸引力法则&#xff0c;轻松掌控自己的人生&#xff01; 挑战每日一省写作173/1000天 很多人觉得成功学是鸡汤&#xff0c;是没用的&#xff0c;甚至是骗人的 我先保持中立&#xff0c;不知道对不对 我们先…

【Python报错已解决】AttributeError: ‘WindowsPath‘ object has no attribute ‘rstrip‘

&#x1f3ac; 鸽芷咕&#xff1a;个人主页 &#x1f525; 个人专栏: 《C干货基地》《粉丝福利》 ⛺️生活的理想&#xff0c;就是为了理想的生活! 专栏介绍 在软件开发和日常使用中&#xff0c;BUG是不可避免的。本专栏致力于为广大开发者和技术爱好者提供一个关于BUG解决的经…