低代码 vs 模型驱动,它们之间到底是什么关系?(低代码 vs 模型驱动,它们之间到底是什么关系)

本文是一篇立场文件,作者借由第一届低代码研讨会的召开,讨论了关于在模型驱动工程领域定位低代码运动的想法,并试图给出了部分问题的答案。

低代码 vs 模型驱动,它们之间到底是什么关系?(低代码 vs 模型驱动,它们之间到底是什么关系)

自从低代码(Low-code)成为新的流行术语之后,我就想知道“低代码”运动与我们过去所说的“模型驱动的工程/开发”相比,是否真的有什么不同。第一届低代码研讨会(属于2020年模型大会的一部分)是让我花时间思考并写作这个主题想法的一个很好的借口。

接下来你将阅读的是我思考的结果。里面还嵌入了我准备发表的论文的演讲幻灯片(见底部)。两者都包含了我在发布本文的第一版时得到的一些反馈(感谢大家给我的宝贵反馈!)。我相信这(低代码在模型驱动领域的定位)是我们作为一个社区所必须继续讨论的话题。即使我们不能达成任何共识

免责声明:

  1. 这是一份简短的立场文件,大家应该据此来阅读和解释。
  1. 这可能是有争议的。如果你阅读时觉得被冒犯了,就说明我的工作做得很好。我认为,立场文件的重点是发表有力且大胆的声明,以帮助展开讨论。
  1. 当其中一个术语(“低代码”)没有被科学定义,但需要通过研究一组称之为低代码的工具集来进行推断时,很难“科学地”比较这两个术语。

说到这里,请继续阅读我关于在模型驱动工程领域定位低代码运动的想法。特别是,我试图给出这些问题的部分答案

  • 在低代码运动的背后有什么根本的新东西吗?
  • 它与模型驱动工程或模型驱动开发等其他概念有什么关系?
  • 这对建模界的研究人员来说意味着什么?

介 绍

低代码应用程序平台通过大幅降低所需的手工编码量来加速应用程序交付(该定义来自Forrester报告[5],被认为是低代码一词的起源)。这显然不是软件工程界第一次试图通过结合可视化开发技术(我们称之为“模型”)和代码自生成来减少手工编码。事实上,正如GradyBooch所说,软件工程的整个历史都是关于提高抽象层次的。

低代码是降低开发软件应用程序所需的手工编码量的最新尝试。这是我们从软件工程开始之初就一直追求的目标。

来自TWEET

低代码可以追溯到模型驱动工程。但是模型驱动工程本身可以追溯到CASE(Computer-Aided Software Engineering,计算机辅助软件工程)工具。早在1991年,在著名的CAiSE会议的第1版中,我们就可以找到这样的论文:“给定最终模型,可以自生成完整的计算机化信息系统”[2]或“我们得出了一个可自动生成可执行代码的规范”[4]。

同时,低代码在当今商业世界中的影响也很明显,包括了一些大胆的预测,但也包括了最近投资于低代码工具的相关实际数据,其中一些工具的商业成功或许仅仅是因为所有最大的软件公司都在确保他们在提供该领域的某种产品

低代码vs模型驱动vs基于模型vs无代码

对于所有的MD*概念,我们并没有通用的定义。我自己的(非正式)定义如下:

  • 模型驱动工程(Model-driven engineering,MDE):任何一种软件工程过程,其中模型起着基础性的作用并驱动着工程任务。
  • 模型驱动开发(Model-driven development,MDD):MDE应用于正向工程,即用于软件开发的模型驱动。
  • MDA是OMG对MDD的特定设想,因此依赖于OMG标准的使用。
  • 基于模型的工程/开发:前面各个概念的软版本。在MBE过程中,软件模型扮演着重要的角色,尽管它们不一定是工程/开发的关键工件(即它们不“驱动”过程)。

能区分MBE与MDE的一个例子是开发过程,在分析阶段,设计人员指定了独立于平台的系统模型,但是这些模型会直接交给程序员来手工编写代码(不涉及代码自生成,也不明确定义任何特定于平台的模型)。在这个过程中,模型仍然发挥着重要的作用,但不是开发过程的基础。

基于以上定义,我认为低代码是模型驱动开发的同义词。如果有什么区别的话,我们可以把低代码看作是MDD中的一个更严格的视图,其中我们仅针对某种特定类型的软件应用程序:数据密集型Web/移动应用程序。

注意,术语“无代码”有时被用作低代码的细微变化。实际上,我们经常会看到工具将自己定义为无代码/低代码工具。然而,对我来说,无代码方法的关键特征是应用程序设计人员应该编写零代码来创建和部署应用程序。这在很大程度上限制了使用无代码工具的实际效果。我们基本上是在研究基于模板的框架或创建工作流,这些工作流将预定义的连接器与外部应用程序混合在一起,在这些应用程序中,设计人员最多是决定何时以及如何触发某些操作。

