`
canonical
  • 浏览: 372988 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Witrix架构分析

阅读更多

        Witrix开发平台基于级列设计理论发展了一系列新的设计思想和软件分解机制。并提出了一种新的Web体系架构。http://canonical.iteye.com/blog/33824
 

 

Witrix架构呈"可"字形态,其中定义了三条主要的分界线:
1. 浏览器和服务器之间通过语义结构明晰的URL形成两分结构。http://canonical.iteye.com/blog/99122
2. 系统前台至后台存在一条预制的非侵入的信道. 它维持了一种无害的可扩展结构. 具体的说,系统从前台js到后台处理,对于所有$为前缀的参数是自动传递的,没有识别出的层将自动把这些参数传递下去.系统通过这一信道实现退化过程。在我以前的文章中曾经指出过, 每一种可退化形式都对应存在一种非侵入性的可扩展设计。http://canonical.blogdriver.com/canonical/993807.html
3. Witrix内置了对于CRUD模型的支持, 而BizFlow通过类似AOP的方法对CRUD模型进行了扩展。这使得Witrix的模型驱动部分并不是仅仅针对单表或者单实体的维护, 而是可以实现特定的业务逻辑和CRUD逻辑的混杂.

这三条分界线分别规范了基础状态空间,对已有知识的重用以及面向未来的可扩展性。在这种大的宏观结构下,Witrix应用了如下技术手段:
1. 对象化。Witrix中的Jsplet框架以对象的名义提供了对后台的状态和行为空间进行分解的基础手段。 http://canonical.iteye.com/blog/33873 。Witrix依托于Jsplet对象实现相关性的局域化, 而不需要像一般面向action的框架那样直接访问http session这一全局状态空间. 前台发送的objectName参数同时在系统的不同层面标定了WebAction响应函数, Biz配置, DataSourceMeta元数据, Hibernate实体等一系列相关概念, 使得它们构成一个统一的整体.
2. 标准化。与REST架构风格类似,DaoWebAction规范化了后台响应事件。DaoWebAction上支持的标准事件有Query,ViewDetail,Add, Update, Remove等, 它们构成一个完整的CRUD模型。与REST不同的是,DaoWebAction提供了一个空的响应事件BizAction。它相当于是CRUD模型中的零元操作。在BizFlow模型下,它将被扩展为一个操作子空间,从而实现对于CRUD模型的超越。而在REST模型下所有的扩展操作必须依附于一个已经具有固定语义的Method上,例如POST. http://canonical.iteye.com/blog/99122
3. 实体化。在Witrix中充分发掘了ORM技术的能力, 使得单一业务对象上可以聚集到某一范围内的所有相关结构信息. http://canonical.iteye.com/blog/111500 . 同时在DaoWebAction中通过EntityFilter机制实现了单实体化过程. 这意味着前台应用可以一次性提交多个批量操作, 后台框架负责把它们分解为针对单个实体的一次确定性操作, 在后台实现时只需要考虑单实体的情况即可. 一个简单的例子是前台提交objectEvent=Remove&id=1&id=2&id=3 , WebAction层会为每一个id对应的实体调用BizFlow中的Remove-default操作. 实体化是一个非常重要的过程, 它使我们关注的核心成为单实体, 正是因为明确了单实体作为基本的关注点, 我们才可以建立更加复杂的状态机机制, 驱动系统状态变化.
4. 组件化. 前台的tpl模板和后台的WebAction共享一个thisObj指针, 结合自定义标签机制, 资源(js/css等)管理机制等构成可以重用的组件结构.
5. 偏置的AOP. BizFlow通过一种类似于AOP的操作对DaoWebAction提供的CRUD模型进行扩展, 使得模型的能力得到本质性的扩张. 这种AOP操作与通常意义的AOP的区别在于: 缺省行为在默认情况下发生, 除非显式禁止. 通过这种方式, 反转了base和extension之间的主体地位. 此外BizFlow所提供的不仅仅是行为的扩展,它同时提供了对界面的描述. 在前台tpl页面中通过 等无参数的标签调用来定义嵌入坐标. http://canonical.iteye.com/blog/34941


 

与传统的J2EE相比较, Witrix表现出很多变化:
1. 不使用全局的session, 而是使用局域化的thisObj
2. 不定义service层,其功能分解到BizFlow和Handler中,它们都不负责日常的DAO操作。独立的MDA部分负责所有的实体CRUD(Create Read Update Delete)操作。
3. 不定义页面跳转规则,在前台使用拉模式直接表明跳转目标。结合前台stdPage对象在前台控制跳转目标。并可以在BizFlow中配置覆盖的规则,这样就可以针对不同的应用场景定义不同的跳转规则。
4. 不是为每个模块, 每个应用场景编制一组新的页面,而是大多数模块共用少数几个标准页面.
5. 不在与网络无关的service层上定义权限和事务管理。Witrix架构下通过URL明确区分了系统内部和外部, 前台访问后台时调用者的全部意图是以规范化的形式表达在url中的. 因此权限和事务管理作用在WebObject上在概念上也可以认为是约束直接作用在URL上, 这与REST风格是统一的. 当然我们也可以规范service方法的命名等, 但是显然要求一种随意性消失是有代价的, 在URL上我们已经付出了代价,为什么要在service上再付出一次. Witrix中Transaction和Auth的配置更加直观, 因为规范化了WebObject上的事件响应函数,一般我们也不需要进行特殊的配置. Witrix这种设计更加适合于网络这一两分结构的,更加充分的利用这一架构边界所提供的隔离性.
6. 不在页面中使用实体的字段名,而是大量通过元数据表达程序意图。http://canonical.iteye.com/blog/114066

   一般J2EE多层架构下,所谓的架构分解主要是对程序纵向的分解,但是程序结构方面是没有横向分解的。而witrix架构的一个核心就是横向存在着CRUD模型和Biz的分解。在系统的所有实现过程中,所有CRUD操作都剥离到MDA模型中,而不需要任何代码编制。典型的, witrix后台代码一般写在handler中,命名为handler而不是service是因为handler中负责的内容和j2ee传统上的service有所不同,一般service总是要负责某个实体的CRUD操作,大量的findxxx代码。一般提倡的最佳实践是实现某个通用的基类,所有service都继承该基类获得CRUD能力。但是在Witrix架构中,根本没有这一需要。Handler只要完成自己特定的功能,它不追求操作概念在其本身的完整性。没有CRUD, handler没有意义。但是handler之所以有意义是因为它提供了CRUD之外的操作。当CRUD成为系统一种自动进行的背景操作时,我们不再需要明确意识到它的存在。
    我们需要认识到我们最终所需要的东西可能不是规整结构的, 它可能要求对于某个规整结构进行剪裁并增补附加元素. 但是这样的规整结构不应只存在于我们的想象之中,相应的剪裁过程应该是可以增量进行, 反复进行的. 在Witrix平台中, 基本的一种图景变化是: Witrix中不再需要从头开始构造结构, 而只要指定当前业务和背景模型之间的差异部分. 在Witrix中所写的业务代码是对核心模型的扩展。这不仅仅是概念上的,而是实际体系架构上精确的体现。CRUD作为独立的模型吸收了系统中大量的变化。整个模型内核是采用通用方式借助meta实现功能,并不涉及到特定于业务的类。对于那些我们已经掌握的知识, Witrix提供了超越对象继承,AOP和组件重用的结构抽取手段, 使得知识可以稳步积累.
      数学中存在两种基本的分解方式, 一种是加性分解 (a,b) + (c, d) => (a,b,c,d), 另一种是乘性分解 (a,b) X (c, d) => (ac,bc,ad,bd), 它也对应于张量(Tensor)运算. 在群论(Group Theory)中,直积对于复杂性的化简至关重要,它的重要性要远在加和之上。实际上AOP操作类似于直积分解, 只是它的能力尚未得到充分的探索。 在Witrix中,biz的作用在感觉上很象是陪集(coset)运算:CURD * biz。不同的biz作用到同样的CRUD模型上产生不同的操作集合,而所有biz组成的集合构成独立的整体。   
      Witrix平台中作为内核的MDA部分首先是物理模型驱动, 而不是逻辑模型或者对象模型驱动. 我们通过在物理模型上标注的方法恢复部分对象模型的信息, 但是我们并不试图把整个软件建立为模型. 所建立的仅仅是整个程序模型的内核. http://canonical.iteye.com/blog/29412 一般业内鼓吹的所谓MDA成功的关键是要提高抽象层次。 但是陪集是更抽象吗。 正规子群更抽象吗。 它们只是系统的指标性表征,使对信息的distill, 是更容易理解的一个侧面而已, 抽象性并不是一个真正的目标。很多时候我们需要的是把系统降维到某个子空间中,形成一种可控性。 但是这个子空间并不一定是更抽象的。
      群作为基本的代数系,一个本质特征是具有逆元。Witrix的MDA中明确定义了逆元结构,即界面上的元素 empty = buttonA + (-buttonA),这一分解公式应用到后台 OpA = Update * (-Update)  * OpA。假设我们已经建立了结构X, 现在需要建立一个与X略有不同的结构Y
       X = a + b + c
       Y = a + d + c = (a + b + c) - b + d = X - b + d
虽然Y的两种构造方式在数学上是等价的, 但在物理上并不等价。第一种方式对原有系统进行分解后再组装,而第二种方式没有打破原有的东西,不需要拆分。拆分总是可能存在问题的,正如你把所有电脑零件拆装下来再装上很可能会发现多出几个零件。一般情况下第二种方式的构建成本要低. 特别是当一切都纠缠在一起的时候, 一种细粒度的逆元结构对于一种试图重用的结构是非常关键的. 可重用性的障碍不仅仅是来自于无法追加新的功能,很多时候也在于无法屏蔽原先已经提供的功能。目前所有的设计原则都未能适时识别出逆元的重要性。所有的设计教条其实所指的方向都是加和, 如何分解出更小的组元, 如何把它们加和在一起, 如何从细部开始进行重新构建, 而不是说依赖于现有已经形成的宏观结构, 如何进行细粒度的调整. 所谓的AOP技术思考的关键点也在于如何给系统增加功能, 很少有人想到场景是为系统减少功能并把这种概念大规模正式应用的, 虽然说AOP已经在某种程度上具有了这种能力, 但是真正应用它仍然需要对AOP进行进一步的诠释. 当然,现在的软件业连基本结构的构造问题都没有完全搞清楚, 更别提所谓结构稳定性的问题了.
     从物理上说,Y = X - b + d的分解方式具有特殊的意味。如果没有逆元,我们必然需要分解。但是如果发掘了背景这一概念,在逆元运算下,对背景不是分解让其成为可见的部分,而是采用追加的,增删的方法对背景结构进行修正,则我们有可能在没有完整背景知识的情况下,独立的理解局部变化的结构。即背景是透明的,知识成为局部的。     
    Witrix试图提供的一种图景是永远只写代码片断,而所有的代码片断组合在一起又构成一个可理解的整体。这个整体可以独立理解,不需要额外的结构元素。Witrix架构所追求的是在不完全信息下建模,不进行整体建模。整体模型 + 不断变化的局部修正 构成 最终模型。平台技术的目标是让一切应该发生的自动发生,让一切不该发生的无法发生。这一模型的构建并不是trivial的,在概念和实现方面都要作出很多的努力。
     
题外:
     今天中午参加同学的婚礼, 席间和一个与同方有些渊源的同学谈到ezOne的现状, 大致的评语是: 垃圾, 自己人也不用. 听来也让人有些感叹. 中国原创的技术总是欺骗的代名词,  这一断言不应总是得到证实.

  • 大小: 51.8 KB
  • 大小: 45.9 KB
分享到:
评论
5 楼 canonical 2007-12-05  
多谢关注。我写blog一方面是记录我们创造的历程,另一方面是让部分对创新感兴趣的同行了解一种不同的思想。我并无意推广Witrix的应用。目前我们最重要的工作还是在行业市场上攻城掠地,Witrix是我们核心竞争力的重要组成,暂时不会考虑开源。
4 楼 dennis_zane 2007-12-05  
老大,你的blog经常看,很佩服您的博学和独立思考精神。关于Witrix,尽管你有这么多阐述的文章,可终究还是不够下里巴人,很难引起足够多的关注,也许开源是条路。
3 楼 canonical 2007-10-07  
思想是开放的,但是实现是商业的。我们目前集中在行业市场,不过也不排除以后会进入平台软件市场,那时才会考虑是否部分开源。
2 楼 Godlikeme 2007-09-26  
老大,牛的,虽然思路跟不上,还是要努力学习。这套架构准备开源么?
1 楼 feidi 2007-09-25  
不管是什么技术,产品,开源,不开源,都希望其持久,延续...哪怕是天天有一点点改进...
真正做成象自己的孩子,看着他成长,心中是什么滋味...
呵呵,希望楼主的的宝宝茁壮成长

相关推荐

    xbeanspring-2.6.jar

    我一直坚持xml是人机共享的信道, 应该是人与机器都能够... 在witrix平台的配置文件中, 我们大量使用了tpl模板技术, 通过tpl的自定义标签机制对外提供一些Domain Specific的功能标签, 大大增强了xml标签的语义表达能力.

    2023年通信施工应急预案.doc

    2023年通信施工应急预案.doc

    234751_43.m3u8

    234751_43.m3u8

    ARM单片机与FPGA协同驱动的先进运动控制卡方案:实时控制功能与应用拓展一体化解决方案

    内容概要:本文详细介绍了基于ARM单片机(LM3S6911)和FPGA(ALTERA EP1C3)的运动控制卡设计方案。ARM负责复杂的插补算法和以太网通信,FPGA则承担实时脉冲生成和IO扩展任务。文中展示了具体的硬件连接、通信协议以及关键代码片段,如以太网通信的LWIP协议栈实现、FPGA的Verilog代码用于脉冲生成和IO消抖处理。此外,还讨论了硬件设计细节,如PCB布局和电源管理,强调了系统的实时性和抗干扰能力。 适合人群:对嵌入式系统和运动控制系统感兴趣的工程师和技术爱好者,尤其是有一定ARM和FPGA开发经验的人群。 使用场景及目标:适用于工业自动化领域的运动控制应用,旨在提高运动控制的精度和实时性,减少机械抖动,增强系统的可靠性和灵活性。 其他说明:本文不仅提供了详细的硬件和软件设计思路,还附带了原理图、PCB图及源代码,方便读者进行进一步的研究和开发。

    Paddle Serving-部署一个自己的OCR识别服务器

    Paddle Serving-部署一个自己的OCR识别服务器

    COMSOL空气流注放电模型——集成针-针电极及Helmholtz光电离过程等离子体模拟新范式

    内容概要:本文详细介绍了如何利用COMSOL的等离子体模块构建针-针电极间的空气流注放电模型。主要内容涵盖了几何结构的定义、物理场配置(如电子、正负离子的载流子选择)、化学反应的设定(包括21组带电粒子反应)以及Helmholtz光电离过程的具体实现方法。文中还提供了多个代码片段用于解释各个步骤的操作方式,并强调了求解器配置和边界条件处理的关键点。此外,作者分享了一些实用的小技巧,如初始步长设置、网格细化等,以确保模型能够稳定收敛并得到合理的仿真结果。 适合人群:从事等离子体物理研究的专业人士,特别是那些对高压放电现象感兴趣的科研工作者和技术人员。 使用场景及目标:适用于希望深入了解和模拟针-针电极间空气流注放电行为的研究项目。通过该模型可以更好地理解电场分布、粒子密度变化等微观物理过程,从而为实际工程应用提供理论支持。 阅读建议:由于涉及较多的技术细节和数学公式,建议读者具备一定的电磁学、流体力学基础知识,并且最好有一定的COMSOL软件使用经验。同时,在实践中可以根据自己的研究方向调整模型参数进行探索。

    西门子S7-200 PLC与触摸屏实现的恒压供水系统全套图纸程序:一拖二与一拖三配置的实践应用

    内容概要:本文详细介绍了基于西门子S7-200 PLC的恒压供水系统的设计与实现。系统采用一拖二或一拖三模式,确保供水系统的可靠性。核心组件包括PLC、富士PID控制模块和ABB变频器,通过精确的压力控制和快速响应,实现了稳定的恒压供水。文中提供了详细的PLC程序示例,涵盖水泵启停控制、PID算法调用以及变频器频率调节等功能。此外,还展示了触摸屏界面设计,用于实时监控和操作。硬件配置方面,强调了柜体制作图纸的重要性和规范性,确保电气接线正确无误。调试过程中,作者分享了许多实用技巧,如PID参数整定、变频器设置和故障切换逻辑等。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是对PLC编程和恒压供水系统感兴趣的读者。 使用场景及目标:适用于工业现场的恒压供水系统设计与实施,旨在提高供水系统的稳定性和可靠性,减少因设备故障导致的生产中断。 其他说明:本文不仅提供了完整的硬件配置和软件编程指导,还分享了丰富的实战经验和调试技巧,帮助读者更好地理解和应用相关技术。

    基于模型预测算法的三电平整流器输入不平衡控制MATLAB仿真模型研究

    内容概要:本文详细介绍了基于MATLAB的三电平整流器输入不平衡控制的仿真模型。该模型采用模型预测控制(MPC)和正负序分离技术,通过Clarke变换和Park变换将三相电压转换到αβ坐标系,并进一步分离出正序和负序分量。随后,通过模型预测控制计算网侧参考电流,确保系统在网侧电压不平衡情况下仍能稳定运行。文中还讨论了仿真过程中的一些关键技术细节,如代价函数设计、LCL滤波器的谐振频率设置以及动态调整预测步长的方法。最终,仿真结果显示该方法在电网电压不平衡时表现出色,直流侧电压纹波控制在2%以内,电流波形质量良好。 适合人群:从事电力电子、电力系统控制领域的研究人员和技术人员,特别是对三电平整流器及其控制策略感兴趣的读者。 使用场景及目标:适用于研究和开发三电平整流器在非理想电网条件下的控制策略,旨在提高系统的稳定性和效率,减少谐波和直流侧电压波动。 其他说明:文中提供了详细的MATLAB代码片段和调试技巧,有助于读者理解和实现该仿真模型。此外,作者还分享了一些实际调试中的经验和注意事项,如坐标变换的时序对齐问题和代价函数权重的选择。

    Asp.Net CRM系统:高效管理客户关系,实现商业价值的最佳选择和必备工具

    内容概要:本文详细介绍了Asp.Net CRM客户关系管理系统的功能和技术实现。该系统不仅涵盖了客户信息管理、日程安排等功能,还展示了如何通过C#代码实现这些功能的具体细节。此外,文章强调了系统的二次开发能力和扩展性,如通过创建新的数据库表和编写相应代码来满足特定行业需求。系统采用三层架构,将客户生命周期、销售流程、团队协同等功能模块有机结合,形成一个完整的业务协同平台。文中还探讨了销售流程引擎、数据关联、实时消息推送等方面的技术实现,突出了系统的灵活性和高效性。 适合人群:对CRM系统开发感兴趣的软件工程师、企业IT管理人员、有一定编程基础的研发人员。 使用场景及目标:适用于希望提升客户管理水平、优化销售流程、增强内部协作的企业。通过实施该系统,企业可以更好地管理客户资源,提高工作效率,降低成本,最终提升销售业绩。 其他说明:文章提供了丰富的代码示例,帮助读者深入理解系统的工作原理和技术实现。同时,强调了系统在实际应用中的灵活性和扩展性,使其能够适应不同企业的具体需求。

    PowerShell7.5.1

    PowerShell7.5.1

    FX5U以太网通讯超清

    内容概要:本文详细介绍了三菱FX5U PLC的以太网通讯配置和编程技巧。首先讲解了基本的硬件配置和参数设置,如IP地址、子网掩码、端口号等。接着展示了如何使用ST语言和Python进行TCP客户端编程,包括创建Socket、连接服务器、发送和接收数据的具体步骤。文中还提到了一些常见的陷阱和解决方案,如隐藏寄存器的设置、十六进制地址转换、连接超时等问题。此外,提供了高级玩法,如批量读写寄存器、使用MC协议读取数据以及通过Python脚本测试通讯稳定性。最后强调了调试工具Wireshark的使用和注意事项。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是对三菱PLC以太网通讯感兴趣的读者。 使用场景及目标:帮助读者掌握三菱FX5U PLC以太网通讯的配置和编程方法,提高设备联机和数据采集效率,解决实际项目中可能遇到的各种问题。 其他说明:文章不仅提供了详细的代码示例,还分享了许多实用的经验和技巧,有助于读者快速上手并避免常见错误。

    PMSM永磁同步电机双环矢量控制理论深度解析与仿真实践指南

    内容概要:本文详细介绍了永磁同步电机(PMSM)的双环矢量控制理论及其在MATLAB/Simulink中的具体实现方法。首先解释了电流环和速度环的工作原理,特别是电流环中的Clarke变换和Park变换的具体实现。文中提供了详细的代码示例,如Clarke变换、Park变换以及电流环PI控制器的实现。同时,针对常见的调试问题给出了具体的解决方案,如速度环PI参数的整定、SVPWM模块的配置等。此外,还强调了仿真过程中需要注意的关键点,如PWM载波频率、死区时间补偿、速度观测器的选择等。 适合人群:从事电机控制研究和技术开发的专业人士,尤其是有一定MATLAB/Simulink基础的研发人员。 使用场景及目标:适用于希望深入了解PMSM双环矢量控制原理并掌握其仿真的技术人员。目标是在MATLAB/Simulink环境中搭建稳定的PMSM双环控制系统,确保系统在不同负载条件下的稳定性和鲁棒性。 其他说明:文章不仅提供了理论分析,还包括了大量的实践经验分享,帮助读者避免常见错误,提高仿真效率。

    FX3U PLC控制器资料:尺寸、主控芯片、电源及功能详解

    内容概要:本文深入介绍了FX3U PLC控制器的硬件架构和嵌入式软件设计。硬件方面,详细描述了控制器的尺寸、主控芯片STM32F103VCT6及其外围电路设计,如电源管理、继电器输出、光耦隔离、模拟量处理和通讯接口(CAN总线、RS485)。软件部分则展示了关键的GPIO配置、ADC校准、中断处理、状态指示灯控制以及多种通讯协议的实现方法。文中还特别强调了抗干扰设计和工业应用场景中的优化措施。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是对PLC控制器硬件设计和嵌入式编程感兴趣的读者。 使用场景及目标:适用于希望深入了解PLC控制器内部工作原理的技术人员,帮助他们掌握如何设计和优化工业控制系统,特别是在小型产线控制器或智能仓储系统的开发中。 其他说明:文章不仅提供了详细的硬件和软件设计方案,还分享了许多实践经验,如光耦隔离的应用、抗干扰措施、以及针对特定工业环境的优化技巧。

    2025年软件实施工程师笔试面试题及答案.docx

    2025年软件实施工程师笔试面试题及答案.docx

    CAD技术在水利水电工程中的应用.docx

    CAD技术在水利水电工程中的应用.docx

    可编程设置±10V、±5V、±3V高精度正负电压输出模块特点:小体积、宽电压输入范围、自动保存电压值、板载LDO稳定及低成本方案

    内容概要:本文介绍了一种低成本、高精度的模拟量正负电压输出模块方案,适用于工业控制和实验室设备。该模块支持±10V、±5V、±3V可编程设置,具备断电参数保存、自定义校准等功能。硬件设计包括电源模块、DAC芯片、EEPROM和控制芯片,确保输出电压稳定性和高精度。软件部分实现了电压设置、参数保存和自定义校准功能。材料成本控制在15元左右,性价比极高。 适合人群:电子工程师、硬件开发者、工业控制系统设计师以及对高精度电压输出有需求的研究人员。 使用场景及目标:① 工业控制系统的精密电压调节;② 实验室设备的高精度电压输出;③ 自动化项目的批量部署。 其他说明:该方案提供了完整的硬件设计和软件实现,包括详细的代码示例和原理图,方便用户进行二次开发和定制。

    淘客云全开源淘客系统:源码开放、支持定制开发,一站式搭建部署与首年免费更新支持

    内容概要:本文深入剖析了一个全开源淘客系统的实现细节,涵盖了多个关键技术点。首先介绍了用Go语言重构的淘宝联盟API网关,展示了商品搜索接口的核心代码,强调了参数签名、HTTP请求处理以及数据转换的重要性。接着讨论了数据库设计,特别是佣金结算表的结构,突出了JSON类型的使用和乐观锁机制的应用。前端方面,展示了基于Vue.js的佣金日历组件,体现了数据驱动UI和事件冒泡处理的设计理念。部署环节则分享了一些实用技巧,如手动更新淘宝API的SSL证书链。此外,还探讨了PHP实现的订单同步服务、SDK封装、热更新通道等特性,以及系统的技术售后支持措施。最后,文章总结了该系统的优点,如清晰的MVC分层结构、灵活的分佣规则设计、完善的部署方案和技术售后支持。 适合人群:对淘客系统开发感兴趣的开发者,尤其是希望深入了解系统架构设计、前后端开发、数据库设计和部署优化的技术人员。 使用场景及目标:适用于想要搭建或改进淘客系统的团队和个人开发者。目标是帮助读者理解淘客系统的各个组成部分及其工作原理,从而能够快速上手并进行二次开发。 其他说明:文中提供了大量实际代码片段和配置示例,便于读者理解和实践。同时,作者还分享了许多实用的经验和技巧,有助于提高开发效率和系统稳定性。

    LabVIEW 2018版:新手必备的动态启动界面制作教程,涉及二维图片写入、控件移动与动态调用知识点

    内容概要:本文详细介绍了如何使用 LabVIEW 2018 版制作动态启动界面,涵盖三大核心技术:图片加载、控件移动和动态调用。首先,通过创建透明图像和使用相对路径确保跨平台兼容性,实现了高质量的图片展示。其次,利用 While 循环和属性节点精确控制控件的移动轨迹,如 Logo 飞入、文字滑入等效果。最后,采用 VI 动态调用技术,使主程序在启动界面前台动画播放完毕后无缝加载,提升了用户体验。此外,文中还提供了许多优化建议,如双缓冲模式、渐隐效果、状态机架构等,帮助开发者打造更加专业的启动界面。 适合人群:具有一定 LabVIEW 基础的开发者,尤其是希望提升用户界面美观度和交互体验的技术人员。 使用场景及目标:适用于需要开发带有动态启动界面的 LabVIEW 应用程序,旨在提高软件的专业性和视觉吸引力,同时确保启动过程的流畅性和稳定性。 其他说明:文中提供的代码片段和技巧可以直接应用于实际项目中,建议初学者逐步尝试各个功能模块,熟悉后再进行综合应用。

    STM32驱动的信号发生器:基于Matlab数据生成与DMA传输的波形输出系统,支持串口通信与TFTLCD显示,一键切换波形,附程序源码与硬件原理图

    内容概要:本文详细介绍了如何利用STM32单片机和Matlab协作构建一个高效的信号发生器。首先,通过Matlab生成不同类型的波形数据并将其转化为适用于DAC的12位格式,然后将这些数据存储为C语言数组以便嵌入STM32程序中。接着,在STM32端配置DAC通道并通过DMA进行高速数据传输,确保波形能够稳定地输出。此外,文中还探讨了串口通信协议的设计用于远程控制波形参数,如频率、幅度等;实现了按键消抖功能以实现波形类型的手动切换;并且优化了LCD显示屏的内容刷新机制。最终测试表明该系统可以在1Hz-50kHz范围内提供高质量的波形输出,总谐波失真控制在1%以内。 适合人群:具有一定嵌入式开发经验的技术人员,尤其是对STM32、Matlab有一定了解的人群。 使用场景及目标:适用于需要定制化波形输出的应用场合,如实验教学、产品研发测试等。主要目的是为了帮助开发者更好地理解和掌握STM32与外部设备交互的方式,特别是DAC与DMA配合使用的技巧。 其他说明:随附有完整的项目资料包,包括Matlab脚本、Keil工程项目文件以及硬件原理图等,方便读者实际操作验证。

    台达触摸屏MODBUS直接通讯程序:变频器启动、停止、正反转与频率设定功能实时实现

    内容概要:本文详细介绍了台达触摸屏通过MODBUS RTU协议直接与台达变频器通讯的技术实现及其应用场景。主要内容涵盖通讯的基础理论、具体的代码实现方法(如连接、启动、停止、正反转控制、频率设定等功能的具体代码示例)、界面设计要点(如实时数据显示、状态指示灯的颜色变化等),以及针对常见问题的解决方案。此外,文中还强调了该方案的应用范围不仅限于台达产品,还可以推广到其他品牌的变频器、触摸屏甚至是温控表等设备,展示了其广泛的适应性和灵活性。 适用人群:从事工业自动化领域的工程师和技术人员,尤其是那些希望深入了解MODBUS RTU协议及其在实际项目中应用的人群。 使用场景及目标:适用于需要简化控制系统架构、降低成本的企业或个人开发者。主要目标是在不需要额外PLC的情况下,实现触摸屏对变频器的有效控制,提高系统的稳定性和效率。 其他说明:文中提供了大量实用的代码片段和配置参数,帮助读者快速理解和实施相关技术。同时,作者还分享了许多实践经验,如避免常见的配置错误、优化用户体验的设计思路等,有助于读者少走弯路。

Global site tag (gtag.js) - Google Analytics