欢迎来到天天文库
浏览记录
ID:9019813
大小:35.00 KB
页数:3页
时间:2018-04-15
《开发者应该避免使用的6个java功能》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库。
1、作者从多年的经验中吸取到,有六个JavaSE功能/API是不提倡Java程序员使用的,它们分别是Reflection、Bytecodemanipulation、ThreadLocals、Classloaders、Weak/Softreferences、Sockets。本文作者是一名拥有多年Java开发经验的程序员,他从经验中得出,并不是所有的JavaSE功能/API都值得程序员去使用,比如本文列举的这6个,大家在使用前得慎重对待。以下是对原文的摘译。多年的Java开发经验告诉我,从长远角度来看,以下这些JavaSE功能/API,开发
2、者最好停止使用。 ·Reflection·Bytecodemanipulation ·ThreadLocals·Classloaders·Weak/Softreferences·Sockets 1.ReflectionReflection即反射,在许多流行的库里面都有反射机制,比如Spring和Hibernate。通过对业务代码进行反思,我建议大家避免使用反射。下面列出我反对使用的原因:首先涉及到代码可读性/工具支持。打开IDE并且在Java代码里找到相互依赖关系。使用relection替换方法调用,并且试着重复该步骤。事情变的愈发
3、不可收拾,正常情况下都应该封装好了再修改状态。下面来看看具体代码示例:1234567891011121314151617public class Secret{ private Stringsecrecy; public Secret(Stringsecrecy){ this.secrecy=secrecy; } public StringgetSecrecy(){ return null; }}public class TestSecrecy{ public stat
4、ic void main(String[]args) throws Exception{ Secrets= new Secret("TOPSECRET"); Fieldf=Secret.class.getDeclaredField("secrecy"); f.setAccessible(true); System.out.println(f.get(s)); }}通过查看以上代码可以得知,方法getDeclaredField()参数只有在运行时才可以被发现。而你也清楚,运
5、行时产生的bug总比不执行脚本要更加棘手。其次,反射调用优化是由JIT执行的,一些优化可能需要花费很长时间才能得到应用,而有些优化甚至都得不到应用,所以关于反射的性能优化有时会被数量化。但在一个典型的业务应用程序中——你可能不会真正意识到这些性能开销。总之,开发者应该通过AOP合理地在业务层使用反射,除此以外,你最好离它远远的。2.Bytecodemanipulation.字节码操作,如果我看到你在JavaEE应用程序里直接使用CGLIB或ASM,我可能会立即跑开。最糟糕的事情莫过于在编译期间没有任何可执行的代码。实际上,当产品在运
6、行时,你根本不知道哪块代码在运行。所以,当你遇到麻烦时,会自然地把错误抛给运行时故障排除和调试,不过这样反而会更麻烦。3.ThreadLocals这里有两个不相关的原因,当我在业务层代码里看到ThreadLocals时会颤抖。首先,在ThreadLocals的帮助里,你可能会看到许多变量的使用都没有通过方法调用链来明确地向下传递。这在某些场合下是有用的,但当你一旦粗心,你会在代码里构建许多意料不到的依赖关系。第二个不相关的原因与我日常的工作相关,在ThreadLocals里存储数据会引发内存泄露。最起码我遇到的Permgen泄露有十
7、分之一都是使用ThreadLocals造成的,在结合了类加载器和线程池后,“java.lang.OutOfMemoryError:Permgenspace”异常可能就马上出现了。4.Classloaders首先,类加载器是一个复杂的野兽。你必须先了解它的层次结构、委托机制、类缓存等等。即使你认为自己已经掌握了,它可能还是不能正常工作。最终将导致一个类加载器泄露问题。因此我只能建议你将这个任务留给应用服务器处理5.Weak/Softreferences现在,你应该更好的理解Java的内部方法。使用软引用来重写所有的缓存并不明智。我知道
8、,当你手上拿着锤子的时候,就会到处寻找钉子。可对于锤子来说,缓存并不是个好钉子。为什么?基于软引用构建缓存可能是如何委托一些复杂因素到GC而不是通过自身实现的一个好例子。下面举个缓存的例子,你使用软引用来创建数据,当内存被耗尽时,GC
此文档下载收益归作者所有