AF(操作者框架)系列(2)-在Actor框架中派生Actor核心(命令模式)
为了能够提高程序的复用性,我们准备用Actor Framework框架,来演示其满足了这个需求(本章及后面的内容,需要有OOP的基础知识)。
首先,简述一下ActorFramework的运行过程:
在QDSM里面,每个队列通过不同指令,执行相应的处理过程。消息存储在消息队列数据中,通过队列消息句柄进行传递。
在ActorFramework中,在有需求的时候,运行相应方法的异步进程。Actors 接收到消息,基于消息的内容发送任务。
看下官方资料中解释的数据和执行的关系:

(1)数据存储在对象中。(2)方法是对已定义数据执行的操作。(3)一个类定义了一组数据,在数据的基础上执行相应的方法。(4)对象是类的特定实例。
下面我们演示一下ActorFramework的运行。在此声明一下,对于ActorFramework框架中涉及到的函数名称,在本系列之后的文章中,尽量以英文名称表述。一是框架的很多资料都是英文的,利于学习统一。二是在NI的官方文档中,也表述过Actor就是计算机行业里面的一个源词汇,如果用中文翻译,感觉有时候表述不到位。
另外actor这个词汇,是在计算机科学中早就存在的通用原语。我们来看下维基百科的定义:
——————————————————————————————————————
From Wikipedia:
The actor model in computer science is a mathematical model of concurrent computation that treats "actors" as the universal primitives of concurrent computation: in response to a message that it receives, an actor can make local decisions, create more actors, send more messages, and determine how to respond to the next message received.
The Actor model adopts the philosophy that everything is an actor. This is similar to the everything is an object philosophy used by some object-oriented programming languages.
“ 计算机科学中的actor模型是一个并发计算的数学模型,它将actors视为并发计算的通用原语:actor可以做出本地决策,来作为其接收到的消息的响应,创建更多actors,发送更多消息,并确定如何响应接收到的下一条消息。
Actor模型采用的哲学是一切都是Actor。这与一些面向对象编程语言应用的“任何事物都是一个对象”的哲学类似。 ”
————————————————————————————————————
在这里吐槽一下,很多资料,尤其是专业性强的技术资料,还是Google靠谱。那个熊掌公司,一搜索基本上全是广告和SEO优化后的网站,翻个3、5页找不到资料很正常。它只能算是一个赚钱的公司,不是一个有社会道德感的公司。
上述内容是我学习资料后,搜集的一部分内容,感觉对理解本系列文章有些帮助。
一、下面开始内容解析:
1.打开一个Launch Root Actor.vi(根操作者)。

2.打开后,里面调用了一个Launch Actor Core.vi(启动操作者核心)

3.打开Launch Actor Core.vi,可以看到程序使用了Start Asynchronous Call( 开始异步调用),当程序运行时,函数Actor.vi静态引用作为VI的引用端。

4.打开静态调用的Actor.vi,查看Actor.vi

5.查看Actor Core.vi,key 可以看到Actor Core.vi本质上就是一个队列结构,但是他是按照面向对象设计原则进行封装的,这种模式在文本语言中也叫作命令模式。

现在,我们来展示一下一个QDSM架构编写的计算加减的功能,然后用OOP重新编写一下。
说明一下:—————————————————————————————————————
原文作者只是展示了大致结构,并没有编写运行程序。为了更好地进行展示,我编写用于示例的程序,方便完整的功能展示。此示例程序不代表Tom的编程水平。
二、程序比对
1.首先,编写一个QDSM架构的计算器,做的加、减计算进行演示。

2.然后,我们创建类,来进行替换队列中的状态处理程序。UML类图如下所示:

3.根据uml文件,新建3个类:Counter、Standard、Complex(这个可以不建,主要用来展示功能扩展的便捷性),编写Counter的动态分配函数,initialise、Add、Substract、Result、Stop。编写MessageData类用于存放自定义数据。

4.按照一个类处理一个队列的逻辑关系,将QDSM架构转为OOP架构。整个程序架构简洁了一些,各个功能间也实现了关系降耦。如果新建一个类似功能函数,仅仅需要重新做一个类即可实现,如下图画圆圈的地方,可以很快捷增加新功能,而不更改整体架构。

5.运行一下,看看结果和QDSM一样。Success!
6.将OOP程序和ActorFramework里面的Actor core.vi进行比对,发现两者基本一致,所以,在将QDSM架构用OOP重构时,已经有了ActorFramework的雏形。

