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.mzph.cn/news/782192.shtml

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

相关文章

用html实现一个手风琴相册设计

<!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>手风琴相册设计</title><link rel"stylesheet" href"./style.css"> </head> <body> <h1>Accordio…

Linux 著名的sudo、su是什么?怎么用?

一、su 什么是su&#xff1f; su命令&#xff08;简称是&#xff1a;substitute 或者 switch user &#xff09;用于切换到另一个用户&#xff0c;没有指定用户名&#xff0c;则默认情况下将以root用户登录。 为了向后兼容&#xff0c;su默认不改变当前目录&#xff0c;只设…

【蓝桥杯第十三届省赛】(部分详解)

九进制转十进制 #include <iostream> #include<math.h> using namespace std; int main() {cout << 2*pow(9,3)0*pow(9,2)2*pow(9,1)2*pow(9,0) << endl;return 0; }顺子日期 #include <iostream> using namespace std; int main() {// 请在此…

分布式理论:CAP理论 BASE理论

文章目录 1. CAP定理1.1 一致性1.3 分区容错1.4 矛盾 2. BASE理论3. 解决分布式事务的思路4. 扩展 解决分布式事务问题&#xff0c;需要一些分布式系统的基础知识作为理论指导。 1. CAP定理 Consistency(一致性): 用户访问分布式系统中的任意节点&#xff0c;得到的数据必须一…

python超详细知识点汇总整理

1、注释以及编码格式的声明 单行注释&#xff1a;# &#xff08;后面放上被注释的内容&#xff09;多行注释&#xff1a;字符段落的上下加上三引号 举个例子: ‘’’ …‘’’编码格式的声明&#xff1a;#coding:utf-8 或者是 #codingutf-8 2、代码编写格式和一些琐碎说明 同…

大数据设计为何要分层,行业常规设计会有几层数据

大数据设计通常采用分层结构的原因是为了提高数据管理的效率、降低系统复杂度、增强数据质量和可维护性。这种分层结构能够将数据按照不同的处理和应用需求进行分类和管理&#xff0c;从而更好地满足不同层次的数据处理和分析需求。行业常规设计中&#xff0c;数据通常按照以下…

深入了解Vue中slot的应用

作为一个流行的JavaScript框架&#xff0c;Vue提供了许多灵活而强大的功能&#xff0c;其中之一就是slot&#xff08;插槽&#xff09;。以下详细介绍Vue中slot的用法。 一、什么是slot&#xff1f; 在Vue中&#xff0c;slot是一种用于在组件中承载内容的特殊元素。通常情况下…

暴力破解pdf文档密码

首先安装pdfcrack工具包 apt install pdfcrack 默认密码字典存储在/usr/share/wordlists里&#xff0c;是gz文件&#xff0c;将它解压并copy到pdf目录 然后使用pdfcrack破解 密码在最后一行user-password的单引号里

Python面对对象 - 类的反射机制

Python面对对象类的反射机制是面向对象编程语言中比较重要的功能&#xff0c;可以动态获取对象信息以及动态调用对象。通过字符串形式的类名或属性来访问对应类或属性。 一、对象的反射 1. getattr 获取指定字符串名称的对象属性、方法&#xff1a; 当访问的属性不存在时&#…

【四】【单片机】蜂鸣器,蜂鸣器模块化编程 1000HZ 鸣响 ms 毫秒,利用定时器让蜂鸣器以特定频率响 ms 毫秒

蜂鸣器模块化编程 1000HZ 鸣响 ms 毫秒 //Buzzer.h #ifndef __BUZZER_H__ #define __BUZZER_H__void Buzzer_Time(unsigned int ms);#endifBuzzer.h文件中只含有一个Buzzer_Time函数&#xff0c;这个函数用来让蜂鸣器以1000HZ固定频率发声ms毫秒。 //Buzzer.c #include <REG…

数据仓库的作用和价值

