当前位置: 首页 > 面试题库 >

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

牧飞鹏
2023-03-14
问题内容

我刚刚发现了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();
    }
  }
}

我确实碰到过这样的评论:本地类的优点),列出了本地类相对于匿名内部类的一些巨大优点。

您可以使用匿名内部类无法获得的本地类做很多事情。

* 因为类型有名称,所以您可以更有用地添加不在超类型中的成员
* 给定名称可以使堆栈跟踪更易于跟踪(尤其是对于锁定对象)
* 亚型不只一种基本类型
* 在一个以上的地方构造多个构造函数

另一方面,它们使某些冗长的语法更加混乱。

我的问题是,在许多情况下,这种技术似乎比非匿名内部类具有优势。我的意思是:如果您的类仅在方法范围内有用,则可以使用本地类。但是当您的方法变得如此复杂时,您需要开始在其中定义自定义类,它们可能已经太复杂了,需要进行拆分。在那时,您的本地班级必须成为内部班级,对吗?

什么是局部类比内部类更可取的示例,其中不涉及超复杂方法(应避免使用)?


问题答案:

局部类是在某些特定方法中使用的东西,在其他任何地方都没有。

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

class DecodeConfig {
    int compId;
    int dcTableId;
    int acTableId;
}

基本上,只有三个intS组合在一起。我需要一系列配置,这就是为什么我不能只使用匿名类的原因。如果我曾经用C进行编码,那我会使用一个结构。

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

当然,这是最基本的示例,但这是来自真实生活的。



 类似资料:
  • 问题内容: 我知道他们两个都禁用了Nagle的算法。 我什么时候应该/不应该使用它们中的每一个? 问题答案: 首先,不是所有人都禁用Nagle的算法。 Nagle的算法用于减少有线中更多的小型网络数据包。该算法是:如果数据小于限制(通常是MSS),请等待直到收到先前发送的数据包的ACK,同时累积用户的数据。然后发送累积的数据。 这将对telnet等应用程序有所帮​​助。但是,在发送流数据时,等待A

  • 问题内容: 在该类中,有两个字符串,和。 有什么不同?我什么时候应该使用另一个? 问题答案: 如果你的意思是和则: 用于在文件路径列表中分隔各个文件路径。考虑在上的环境变量。您使用a分隔文件路径,因此在上将是;。 是或用于拆分到特定文件的路径。例如在上,或

  • 关于什么时候使用Docker而不是VM的,有什么指导方针吗?(反之亦然) 在我看来,像NGINX、Apache或Redis这样的服务应该是docker,但我不确定是否应该在HPC环境中使用ElasticSearch docker。 Docker总是比VM好吗?

  • 问题内容: 一个理想的例子是什么时候确切地使用Java中的特定接口,以及适用的任何特定规则。 问题答案: 集合框架是一个不错的选择。 因此,你可以编写如下代码: 如果将来你想使用say 或自己的界面更改实现,那么你要做的就是将第一行更改为: 其余代码将继续进行。

  • 我想知道什么时候可以有效地使用。我不确定到底有多有用,有三个原因。 (请将start和end视为整数。) > 如果我想要一个数组,,下面的代码要快得多。 我不认为仅仅获取从到的数字是有用的。我可以将

  • 问题内容: 我已经用python编程了大约两年了。主要是数据资料(熊猫,mpl,numpy),还有自动化脚本和小型Web应用程序。我试图成为一个更好的程序员,并增加我的python知识,而困扰我的一件事是我从未使用过一个类(除了为小型Web应用程序复制随机烧瓶代码外)。我通常理解它们是什么,但是我似乎无法为为什么在一个简单的函数中需要它们的问题而wrap之以鼻。 为了使我的问题更具针对性:我编写了