V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
sorra
V2EX  ›  分享创造

自动分析和修改 Java 代码

  •  1
     
  •   sorra ·
    sorra · 2016-09-17 14:36:44 +08:00 · 2239 次点击
    这是一个创建于 2981 天前的主题,其中的信息可能已经有所发展或是发生改变。

    两年前,我在某外企完成了一个逾一年的探索性项目:自动把基于 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

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

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

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

    第三点听起来不错
    murmur
        7
    murmur  
       2016-09-18 08:40:12 +08:00
    @WhatIf 什么样的企业计算瓶颈不在数据库在日志处理呢
    sorra
        8
    sorra  
    OP
       2016-09-18 11:54:23 +08:00
    @murmur 当数据命中缓存时,数据处理和日志处理的性能开销是一个数量级了
    WhatIf
        9
    WhatIf  
       2016-09-18 12:58:55 +08:00
    @murmur 然而并不是瓶颈问题,只是为了不浪费而已,属于某种洁癖吧,顺带一些微小的优化而已。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   4578 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 41ms · UTC 10:00 · PVG 18:00 · LAX 02:00 · JFK 05:00
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.