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