桌面应用开发技术对比,你明白了吗?(桌面应用开发前景)

作者:ayuliao

前言

因个人兴趣,想着开发一个桌面应用软件,其具体定位是:RPA,相关的商业软件有很多,我了解使用过的几个:UiPath、UiBot、影刀 RPA。

什么是 RPA?其全称为 Robotic Process Automation(机器人流程自动化),简单而言就是让计算机帮助我们执行各种重复性高的工作,对于行政、金融、政府等人力密集型部门,RPA 是很好的助力。

最近几年,RPA 相关赛道的公司融资都很猛,通常都是亿级的融资,因为我之前在公司负责过自动化工具相关的工作,所以一直有关注自动化相关的各种技术,其中 RPA 是我关注的重点,观察下来,各种 RPA 商业应用其技术实现难度不算特别大,虽然其功能很多,但感觉慢慢从基础功能搞,还可以够得着,所以一直有打算开发一个的想法。

这篇文章是第一步,对比一下目前桌面端技术栈,做技术选型。

PS: 熟悉我的朋友知道我之前使用 Electron Vue 开发过抖直播这个应用,但 RPA 软件需要更多系统层的支持,我在调研前,会疑惑 Electron 对系统 API 的兼容情况以及是否有更好的方案,所以还是花时间调研了一下。

当然,做事情前先明确目标:

  • 我希望可以构建出一个跨平台的 RPA 桌面应用,目前多数商业 RPA 软件都局限在 Windows 平台(即只有 exe 安装包)。
  • 因为 RPA 需要很多系统级的功能,所以我希望可以比较轻松的试验系统 API。
  • 因为时间、精力和能力的问题,我希望可以基于自己已有技术栈之上来开发。

桌面应用开发技术对比,你明白了吗?(桌面应用开发前景)

常见桌面端开发技术栈

通过微信、QQ 等各种桌面端应用,可以了解目前开发桌面端的主流技术栈,简单总结一下:

1.使用 C# WPF 依旧是开发 Windows 桌面应用的主流选择,其优点是:比较成熟,参考资料比较多,其缺点是:性能一般,需要用户主动安装 net 库,虽然很多软件会直接提供下载,然后让用户安装,但依旧是一个坎,此外 WPF 只支持 Windows 平台,与目标不符。

2.C QT 也是很多人的选择,QT 是否成熟,但比较重,适合开发大型应用,对于个人开发者而言,效率不高,此外我除了大学时用 C 参加过算法比赛外,很少再使用过。

3.在 Windows 平台下,国内多个大众应用,如微信、QQ、百度网盘都使用了 C 类duilib 的形式进行开发(类 duilib 的意思是,基于开源的 duilib 这个 Windows GUI 进行了二开),这种方式出的桌面应用,性能较高而且包的体积下,是专业团队比较好的选择,但不适合我这个项目,因为 RPA 并不要求太高的性能,而且我希望一份代码可以跨平台使用。

4.影刀等商业 RPA 软件使用了 C CEF 的形式开发,CEF(Chromium Embedde FrameWork)与 Electron 定位类似,基于 Chromium,让开发者可以使用前端技术栈来构建桌面应用,跨平台,就是 CEF 资料比较少,还需要 C 等知识,因为是对标软件使用的技术,所以加入候选技术栈。

5.VScode、Github 桌面端等使用 Electron 开发,与 CEF 类似,Electron 让我们使用前端技术便可以开发桌面应用,其优点是:资料很多、开发效果比较 OK,缺点是慢,而且对于需要比较多系统 API 的兼容因没有对标软件,所以不太好确定。

6.Flutter 是 Google 推出了全平台开发框架,支持 windows、macos、android、ios 甚至是汽车中的系统,调研下来的结论是,Flutter 对跨平台的支持还非常早期,很多系统层的 API 并不支持,生态也刚起步,与 npm 比不了,很多东西可能要自己造,所以也不考虑。

CEF 与 Electron 的比较

CEF github: https://github.com/chromiumembedded/cef (1.6k star) Electron github: https://github.com/electron/electron (101k star)。

从 Github 上看,Electron 的活跃度远高于 CEF,包括:版本更新频率(解决 issue 的速度、新功能的开发速度)、社群活跃度(资料丰富度)。

那为啥有些商业产品要选择 CEF 呢?其优势在哪?对目前想开发的项目来说,是否重要?

相比于 Electron,CEF 支持 Windows XP 系统,提供的很多比较底层的 C API 方便你使用系统级能力,而且也很方便与 Native UI 框架融合使用,实现更近似本地应用的应用。

简单而言,使用 CEF,相比于 Electron 可以更轻松的做的更像原生软件,除了不支持 Windows XP 这个硬伤,Electron 其实可以通过 C 的方式调用更多系统级的原生能力,但这要求你对 Electron 框架源码比较熟悉,当然也要会写 C 代码。

那 Windows XP 系统目前占用量大吗?查阅了一下,Windows XP 在 2020 年,市场占有率已经低于 1%,所以我还是偏向于选择 Electron 进行 RPA 桌面应用的开发。

所以剩余的问题,便是加强对 Electron 的把控感。

