gpt4 book ai didi

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

转载 作者:IT老高 更新时间:2023-10-28 20:35:50 25 4
gpt4 key购买 nike

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

我确实看到了这条评论:Advantages of Local Classes其中列出了本地类相对于匿名内部类的一些巨大优势。

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

有哪些本地类比内部类更受欢迎且不涉及超复杂方法(应该避免)的示例?

最佳答案

本地类是在某些特定方法中使用的东西,在其他地方没有。

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

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

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

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

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

关于java - 什么时候应该在 Java 中使用本地类?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3247654/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com