知乎高赞:Java9的模块化技术在应用上有什么价值?

点击关注公众号,利用碎片时间学习

来源:zhihu.com/question/264956573/

answer/1840974105

最近就正好在倒腾模块化,说说我们的应用场景

就是用java来写steam上的游戏,那缺省的jdk,它提供了语言常见的功能

但是

jdk并不提供以下功能

  • gui,一个高性能的,能够使用硬件加速渲染的gui,缺省的java gui是awt和swing,虽然说可以手动打开硬件加速渲染,比如-Dsun.java2d.opengl=true,但是swing的控件什么都不尽如人意,缺省界面比较难看,上个世纪80年代unix的ui风格,官方已经不再建议我们使用swing了,而改为javafx

  • steamworks sdk,这个steam官方提供的是c++的api,jdk并不提供,但是有第三方用jni将其包装成java的api,并开源

  • 游戏引擎

  • 非java语言的扩展,比如kotlin

那怎么办呢?这时候你就可以感觉出来,模块化大显身手了

我们可以将jdk提供的模块,以及我们需要扩展使用的模块,把它们做成一个统一的runtime运行时,然后连同这个runtime跟我们自己写好的代码,一起分发出去,然后我是用这种方式依次解决上述几个问题的

1.javafx官方缺省提供jmods下载,所以第一个问题好解决,下载jmods就好了

2.steamworks sdk的java包装steamworks4j项目并不提供模块化,但是它是开源的,所以我们将其代码fork过来,下载到本地,对其做模块化处理。

值得注意的是,steamworks4j源码的resources里面,同时提供了三种平台的动态链接库,也就是dll,so和dylib,对应win,linux和mac,那么我们制作不同平台的模块的时候,只需要取其中一种就可以了,比如mac上只需要dylib,不需要so和dll,这样就可以节省一部分空间,虽然不多,但是如果多的话,这里节省的大小就很可观了,然后我分别制作了三个平台对应的jar,分别是win-x64.jarmac-x64.jarlinux-x64.jar,是模块化后的jar,jar里面有module-info.class,定制runtime并不一定需要jmod,jar也行,只要jar做了模块化,也就是有module-info.java,值得注意的是,jlink命令并不接受automatic modualized jar,自动模块化的jar,不能用在jlink里面,你需要显式写出来该模块的module-info.java,如果没有该文件,那么将不能用在jlink上,我给该模块起名steam.sdk

3.选了一个游戏引擎fxgl,作者是英国大学的发考题,提供社区和即时聊天服务,然后该引擎是基于javafx制作的游戏引擎,作者本人就是在大学教怎么做游戏的,教怎么用unity之类的是他的日常,以前我们用java做游戏,同道多数来自玩minecraft的小孩子,小孩子毕竟经验没有发考题那么丰富,所以有发考题介入,这事就轻松很多

4.kotlin自身在1.4还是哪个版本也做了模块化处理,所以kotlin的jar可以直接用,所以fxgl同时依赖javafx和kotlin,还有一个是jackson,gluon这些依赖,庆幸的是,这些也都做了模块化

太棒了,然后我就把我自己做好模块化的steam sdk的jar,fxgl的jar,kotlin的jar,jackson,gluon的jar,还有fxgl依赖的gluon的jar,连同javafx的jmod,jdk自身的jmod,这些东西,凑在一起(全部放到jdk的jmods文件夹下面去),做了一个我们游戏使用的runtime运行时,命令如下(mac,win/linux类似):

bin/jlink --module-path jmods --add-modules java.base,javafx.base,javafx.graphics,javafx.controls,java.logging,javafx.media,steam.sdk,com.almasb.fxgl.all,com.fasterxml.jackson.databind --output macrt

然后我们的游戏就可以直接运行在runtime运行时上了,就跟这个老外说的一样

9ee4fd100f8e24c4ebe2b078c75e6bba.png

所以模块化有什么价值?

一减,一增

减法就是你可以把你不用的模块,全部丢掉,因为jdk很大,你说你生产环境,整一个javac或者jshell是几个意思?尤其是像客户端开发,用户都是在在线商店直接下载的,1g和100m对于用户而言,差别巨大,虽然可以压缩,但你也应该想办法减少掉那些没用的类库和模块

嗯,对,说到这里,模块化后的游戏可以用graal做native image,打包成安卓上的apk和ios上可执行的ipa,上线google play或者app store,在这种目标下,减法意义就比较大了

