Intellij IDEA / Android studio 可持续开发笔记

Intellij 的Java/安卓工具链有着一种不可持续性,这种不可持续性体现在多个方面。

首先是不可持续运行。IDEA 使用时间越长,内存占用越大,从不主动释放。运行时间越长,日志越多,从不主动清理。

然后是不完整的开源,从源码编译时需要下载更多依赖。而研究更多依赖就要消耗更多的精力与资源……


合理选择 IDEA 与 Gradle 版本

Android studio 是闭源的工具。它使用gradle构建安卓项目。gradle又是从网络下载下来的,至少有三个部分、三种语言。

Android SDK 也是闭源的。并且还附加了使用协议,只能用于为安卓兼容的设备开发app。

IDEA 的 Android Support Plugin 是开源的,效果和 Android studio 基本一致。但仅有内置的 Android 插件还不行,首次编译安卓项目时 IDEA 还需要下载许多资源。

Gradle 的中文意译当为 —— 小混球儿。它也是开源的。但是兼容性很差,需要配合特定版本的 IDEA 才能正常运行。

Gradle wrapper 7,比如 gradle-7.3.3-bin 相比于版本 6 ,增量编译更快。原本十秒,优化至三四秒,甚至1秒。但是版本 7 不支持 IDEA 2023 以前的版本,所报错误匪夷所思:

Querying the mapped value of map … before task ‘:app:compileDebugJavaWithJavac’ has completed is not supported CSDN博客

Android Studio:Gradle project sync failed_unable to find method ''java.lang.string org.gradle-CSDN博客

如果升级最新版本的 IDEA 2023,那么恭喜你,这个问题不出现了。不是因为解决了,而是免费的 IDEA 2023 压根不让你玩安卓,需要付费解锁 ultimate 。

(付费版还内置了辅助机器人)。
如果尝试自行编译 gradle ,那么你会遇到更多问题,占用更多c盘空间。

Gradle / Can not build gradle from source code · Issue #5282 · gradle/gradle

只能用不新不旧的 IDEA 2023.1 。几番测试下来,已经用了 c 盘十个G了……

不新不旧的 IDEA 内置不新不旧的 open jdk 17。这玩意儿最恶心在于强制模块化,许多旧项目需要添加许许多多的 jvm 参数才能编译:

jdk17运行程序报错module java.base does not open java.lang.reflect to unnamed module @_module java.base does not "opens java.lang.reflect-CSDN博客

上面博客是将启动参数放到设置里。我参考的是博客写入 gradle.properties。

如果编译过程使用了gradle插件,可能还需要更多参数,比如我的改成:

org.gradle.jvmargs=-Xmx2048m --add-exports=java.base/sun.nio.ch=ALL-UNNAMED --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.lang.reflect=ALL-UNNAMED --add-opens=java.base/java.io=ALL-UNNAMED  --add-exports=jdk.unsupported/sun.misc=ALL-UNNAMED --add-opens=jdk.compiler/com.sun.tools.javac.model=ALL-UNNAMED  --add-opens=jdk.compiler/com.sun.tools.javac.processing=ALL-UNNAMED   --add-opens=jdk.compiler/com.sun.tools.javac.tree=ALL-UNNAMED \\ --add-opens=jdk.compiler/com.sun.tools.javac.util=ALL-UNNAMED \\ --add-opens=jdk.compiler/com.sun.tools.javac.code=ALL-UNNAMED  

这么一长串启动参数,每一个add-opens都要试出来的,谁懂啊。也可降级,用旧的 jvm 运行 gradle。


解决log无底洞

运行 gradle deamon 会持续记录log,这些日志累积可达 10G、甚至百G,从不自动清理。

Gradle / Gradle logging hygiene · Issue #2688 · gradle/gradle

这个问题仍然存在,按照issue中的方法提高 Log 等级、自定义任务等,只能缓解无法根治。

我的解决方法很有技巧性,配合了符号链接(Symbolic Link) 与 用户空间文件系统(Filesystem in Userspace)。

用户空间文件系统(Filesystem in Userspace): 是虚拟的文件系统,但可以挂载。第三方程序感觉起来,无异于真实文件系统。windows上的fuse是dokanky,持续开源、性能好、上手简单(借鉴官方mirror.c镜像文件系统)。

dokany mirror.c github

自己写的 fuse 可以移花接木,拦截修改,令行禁止:

  1. 可以直接禁止创建log文件,但是那样 gradle deamon 启动崩溃。

  2. 可以禁止写入,但守护进程陷入死循环。

  3. 于是只能循环写入:只允许写入 1kb,超出部分从头写入。

符号链接(Symbolic Link): 有别于普通的lnk快捷方式,会被第三方程序识别为目录,从而达到移花接木的效果。

使用指令创建符号链接: mklink /D deamon V:\deamonX,其中 V:\deamonX 是镜像文件系统,强制IDEA打印日志时循环写入。

为什么不直接将 fuse 挂载到 deamon 呢?因为 dokany 一个线程只能有一个挂载点,为了节省性能,我用一个盘符为所有磁盘开启镜像文件系统,并用不同目录区分不同功能:

在这里插入图片描述
J:\c\ 代表 c 盘回收站内容(解码了文件名乱码,可正常打开)。其中双横杠开头的文件夹代表特殊功能区域:

