在我正在处理的遗留代码库中,有大量的String文字.其中很多都是重复的.例如,字符串“userID”用于500个地方.可能有一千种这样的文字以重复的方式使用. IntelliJ Idea静态代码分析表明我将它们提取为常量.如果IDE为我自动重构,没有我键入一行代码,我应该去吗?
通常,将许多这样的重复字符串文字提取为常量是一个好主意吗?这显然可以避免重复,提供单点访问,声明等.
但是,这些文字中的一些在访问时会出现.如果我将所有文字声明为常量(静态最终),那么所有这些文字将被加载在一起.在这种情况下,将所有这些文字声明为常量是一个好主意吗?你能提供一些指向垃圾收集的指针,在这种情况下的内存空间预防措施吗?在这种情况下使用的最佳做法是什么?
一些注意事项:我知道字符串文字被实习.所以我不会在最坏的情况下保存任何内存.此外,似乎jdk 7将这些字符串放在堆而不是permgen.我看到像我这样的couple of questions,但觉得它与众不同.所以在这里发布.
谢谢
解决方法:
>所有字符串文字都自动实习.从JDK7开始,当类(实际上是加载定义字符串文字的类的类加载器)定义它们时,它们将被GCed(假设没有其他类引用它(尽管很少发生这种情况).使它们成为静态的最终并将它们放入一个公共类中从内存保存的角度来看确实是无用的,但从设计的角度看是有用的,因为它将提供单点访问.
>在JVM中的所有类之间共享相同的字符串文字.所以,没有新的字符串.实际上,将它们放在一个类中并从该位置访问它们会使您的代码更具结构性/可读性.
我的建议是,不要修改遗留代码,除非它有很大的不同.您可以选择权衡取舍. :P