自动分析和修改 Java 代码

2016-09-17 14:36:44 +08:00
 sorra

两年前,我在某外企完成了一个逾一年的探索性项目:自动把基于 EJB 全家桶的 200 万行程序迁移到自研框架全家桶,修改了 40 余万行代码。项目大获成功。

然后我把项目中最基础的一小部分,重写成一个开源的 toolkit : https://github.com/sorra/Exia

这个 toolkit 只支持到 Java 7 ,眼看着 Java 8 要普及了,我觉得不能白费了当年的苦心,任由这个项目默默无闻飘荡在风中。如果有人用,我考虑支持 Java 8 或 Kotlin ,也可以尝试支持更多语言(仅限静态语言)。

它能做什么事呢?举个例子,除了从一个框架迁移到另一个框架(需要一些二次开发的工作量)之外,还可以:

  1. 自动修改日志代码

    logger.debug(...); 优化为 if(logger.isDebugEnabled()) { logger.debug(...); }

  2. 自动适配新接口

    如果方法 void act(Message message) 被改为 void act(Message message, Context context)

    那么所有调用位置的act(message) 改为 act(message, context)

    如果作用域中没有 context 对象,可以自动插入相关的依赖注入代码 @Inject Context context;

  3. 同步转异步(或 异步转同步)

    这个相当于从一个同步编程框架迁到一个异步编程框架,此处就不赘述了。

那么问题来了, V 友们有没有什么点子来利用这套东西?

PS: 实现原理已分享于系列文章 http://www.qingjingjie.com/blogs/2

2245 次点击
所在节点    分享创造
9 条回复
Lonely
2016-09-17 15:17:24 +08:00
马克一下,回去再看
murmur
2016-09-17 15:18:41 +08:00
logger.debug(...); 优化为 if(logger.isDebugEnabled()) { logger.debug(...); }
这个不是在 logger 里做手脚就可以么 或者干脆 log level >= info
holmesabc
2016-09-17 15:24:00 +08:00
@murmur 这种影响还是蛮大的,少函数调用,还有字符串拼接的消耗。

不过既然可以改成 if(debug)...的形式,不啥不直接在编译后自动干掉这部分代码呢?
sorra
2016-09-17 15:56:31 +08:00
@murmur 如果性能开销是在参数计算,就无法靠改 logger 解决了
ihuotui
2016-09-17 18:58:18 +08:00
万能适配器?
WhatIf
2016-09-18 08:32:45 +08:00
@murmur 做手脚也没用,因为运行时先执行 debug 方法的参数,于是浪费计算资源。

至于楼主,第二点可以简单用暴力 aop 解决

第三点听起来不错
murmur
2016-09-18 08:40:12 +08:00
@WhatIf 什么样的企业计算瓶颈不在数据库在日志处理呢
sorra
2016-09-18 11:54:23 +08:00
@murmur 当数据命中缓存时,数据处理和日志处理的性能开销是一个数量级了
WhatIf
2016-09-18 12:58:55 +08:00
@murmur 然而并不是瓶颈问题,只是为了不浪费而已,属于某种洁癖吧,顺带一些微小的优化而已。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/306750

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX