什么时候应该在Java中使用本地类?

Tom*_*sky 23 java oop

我刚刚在Java中发现了本地类:

public final class LocalClassTest
{
  public static void main(final String[] args) {
    for(int i = 10; i > 0; i--) {
      // Local class definition--declaring a new class local to the for-loop
      class DecrementingCounter {
        private int m_countFrom;

        public DecrementingCounter(final int p_countFrom) {
          m_countFrom = p_countFrom;
        }

        public void count() {
          for (int c = m_countFrom; c > 0; c--) {
            System.out.print(c + " ");
          }
          System.out.println();
        }
      }

      // Use the local class
      DecrementingCounter dc = new DecrementingCounter(i);
      dc.count();
    }
  }
}
Run Code Online (Sandbox Code Playgroud)

我确实遇到过这样的评论:Local Classes的优点,它列出了本地类对匿名内部类的一些巨大优势.

我的问题是,似乎很多情况下这种技术优于非匿名内部类.我的意思是:如果你的类只在方法范围内有用,你会使用本地类.但是当你的方法到达它们如此复杂时,你需要开始在它们内部定义自定义类,它们可能已经太复杂了,需要拆分.那时,你的本地班级必须成为内部班级,对吗?

什么是当局部类比内部类更可取时的一些例子,它们不涉及超复杂的方法(应该避免)?

Mal*_*olm 9

本地类是某种特定方法中使用的东西,而不是其他任何方法.

让我举一个例子,我在JPEG解码器/编码器中使用本地类,当我从文件中读取配置时将确定进一步的解码过程.它看起来像这样:

class DecodeConfig {
    int compId;
    int dcTableId;
    int acTableId;
}
Run Code Online (Sandbox Code Playgroud)

基本上它只是三个int组合在一起.我需要一系列配置,这就是为什么我不能只使用匿名类.如果我用C编码,我会使用一个结构.

我可以使用内部类来完成此操作,但所有解码过程都在一个方法中处理,我不需要在其他地方使用配置.这就是本地课程足够的原因.

当然,这是最基本的例子,但它来自现实生活.

  • 你为什么选择把这个“结构”变成一个本地类而不是一个私有内部类?它只在单个方法中使用?你说这个方法有多复杂? (2认同)
  • 确切地说,它不会在其他任何地方使用.这是主要原因.该方法并不复杂(顺便说一下,在100 SLoC下),但它有两个部分.第一部分是读取几个配置并将它们存储在一个数组中.第二部分是使用这些配置来解码以下数据.此过程在非常高的级别上完成,较低级别的代码隐藏在其他类中.完成解码后,我不再需要这些配置了.也许我应该编辑我的答案来解释为什么我在这种情况下使用本地类,我只是说明了我如何使用它(但这个事实暗示). (2认同)