支持管理决策分析 支持管理决策分析 数据仓库集成了企业各类运营和外部数据,为管理者提供了全面透明的数据视图,帮助他们洞察业务动态,发现问题和机遇。 通过多维度的数据分析、预测建模等,能够为企业未来战略制定、投资规划等重大决策提供依据。 案例:沃尔玛的数据仓库囊括了…

Python学习(二)

数据容器 数据容器根据特点的不同&#xff0c;如&#xff1a; 是否支持重复元素是否可以修改是否有序&#xff0c;等 分为5类&#xff0c;分别是&#xff1a; 列表&#xff08;list&#xff09;、元组&#xff08;tuple&#xff09;、字符串&#xff08;str&#xff09;、集…

09_Web组件

文章目录 Web组件Listener监听器ServletContextListener执行过程 Filter过滤器Filter与Servlet的执行 案例&#xff08;登录案例&#xff09; 小结Web组件 Web组件 JavaEE的Web组件&#xff08;三大Web组件&#xff09;&#xff1a; Servlet → 处理请求对应的业务Listener →…

Linux利用Jenkins部署SpringBoot项目保姆级教程

在当今快速发展的软件开发领域&#xff0c;持续集成和持续部署&#xff08;CI/CD&#xff09;已经成为提升开发效率、缩短产品上市时间的关键实践。Linux系统以其稳定性和开源友好性&#xff0c;成为众多开发者和企业的首选平台。而Spring Boot&#xff0c;作为一个轻量级的Jav…

飞天使-k8s知识点28-kubernetes散装知识点5-helm安装ingress

文章目录 安装helm添加仓库下载包配置创建命名空间安装 安装helm https://get.helm.sh/helm-v3.2.3-linux-amd64.tar.gztar -xf helm-v3.2.3-linux-amd64.tar.gzcd linux-amd64mv helm /usr/local/bin修改/etc/profile 文件&#xff0c;修改里面内容,然后重新启用export PATH$P…

【3月比赛合集】5场可报名的「创新应用」、「数据分析」和「程序设计」大奖赛,任君挑选!

CompHub[1] 实时聚合多平台的数据类(Kaggle、天池…)和OJ类(Leetcode、牛客…&#xff09;比赛。本账号会推送最新的比赛消息&#xff0c;欢迎关注&#xff01; 以下信息仅供参考&#xff0c;以比赛官网为准 目录 创新应用赛&#xff08;2场比赛&#xff09;数据分析赛&#…

深入理解 Hadoop 上的 Hive 查询执行流程

在 Hadoop 生态系统中&#xff0c;Hive 是一个重要的分支&#xff0c;它构建在 Hadoop 之上&#xff0c;提供了一个开源的数据仓库系统。它的主要功能是查询和分析存储在 Hadoop 文件中的大型数据集&#xff0c;包括结构化和半结构化数据。Hive 在数据查询、分析和汇总方面发挥…

微服务篇-C 深入理解第一代微服务(SpringCloud)_VII 深入理解Swagger接口文档可视化管理工具

原创作者&#xff1a;田超凡&#xff08;程序员田宝宝&#xff09; 版权所有&#xff0c;引用请注明原作者&#xff0c;严禁复制转载 Part 1 理论部分 1 传统API接口文档存在的问题&#xff1f; 1 对API接口文档进行更新的时候&#xff0c;需要及时将变化通知前端开发人员&…

如何使用 Python 本地客户端操作读写云服务器 Redis 缓存数据库详细教程(更新中)

Redis 基本概述 Redis&#xff08;Remote Dictionary Server&#xff09;是一个开源的使用 ANSI C 语言编写的、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库&#xff0c;并提供多种语言的 API。它通常被称为数据结构服务器&#xff0c;因为值&#xff08;value…

本地虚拟机服务器修改站点根目录并使用域名访问的简单示例

说明&#xff1a;本文提及效果是使用vmware虚拟机&#xff0c;镜像文件是Rocky8.6 一、配置文件路径 1. /etc/httpd/conf/httpd.conf #主配置文件 2. /etc/httpd/conf.d/*.conf #调用配置文件 调用配置文件的使用&#xff1a; vim /etc/httpd/conf.d/webpage.conf 因为在主配…