Electron 开发需要考虑的问题

1.因为 Electron 本身架构的原因,Electron 打出来的包会比较大,但就目前个人电脑的性能而言,也不算什么特别大的问题,就像现在手机游戏一样,反正手机性能过剩,一些比较难搞的优化直接就放弃了,但在开发时,还是尽量精简 require,从而让 Electron 打出的包小一点。

2.Electron 对源码是没有保护的,即你开发的软件,很容易别人逆向分析,有几个解决方案,除了方案 c,都可以逆向破解,这些操作只是让可破解的人少一点而已(当然,最安全的方式是你的软件没有任何价值,放到 Github 都没人 fork)。

  • a. 使用 C 编写核心逻辑,发布时,C 是编译后的二进制文件
  • b. 使用 wasm 编写核心逻辑,发布时,也是二进制内容
  • c. 核心逻辑放在后端
  • d. 使用 bytenode 将代码转成字节码

3.Electron 对系统层能力的使用可能比较弱,此时需要求助 Python、C 、C# 等语言,通过 ffi-napi 库可以让 Node.js 使用 C dll,通过 electron-edge-js 库可以让 Node.js 使用 C# dll。

参考

  • 开发桌面应用是用 flutter 还是用 electron

https://www.zhihu.com/question/390186321

  • macOS 上 Flutter Desktop 与 Electron 的性能对比

https://juejin.cn/post/7018450473292136456

  • 对比跨平台客户端方案:Electron 和 CEF

https://blog.csdn.net/caperxi/article/details/115901659

  • 桌面端框架 Electron 使用问题整理和总结

https://juejin.cn/post/6844904072743501831

来源: 懒编程

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

(0)
上一篇 2023年5月4日 上午8:27
下一篇 2023年5月4日 上午8:37

相关推荐

  • 5个完全免费的实用软件,值得收藏备用(免费使用的软件)

    1、B站下载器Downloader 【BilibilivideoDownload】看名字就能知道这是一款B站的视频下载器,复制黏贴对应的视频地址在输入框点击按钮提取下载,可选择清晰…

    科研百科 2023年4月19日
    304
  • 项目管理风险类别

    项目管理风险类别 项目管理风险类别是项目管理中非常重要的一部分,不同的风险类别可能会导致项目失败或延期。本文将介绍项目管理风险类别,并探讨如何识别、评估和控制这些风险。 一、风险类…

    科研百科 2024年9月23日
    28
  • 农业部多措施促现代畜牧业提质增效

    CGv   本报讯(记者高飞)今年以来,农业部坚决贯彻落实党中央国务院推进农业转方式调结构的精神,采取有力措施加快转变畜牧业发展方式,提高质量效益和竞争力,现代畜牧业建设取得明显进…

    2022年5月31日
    293
  • 楼宇自控系统中可视对讲系统四大基本构件(楼宇对讲可视对讲原理)

    城镇化的迅速发展对于楼宇自控提出了更高要求,而作为楼宇自控的重要组成部分之一,可视对讲系统十分重要。随着国家互联网和云技术的成熟,目前对可视对讲系统实施集中管理,通过智能终端,结合…

    科研百科 2023年8月22日
    137
  • 信息系统项目管理 AC

    信息系统项目管理 AC 随着信息技术的不断发展,信息系统项目管理已经成为企业运营中不可或缺的一部分。信息系统项目管理 AC 是其中的一个重要组成部分,负责规划和实施信息系统项目,确…

    科研百科 2025年1月6日
    0
  • 资兴市出台村级(社区)财务管理办法

    红网资兴分站8月22日讯(分站记者 何志强 通讯员 曾青红)8月21日,笔者从湖南省资兴市财政局获悉,资兴市出台了《资兴市村级(社区)财务管理办法》,进一步加强村级财务管理,规范村…

    科研百科 2024年1月23日
    113
  • 浙江省科技项目经费管理办法

    浙江省科技项目经费管理办法 为加强浙江省科技项目经费管理,提高科技项目管理和经费使用效率,根据《中华人民共和国科学技术法》和浙江省人民政府《关于促进科技创新的决定》,浙江省制定了《…

    科研百科 2024年8月15日
    55
  • 精品软件推荐-软件助手(精品软件下载站)

    今天推荐的这款软件非常适合桌面运维人员使用,该软件可以批量安装你所需要的软件,只需把你把需要的软件放在软件助手同一目录下面,支持一键安装,也支持手动安装 软件助手 软件助手最大的特…

    科研百科 2023年3月13日
    288
  • 如何管控项目进度

    管控项目进度是项目管理中至关重要的一部分,以下是一些管控项目进度的方法和技巧。 1. 制定详细的计划:制定一份详细的项目计划,包括时间表、任务分配、资源需求和风险预算等,确保项目团…

    科研百科 2024年8月27日
    27
  • 科研项目主持人 本人作用

    科研项目主持人的作用 作为科研项目的主持人,我们肩负着重要的责任和使命。我们不仅仅是负责项目的规划和组织,还要对项目的进展和质量进行监督和指导。在这篇文章中,我们将探讨科研项目主持…

    科研百科 2024年11月10日
    0