综上,通过将架构替换编程,可以看到刚刚开始编写时,面向过程和面向对象所花费的时间基本相同,但是在中大型程序中,面向对象的优势就开始明显了。
————————————————————————————————————————————————————————————————————————————————————————————
AF(操作者框架)系列(2)-在Actor框架中派生Actor核心(命令模式)的更多相关文章
- Android 开发 框架系列 Google的ORM框架 Room
目录 简介 导入工程 使用流程概况 一个简单的小Demo 深入学习 @Entity使用 自定义表名 tableName 自定义字段名@ColumnInfo 主键 @PrimaryKey 索引 @In ...
- ABP框架系列之二:(Entity Framework Core-实体核心框架)
Introduction(介绍) Abp.EntityFrameworkCore nuget package is used to integrate to Entity Framework (EF) ...
- Tomcat系列(10)——Tomcat主要设计模式5种(外观,责任链,观察者,模板方法,命令模式)
核心部分 外观模式: RequestFacade应用门面模式(facade)来封装HttpServletRequest. 观察者模式: 事件监听机制,控制组件生命周期的 Lifecycle .Serv ...
- 如何实现一个php框架系列文章【5】安全处理输入
所有的外部输入参数都应该检查合法性. 未正确处理输入数据将可能导致sql注入等漏洞. 框架提供系列函数来取$_REQUEST中的值 requestInt requestString requestFl ...
- Quartz.NET开源作业调度框架系列
Quartz.NET是一个被广泛使用的开源作业调度框架 , 由于是用C#语言创建,可方便的用于winform和asp.net应用程序中.Quartz.NET提供了巨大的灵活性但又兼具简单性.开发人员可 ...
- 老周的ABP框架系列教程 -》 一、框架理论初步学习
老周的ABP框架系列教程 -- 一.框架理论初步学习 1. ABP框架的来源与作用简介 1.1 简介 1.1.1 ABP框架全称为"ASP.NET Boilerplate ...
- Google C++测试框架系列:入门
Google C++测试框架系列:入门 原始链接:V1_6_Primer 注 GTest或者Google Test: Google的C++测试框架. Test Fixtures: 这个词实在找不到对应 ...
- Spring框架系列之AOP思想
微信公众号:compassblog 欢迎关注.转发,互相学习,共同进步! 有任何问题,请后台留言联系! 1.AOP概述 (1).什么是 AOP AOP 为 Aspect Oriented Progra ...
- SpringMVC 框架系列之初识与入门实例
微信公众号:compassblog 欢迎关注.转发,互相学习,共同进步! 有任何问题,请后台留言联系! 1.SpringMVC 概述 (1). MVC:Model-View-Control Contr ...
随机推荐
- 聊一聊 InnoDB 引擎中的索引类型
索引对数据库有多重要,我想大家都已经知道了吧,关于索引可能大家会对它多少有一些误解,首先索引是一种数据结构,并且索引不是越多越好.合理的索引可以提高存储引擎对数据的查询效率. 形象一点来说呢,索引跟书 ...
- Oracle GoldenGate 19.1新特性
1.GoldenGate 19.1 新特性概览a.支持Oracle数据库19.1 长期支持发布版本.集成Oracle GoldenGate 12.3版的最终补丁集更新.b.微服务的安全性和可管理性增强 ...
- Nmap使用教程(一)
基本扫描技术 扫描单个网络 nmap 192.168.1.1/www.baidu.com 扫描多个网络/目标 nmap 192.168.1.1 192.168.1.2 #将扫描同个网段内不同的ip地址 ...
- [bzoj4827] [洛谷P3723] [Hnoi2017] 礼物
Description 我的室友最近喜欢上了一个可爱的小女生.马上就要到她的生日了,他决定买一对情侣手 环,一个留给自己,一 个送给她.每个手环上各有 n 个装饰物,并且每个装饰物都有一定的亮度.但是 ...
- Linux下Tomcat,mysql安装包及教程整合,
前段时间孔老师给了一个虚拟机,自己瞎捣鼓,装了Tomcat和mysql,捣鼓了好几天,把一些安装包和试过还不错的博客整理出来: 老师给的已经装好了Linux系统和JDK. Tomcat9安装包 ...
- leetcode腾讯精选练习之螺旋矩阵(八)
螺旋矩阵 题目 给定一个包含 m x n 个元素的矩阵(m 行, n 列),请按照顺时针螺旋顺序,返回矩阵中的所有元素. 示例 1: 输入: [ [ 1, 2, 3 ], ...
- 优雅写Java之一(常见编程技巧)
一.字符串相关 推荐使用Apache Commons Lang3库 创建Empty字符串:return StringUtils.EMPTY; 或者 return ""; 创建重复的 ...
- mysq5.7l的下载与配置
---恢复内容开始--- mysql是一个开源免费的数据库,它属于oracle公司 下载地址:www.oracle.com 页面移动到下面可以找到这几个选项 还是移动到下面 如果你要下载的不是那四样中 ...
- Web自动化测试项目(七)日志
一.日志作用 调试程序 了解系统程序运行的情况,是否正常 系统程序运行故障分析与问题定位 用来做用户行为分析和数据统计 二.为项目添加日志 └── utils ├── log_utils.py └── ...
- 一个基于RabbitMQ的可复用的事务消息方案
前提 分布式事务是微服务实践中一个比较棘手的问题,在笔者所实施的微服务实践方案中,都采用了折中或者规避强一致性的方案.参考Ebay多年前提出的本地消息表方案,基于RabbitMQ和MySQL(JDBC ...