标签:java string memory-management constants static-analysis
在我正在处理的遗留代码库中,有大量的String文字.其中很多都是重复的.例如,字符串“userID”用于500个地方.可能有一千种这样的文字以重复的方式使用. IntelliJ Idea静态代码分析表明我将它们提取为常量.如果IDE为我自动重构,没有我键入一行代码,我应该去吗?
通常,将许多这样的重复字符串文字提取为常量是一个好主意吗?这显然可以避免重复,提供单点访问,声明等.
但是,这些文字中的一些在访问时会出现.如果我将所有文字声明为常量(静态最终),那么所有这些文字将被加载在一起.在这种情况下,将所有这些文字声明为常量是一个好主意吗?你能提供一些指向垃圾收集的指针,在这种情况下的内存空间预防措施吗?在这种情况下使用的最佳做法是什么?
一些注意事项:我知道字符串文字被实习.所以我不会在最坏的情况下保存任何内存.此外,似乎jdk 7将这些字符串放在堆而不是permgen.我看到像我这样的couple of questions,但觉得它与众不同.所以在这里发布.
谢谢
解决方法:
>所有字符串文字都自动实习.从JDK7开始,当类(实际上是加载定义字符串文字的类的类加载器)定义它们时,它们将被GCed(假设没有其他类引用它(尽管很少发生这种情况).使它们成为静态的最终并将它们放入一个公共类中从内存保存的角度来看确实是无用的,但从设计的角度看是有用的,因为它将提供单点访问.
>在JVM中的所有类之间共享相同的字符串文字.所以,没有新的字符串.实际上,将它们放在一个类中并从该位置访问它们会使您的代码更具结构性/可读性.
我的建议是,不要修改遗留代码,除非它有很大的不同.您可以选择权衡取舍. :P
标签:java,string,memory-management,constants,static-analysis 来源: https://codeday.me/bug/20190824/1711424.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。