比较这些不同范例的另一种方法是查看你需要编写多少手工代码。在MBE中,你可能需要编写所有代码。相反,在MDD和低代码中,大部分代码都应该是自动生成的,但是你可能仍然需要定制并完成所生成的代码(大多数MDD工具都包含某种黑盒建模原语,你可以在生成过程中编写任何应该添加到其中的自定义代码)。在无代码中,你应该编写零代码。

显然,需要进行更多的研究来评估市场上的低代码工具,并更好地将其描述为比这里介绍的工具更细粒度的类别。事实上,目前基本上还没有关于低代码运动的研究(快速搜索只会发现一些关于将自己归类为低代码工具的论文,而不是将低代码本身作为研究对象),我相信这个研讨会将会使这一点开始改变。

低代码趋势

如图1所示,对低编码的兴趣达到了顶峰,即使如图2所示,这个峰值远小于对模型驱动的注意力达到顶峰时的峰值。

低代码 vs 模型驱动,它们之间到底是什么关系?(低代码 vs 模型驱动,它们之间到底是什么关系)

谷歌趋势图显示了对低代码术语的搜索兴趣

低代码 vs 模型驱动,它们之间到底是什么关系?(低代码 vs 模型驱动,它们之间到底是什么关系)

但是,如果从技术上讲,低代码并没有真正带来什么新东西,为什么会如此流行呢?

  • 首先,我认为低代码所传达的信息比模型驱动/基于模型的信息要清晰得多 。模型是一个非常模糊的词,因此模型驱动的概念比低代码更难解释(每个人对什么是代码都有清晰的认识,低代码就变得不言而喻了)。
  • 其次,我们知道建模会吓跑开发人员。相反,低代码听起来更熟悉。他们已经在做同样的事情了(编码),只是更少。
  • 此外,低代码的应用场景也更加清晰。低代码不是说你可以用MDD做任何事情(这最终会产生不信任),而是通过针对特定类型的应用程序(即行业中最需要的应用程序)来其使可信度更高。
  • 低代码也是一种典型的一次性建模方法,这意味着你拥有模型和生成的代码,没有复杂的细化链,没有模型转换,也没有其他任何东西。
  • 平均而言,低代码工具比我们传统的重型建模工具更好。例如,大多数都是基于Web的,并且不依赖于EMF。

总而言之,在低代码工具中,我还没有看到任何在模型驱动领域找不到的符号、概念、模型类型或生成技术。但可以肯定的是,这些相同的技术以不同的方式呈现、配置、调整和“销售”,这最终会使人们对低代码的新颖性和实用性在认知上产生巨大的差异。MDE项目的成功通常更多地取决于社会和管理方面,而不是纯粹的技术方面[3]。这并不是免费的(缺乏互操作性、供应商锁定、昂贵的商业模式等等),但目前看来这并没有阻止社区的发展。

低编码是一个机会

如前所述,我不认为MDD和低代码趋势之间存在根本的技术差异。事实上,我们可以应用模型驱动工程中几乎所有的开放性挑战[1],只需将“模型驱动”变更为“低代码”即可免费获得低代码开发的研究路线图(例如,我们需要更好的方法将人工智能集成到低代码工具中,或者我们应该作为一个社区努力构建低代码示例的共享存储库用于未来研究)。

但是我不认为这是消极的。恰恰相反。显然,低代码吸引了很多人的关注,包括那些从未参与过建模的人。从这个意义上说,低代码是降低进入建模技术领域的门槛。因此,对我来说,低代码是将建模(以及我们的建模专业知识)引入新领域和社区的巨大机会。如果我们能通过将自己塑造成低代码专家以获得更多的资金/曝光/用户/反馈,我完全赞成。这正是许多知名的所谓的低代码公司所采用的方法(你可以随意使用互联网时光机,看看他们的网站在过去几年中是如何从可视化建模、敏捷开发、CASE工具和类似关键字转变为低代码的)。让我们也借此机会更好地理解使类似建模技术在广泛的软件社区中引起共鸣的因素,并从中学习。

低代码是一个巨大的机会,可以将建模(以及我们的建模专业知识)带到新的领域和社区

来自TWEET

在我们这么做的同时,让我们关注一下未来的市场趋势。一些低代码供应商正在(再一次)改变他们的营销工作。也许用不了多久,我们就会开始高呼:低代码已死,多体验开发万岁!

比较低代码与模型驱动工程的幻灯片

低代码 vs 模型驱动,它们之间到底是什么关系?(低代码 vs 模型驱动,它们之间到底是什么关系)

Low-code vs Model-Driven Engineering 来自 Jordi Cabot

参考文献

1. Antonio Bucchiarone、Jordi Cabot、Richard F. Paige和Alfonso Pierantonio。《模型驱动工程的重大挑战:研究现状分析》。《软件和系统建模》19,1(2020),5-13。https://doi.org/10.1007/s10270-019-00773-6