然后是加法,你看一下我加的几个依赖,是不是有不少是c/c++写的依赖?比如javafx,可以看成是一个c++的项目,steamworks sdk也是c++写的,我们需要将其集成到我们的运行时里面去,如果没有模块化,那我除了自己动手去改jdk源码以外,好像也没有太好的办法,因为过去没有模块化之前,如果有native代码的话,那么要么就是全部放到jar里面去,就像steamworks4j那样,一个jar里面有三个平台的动态链接库dll,so和dylib,用的时候,再用代码去区分,那这样就很麻烦。

学习资料:Java进阶视频资源

那现在就很方便,我们可以针对不同平台,发布不同的jar或者jmod,然后我们再用jlink,将其整合到我们java的运行时里面去,用起来又跟普通的api一样,是不是就很方便?

另外,我们并不要求用户安装jre或者我自己定制的runtime运行时,没有必要,我会提供相应的启动文件,用户双击即可启动,不用安装,当然你要安装的话,也可以

然后渠道本身也会帮助你做好分发和安装的工作,比如steam就会自动帮你提供一个客户端,你只需要在steam的后台填写一下你要客户端执行的命令即可,就像这样

macrt/bin/java -XX:+UseZGC com.whitewoodcity.Main

steam会帮你把桌面快捷方式什么都建好,所以你交给steam去完成就可以了,当然你也可以自己做,不同平台有不同平台的打包方式,jdk 16也重新提供了jpackage[1]这个工具,你也可以用该工具来打包

也就是说安装本身并非必须,跟模块化什么可以独立开来看,没有必然联系

我们写的都是绿色软件,不是流氓软件,所以不会对客户机器各种绑架。像安装这种事,我一般是懒得做的,我直接丢给你一个可执行文件,你双击运行就可以了,安装什么哦,我对你的机器和隐私不感兴趣

参考

  • ^https://openjdk.java.net/jeps/392

推荐:

主流Java进阶技术(学习资料分享)

a3dba38d601afe5f87ba2363c2137375.png

PS:因为公众号平台更改了推送规则,如果不想错过内容,记得读完点一下“在看”,加个“星标”,这样每次新文章推送才会第一时间出现在你的订阅列表里。点“在看”支持我们吧!

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

知乎的彩蛋

在这篇文章中《Python一个有趣的彩蛋命令行执行python -c "import this"或者在python解释器中执行import this,会打印出Python之禅,另外介绍了个Chrome的彩蛋,在地址栏输入chrome://dino/,就可以打开一个小恐龙跑酷的黑…

设计模式看了又忘,忘了又看?

设计模式收藏这篇就够了 耗时了 5 个月,终于把设计模式一整个系列写完。其实设计模式这一系列文章网上已经有很多非常好、非常优秀的文章,为什么要写呢? 一方面是为了学得更扎实,印象中设计模式学习了 2 遍,记得牢的基…

响铃:IP跨界她经济,同道能讲好“单身婚纱”的故事吗?

文|曾响铃 来源|科技向令说(xiangling0815) 国泰君安证券报告显示,女性消费对经济增长的贡献率接近70%,到2019年中国内地女性经济市场规模近将接近4.5万亿元,而家庭消费中,近75%由女性决策。 由此引发的…

“因为内存泄漏,我的 M1 MacBook Pro 瘫痪了”

整理 | 郑丽媛 出品 | CSDN(ID:CSDNnews) 上个月,苹果在宣布“王炸候场中”后,19 号发布了 AirPods 3、HomePod mini 等新品,而这场发布会真正的主角当属新款 MacBook Pro:强悍的 M1 Pro/M1 Max…

程序员的财务自由之路(五)- 三人行必有吾师

一、前言 给自己树立一个「 目标 」是非常重要的,有「 目标 」才会有「 方向 」,有「 目标 」才会有「 动力 」,有「 目标 」才会有「 人生的意义 」。有了「 目标 」,再做一定的「 规划 」,并且「 坚持 」做下去&…

浅谈脑机接口:传统神经学科的颠覆者

人类从未停止对大脑的研究,然而有关于大脑的探秘如今所发现的也仅仅只是冰山一角,作为神秘的研究领域,脑科学直到下个世纪仍是前沿科学。 早在2001年,美国《麻省理工科技评论》首次提出把脑机接口领域称为将会改变世界的10大新兴技…

程序员坐牢了,会被安排去写代码吗?

点击蓝色“程序员黄小斜”关注我哟 加个“星标”,每天和你一起多进步一点点! 今天给大家分享一篇有意思的爽文,但也是根据多年之前一个真实报道改编而来的。 本文字数较多,建议先收藏,上下班路上、带薪上厕所、浑水…

痞子衡职场经验与感悟分享 - 索引