– encrypt – 是对该磁盘回收站内容的加密镜像。(调用 openssl aes 加密)
– entropy – 是对该磁盘所有文件的加密镜像,以及加密文件的解密镜像。
– equator – 是对该磁盘所有文件的原始镜像,添加了上述日志写入的限制。

这样我就能用一个挂载点,实现许许多多不同的功能。

再配合ahk用户脚本引擎,添加快捷键,可以一键往返真实目录与镜像目录,任意穿梭,方便无比。

所有日志导入一个文件,并限制大小。


解决内存无底洞

其实 c++ 调用 java 方法可以归还内存,实现零泄漏、占用零增长的。不知为何 IDEA 只能持续占用内存,从不归还。

编译几次就整个重启?还可以结束 gradle 守护进程,保留IDEA本体。本体重启守护只需几十秒,很值,只需:

在这里插入图片描述
windows的任务管理器。没谁了吧,mac、linux、安卓哪一个这么能打?

其中图标写着JB二字的进程里,就住着我们的小混球gradle,等他增长到1gb,idea本体4gb的时候就可以结束他,开启新的轮回,实现可持续性编译!

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

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

相关文章

8款最佳可用磁盘空间分析器工具,总有一款你能相中

序言 下面是我对可用磁盘空间分析器工具(有时称为存储分析器)的首选列表。在我的计算机上试用了其中的几个应用程序后,我可以确认这里列出的应用程序100%免费使用,并在确定硬盘驱动器、闪存驱动器或外部驱动器中的内容方面做得很好。其中一些甚至允许你直接从程序中删除文…

蓝桥杯相关算法学习(Python)

一、排序 排序算法是指将一组数据按照某种规则重新排列,使得数据呈现出递增或递减的顺序。常见的排序算法包括冒泡排序、选择排序、插入排序、快速排序、归并排序、堆排序等。 1.冒泡排序 解释: 冒泡排序通过不断交换相邻两个元素的位置,使…

【Spring实战项目】SpringBoot3整合WebSocket+拦截器实现登录验证!从原理到实战

🎉🎉欢迎光临,终于等到你啦🎉🎉 🏅我是苏泽,一位对技术充满热情的探索者和分享者。🚀🚀 🌟持续更新的专栏《Spring 狂野之旅:从入门到入魔》 &a…

蓝牙串口模块、初识AT命令、WiFi模块、WiFi模块使用和编程

蓝牙模块 蓝牙模块,又叫做蓝牙串口模块。 串口透传技术: 透传即透明传送,是指在数据的传输过程中,通过无线的方式这组数据不发生任何形式的改变,仿佛传输过程是透明的一样,同时保证传输的质量,原封不动地到…

166.乐理基础-五声性调式、宫商角徵羽

如果到这五线谱还没记住还不认识的话去看102.五线谱-高音谱号与103.五线谱-低音谱号这两个里,这里面有五线谱对应的音名,对比着看 如果不认识调号去看112.五线谱的调号(一)、113.五线谱的调号(二)、114.快…

让很多人直呼“要失业”的到底是什么?--AIGC

当下,全球科技圈的焦点汇聚AI,ChatGPT还是Midjourney等生成式AI工具,于是在这些生成式AI工具的助推下,诞生了新的人工智能产业方向:AIGC(AI Generated Content)。 一、AIGC是什么? …

数据库加载驱动问题(java.lang.ClassNotFoundException: com.mysql.cj.jdbc.Driver)

java.lang.ClassNotFoundException: com.mysql.cj.jdbc.Driver 遇到此问题,首先检查IDEA外部库中是否有mysql数据库驱动。如下所示: 如果发现外部库中存有mysql数据库驱动,需要在数据库配置文件中查看是否设置有时区mysql8.0以上版本需要设…

智能视频翻译和配音处理工具:Pyvideotrans

pyVideoTrans:一键字幕识别翻译配音带新语言字幕和配音的视频 - 精选真开源,释放新价值。 概览 Pyvideotrans是一款卓著的智能化视频处理系统,专精于视频翻译与配音艺术,以其卓越的技术实力实现对原始视频中音频信息的精准捕捉、…

HWOD:自守数

一、知识点 break只会结束最里面的一层循环 int型数按位比较的时候,可以直接求余比较,无需转换为char型数组后再按下标比较 二、题目 1、描述 自守数是指一个数的平方的尾数等于该数自身的自然数。例如:25^2 625,76^2 5776…

一个页面实现两个滚动条【前端】

一个页面实现两个滚动条【前端】 前言版权推荐一个页面实现两个滚动条最后 前言 2024-4-2 12:54:46 以下内容源自《【前端】》 仅供学习交流使用 版权 禁止其他平台发布时删除以下此话 本文首次发布于CSDN平台 作者是CSDN日星月云 博客主页是https://jsss-1.blog.csdn.net …

AJAX —— 学习(二)

目录 一、利用 JSON 字符串 返回数据 (一)基础代码 (二)原理及实现 二、nodmon 工具 自动重启服务 (一)用途 (二)下载 (三)使用 三、IE 缓存问题 &a…

Paragon NTFS for Mac15直装版2024最新安装包下载

Paragon NTFS for Mac 是一款专为 Mac 用户设计的软件,它解决了 Mac 系统无法直接读写 NTFS 格式硬盘的问题。通过安装这款软件,Mac 用户可以像使用本机磁盘一样,轻松地在 NTFS 格式的硬盘、U 盘等存储设备上读写文件,无需进行任何…