2. Jon Atle Gulla、Odd Ivar Lindland和Geir Willumsen。 1991年。《PPP:一个集成的CASE环境》。《高级信息系统工程》,CAiSE'91,挪威特隆赫姆,1991年5月13-15日,论文集(计算机科学讲座,第498卷)。Springer(194-221)。https://doi.org/10.1007/3-540-54059-8_86

3. John Edward Hutchinson、Jon Whittle和Mark Rouncefield。2014。《工业中模型驱动的工程实践:导致成功或失败的社会、组织和管理因素》。《科学、计算机、程序》89(2014年),144–161。https://doi.org/10.1016/j.scico.2013.03.017

4. John Krogstie、Peter McBrien、Richard Owens和Anne Helga Seltveit。1991。《使用过程和基于规则的方法相结合的信息系统开发》。《高级信息系统工程》,CAiSE'91,特隆赫姆,挪威,1991年5月13-15日,论文集(计算机科学课堂讲稿,第498卷)。Springer,319-335。https://doi.org/10.1007/3-540-54059-8

5. Clay Richardson和John RRymer。2014《面向客户的应用程序的新开发平台应运而生》。 Forrester:剑桥,马萨诸塞州,美国(2014年)。

原文链接:

https://modeling-languages.com/low-code-vs-model-driven/

关注我并转发此篇文章,私信我“领取资料”,即可免费获得InfoQ价值4999元迷你书,点击文末「了解更多」,即可移步InfoQ官网,获取最新资讯~

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

(0)
上一篇 2024年1月11日 上午9:20
下一篇 2024年1月11日 上午9:36

相关推荐

  • 根据有关规定,乡镇党委委员一般应当具有2年以上的党龄,乡镇党政正职一般应当具有3

    根据有关规定,乡镇党委委员一般应当具有2年以上的党龄,乡镇党政正职一般应当具有3年以上的党龄。这是我国党员和干部的一个重要规定,也是保证和提高乡镇干部素质的重要内容。 党龄是党员的…

    科研百科 2024年11月25日
    0
  • 软考系统集成项目管理师

    软考系统集成项目管理师: 掌握项目管理的“金三角” 系统集成项目管理师(SPM)是项目管理领域的重要职业,主要负责在项目中整合、规划、执行和监控项目资源,确保项目按时、按质、按预算…

    科研百科 2024年12月12日
    0
  • 2024年重庆市科研项目2024年重庆市科研项目

    2024年重庆市科研项目 随着科技的不断发展,科研项目也在不断地推进。在2024年,重庆市计划开展一系列重要的科研项目,以推动当地经济的发展和社会进步。 其中,一项备受关注的科研项…

    科研百科 2024年7月4日
    34
  • 项目管理 团队

    项目管理团队:推动项目成功的引擎 项目管理是一个企业或组织中至关重要的一环。一个好的项目管理团队可以帮助企业或组织实现目标,并确保项目按时完成,并在预算内交付。一个有效的项目管理团…

    科研百科 2024年5月25日
    43
  • 没有研究基础如何申请课题

    没有研究基础如何申请课题 申请课题是研究人员在学术研究过程中的一个重要环节。如果没有足够的研究基础,申请课题可能会比较困难。本文将介绍一些没有研究基础如何申请课题的建议。 1. 确…

    科研百科 2024年10月10日
    16
  • 研发经费投入与核算管理办法

    研发经费投入与核算管理办法 为规范和加强企业的研发经费投入与核算管理,提高企业的研发效率和质量,促进企业技术创新和发展,根据《中华人民共和国财务管理法》等相关法律法规,我部制定了研…

    科研百科 2024年7月12日
    35
  • 华为客户关系三板斧

    华为客户关系三板斧华为客户关系三板斧,迟早会被其他人抢掉。但这个世界上,如果没有好的人脉,没有好的技能,是很难取得成功的。很多人总是抱怨工作的不公,抱怨自己没有上好大学,总觉得自己…

    科研百科 2024年11月21日
    0
  • 架起“连心桥” 画好“同心圆”——渭南高新区党建引领网格化管理工作小记

    来源:【渭南日报】 渭南日报 记者 王珂 通讯员 周微娟 在渭南高新区,有这样一群人:他们行走在网格,化身宣传员,将党的政策传递到千家万户;他们深耕社情民意,访民情、听民意、解民忧…

    科研百科 2023年11月7日
    137
  • 具体项目管理

    具体项目管理 项目管理是一种有效的组织方式,可以帮助企业或个人实现特定的目标。具体项目管理是一种将项目分解为一系列可管理的任务,并使用适当的方法和工具来跟踪,控制和协调这些任务的过…

    科研百科 2024年8月17日
    26
  • 小区党建遇到的困难

    小区党建遇到的困难 小区党建是中国共产党在社区中开展的一项重要工作,旨在加强社区党组织的建设,促进社区党员的积极参与,为社区居民提供更好的服务和保障。然而,在实际操作中,小区党建也…

    科研百科 2024年11月14日
    2