大家好,我是痞子衡,是正经搞技术的痞子。本系列痞子衡给大家分享的是职场经验与见闻感悟。 痞子衡在嵌入式行业也摸打滚爬了不少年,有一些个人经验可以给大家参考。所谓他山之石可以攻玉,希望痞子衡的经验对大家的职场之路有所帮…

有才天下猎聘股份简称更名为“同道猎聘” 7月31日生效

7月28日晚间,有才天下猎聘(06100)发布公告,公司英文名由“Wise Talent Information Technology Co., Ltd”更改为“Tongdao Liepin Group”,中文双重外文名称已由“有才天下信息技术有限公司”更改为“同道猎聘集团”,均自2020年6…

同道猎聘营收、利润双增:市值3个月回落七成,已被BOSS直聘超越

日前,同道猎聘(HK:06100)发布截至6月30日的2021年中期业绩。财报显示,同道猎聘2021年上半年实现收入11.98亿元,同比增长48.3%;净利润5343.9万元,同比增长57.1%。 同道猎聘称,其收入…

我要学计算机表情包,确认过表情包,怕是遇上学计算机的“同道中人”了

不同的大学专业有着自己的专属表情包,专业知识结合着骚浪贱,皮中带稳还多了点内涵……今天我们来围(bi)观(pin)计算机科学 CS 专业学生才能懂的表情包。 说到计算机, 不禁想起被亲朋好友问专业时的恐惧。 “小伙子学什么的?” “计…

同道伟业完成2400万元A轮融资 深耕足球大数据产业

投资界(微信ID:pedaily2012)6月15日消息,国内领先的足球大数据科技公司——北京同道伟业体育科技有限公司(以下简称同道伟业)宣布完成2400万元A轮投资,本轮融资由华盖资本和丰厚资本共同投资&am…

深度学习知识点全面总结

👨‍💻作者简介:大数据专业硕士在读,CSDN人工智能领域博客专家,阿里云专家博主,专注大数据与人工智能知识分享,公众号:GoAI的学习小屋,免费分享书籍、简历、导图等资料&a…

自度曲.同道

自度曲.同道 道路弯弯弯九曲,倚车凝望窗明。同道半途分手行,君去小坝路,我到吴忠城。 顿想车上欢笑事,如何只剩愁生。身世别后更孤零,跳舞没意思,唱歌无心情。 转载于:https://www.cnblogs.com/ysx4221…

痞子衡嵌入式:我被邀请做科锐国际旗下数科同道主办的技术沙龙嘉宾

「数科同道」是「科锐国际」旗下的面向技术开发者的专属垂直招聘平台。《数科同道技术沙龙》是由数科同道主办的活动,每期活动邀请行业内及其他知名公司的技术专家分享来自一线的实践经验。自2022年12月起,数科同道将在苏州,聚焦嵌入式行业及…

虎牙、斗鱼同道同命:共同御寒

配图来自Canva可画 回顾游戏直播行业过去十年,先是直播行业野蛮发展玩家快速跑马圈地,而后历经千播大战形成斗鱼、虎牙分天下的市场格局,现在头部平台进入精细化、多元化运作阶段,市场竞争愈加激烈。 也就是说,游戏直…

同道大叔创始人蔡跃栋推出的「YOOZ」电子烟,朋友圈一天卖出500万营业额

最近一段时间,电子烟市场迎来了许多新“玩家”。除了烟民们对于电子烟本身开始认可之外,将“春节送烟”转变为“春节送电子烟”也开始成为了一股潮流。 1 月 20 日,前同道大叔创始人蔡跃栋在朋友圈发布了海报——“创业再出发,需…

同道大叔星座大吐槽001 读后感

同道大叔星座大吐槽001 读后感 作者:同道大叔 【少女之友同道开专栏啦!】星座娱乐专家,少女之友同道大叔,内容纯属娱乐。会吐槽,会画画,会卖萌,还能带你上天!这就是同道大叔&…

2023年最全的Web前端开发必知必会详尽知识手册

基础部分 CSS盒模型 标准盒模型:box-sizing: content-box 浏览器默认的标准,元素宽度即为内容宽度。 IE盒模型:box-sizing: border-box 元素宽度为内容宽度边距边框(content padding border width) 相关阅读&a…

Slack Claude插件,实现chatGPT

随着OpenAI发大模型chatGPT推广,AI技术离人们越来越近了,AI可以帮助我们生活,学习,及其工作,但chatGPT资源很紧张,很难申请到,有一个可与chatGPT比美AI工具Clause,可简单在加入插件就…