- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在设计一个简单的类子类化 ArrayList<Color>
.在我的应用程序上下文中,此列表充当“引用列表”,返回 Color
遵循循环且定义明确的顺序的对象。
@SuppressWarnings("serial")
public final class ColorList extends ArrayList<Color> {
private static int colorIndex = -1;
public ColorList() {
this.add(Color.CYAN);
this.add(Color.DARK_GRAY);
this.add(Color.GRAY);
this.add(Color.GREEN);
this.add(Color.BLUE);
this.add(Color.LIGHT_GRAY);
this.add(Color.MAGENTA);
this.add(Color.ORANGE);
this.add(Color.PINK);
this.add(Color.RED);
this.add(Color.YELLOW);
}
//if the color chosen is not the last one, increment index and get it.
public Color getNextColor() {
Color color = null;
if(colorIndex != this.size() - 1) {
color = this.get(++colorIndex);
}
else {
colorIndex = -1;
color = this.get(++colorIndex);
}
return color;
}
出于这个原因,我想让这个类不可变,因为它旨在成为一个只读列表,其内容在对象首次实例化时定义,并在其整个生命周期内保持不变。同时,我需要能够利用 getNextColor()
保持“循环”时尚。
采取的方法
返回不可修改的引用。
public static List<Color> getInstance(){
return Collections.unmodifiableList(new ColorList());
}
这种方法的问题在于,通过返回一个 List 引用它阻止我调用 getNextColor()
方法,使我的类无用。转换并不能解决问题,因为底层对象是一个UnmodifiableRandomAccessList
的实例并且不能转换为 ColorList
.
覆盖引用可选操作的方法
@Override
public boolean add(Color c) {
throw new UnsupportedOperationException("color list is read-only");
}
<overridding other methods such as addAll, remove...>
如 documentation 中所述,一些标记为“可选”的操作可能会或可能不会根据集合的目的来实现。但这会阻止我首先添加颜色,就像我在实例化对象时在构造函数中所做的那样。
我想我可能误解了一些关键的设计方面。有没有办法让我的类不可变,而不限制其(已经是基本的)功能?
编辑:出于向后兼容性的原因,要求此类显式扩展 ArrayList。因此我不能使用包装类,尽管我也认为这是最正确的方法。
最佳答案
如果你希望 List 的内容是不可变的,那么你的构造函数就可以工作,只是你应该调用 super.add(...)
而不是 this.add (...)
;这样做意味着您对 add(...)
的覆盖将是明智的,可以保护列表免受外部干扰,同时允许构造函数为您初始化对象。
你的问题不清楚,但如果你还想阻止直接访问列表中的对象,你显然也可以重写 get(...)
和其他适当的方法 - 尽管如果你做,那么你的 getNextColor(...)
方法应该调用 super.get(...)
而不是 this.get(...)
.
最后,您可能不需要 colors
成员变量,因为您正在扩展一个 List - 没有必要在其中嵌套另一个 List。
关于java - 创建 ArrayList 的不可变子类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50189773/
将一个数组列表分配给另一个数组列表与在两个数组列表之间使用 addAll 方法有什么区别? 1 > arrayList = arrayList;//应该将后面的arrayList的值分配给第一个。 2
所以我在将 ArrayList 添加到我的 ArrayList 时遇到了一些问题。将其想象成一张 table 。 下面是一些示例代码: ArrayList currentRow = new Arra
我一直在尝试转换 ArrayList> to ArrayList> 的字符串 这是我尝试构建的代码。 public void convertString (ArrayList> templist) {
我有一个 ArrayList (alal) 和一个 ArrayList(al) 的 ArrayList。我想将 al 插入 alal,但我希望 alal.get(0) 包含 al 拥有的所有内容以及添
很抱歉标题太长,如果您能想到更好的标题,请告诉我! 我正在做的是尝试创建一个 ArrayList 的 ArrayList 并将 ArrayList 逐个添加到其中。两个AL>我所拥有的称为三角形和正方
我有带有值的 mList2。存在具有相同 id 的值。如何获取具有相同 id 的对象分组的 List 或 ArrayList 并将其添加到 ArrayList>? List mList2 = list
我正在创建一个 ArrayList的 ArrayList并添加 ArrayLists给它。但每次我对 ArrayList 进行更改时, 它反射(reflect)在 ArrayList 中. 示例: L
谁能解释一下ArrayList之间的区别是什么? , ArrayList和 ArrayList是什么时候使用它们?它们在实现层面上是相同的还是各自具有不同的含义? 最佳答案 ArrayList 特别是
这个问题在这里已经有了答案: Java generics: List> = new LinkedList>() is prohibited? (3 个答案) 关闭 9 年前。 为什么这段代码可以编译
我的 arraylistS 在覆盖数组列表中的行为类似于同一个实例。 我用其中一个来操作 i=0; manupulate((ArrayList)theCoveringRootArrayList.get
我们遇到这个错误 java.lang.NullPointerException at java.util.ArrayList.(Unknown Source) at de.mystuf
据我了解,ArrayList 类继承其父“List”类的 equals() 函数来查找两个成员对象是否相同。这是否意味着“contains()”线性搜索(使用“equal”)来查找 ArrayList
这个问题已经有答案了: What is the diamond operator in Java? (2 个回答) 已关闭 7 年前。 正如标题所说,在Java中,这两种语句有什么区别吗? 通常我都能
我正在尝试求解帕斯卡三角形。我有两个用 Java 编写的代码片段,第一个创建 inner ArrayList 几次并且对我来说效果很好。 但是在代码的第二个版本中,如果我修改 inner ArrayL
正如标题所示,我有两个 ArrayList。奇怪的是,在一个数组列表上设置一个值会改变另一个数组列表的值。 一些信息:这些是 Entry 类型的 ArrayList,每个列表都包含一个金额和一个值(这
我已经添加了一个项目到列表 a,然后添加了列表 a 到列表 b 并再次做了同样的事情。 我的问题是,如果我打印 b.get(0) 和 b.get(1),我会得到相同的列表,这两个项目都是 “一”和“二
我正在创建一个 ArrayList of ArrayList of ArrayList 的 ArrayList 并按以下方式填充它。它正确地填充它。我已经通过调试和 println 弄清楚了这一点。但
实现可以在 Arraylist 和 Integer 中存储任何级别的 ArrayList 的 ArrayList 的最佳方法是什么。 List> list = ArrayList(); 仅允许列表中最
在下面的示例中,我将如何将 ArrayList al4 的内容与其他 ArrayList 中的任何一个进行比较?以同样的方式,我将 al1 与 al2 进行了比较。 import java.util.
好的,所以我之前发布了一个线程,它回答了我的很多问题并帮助我改进了我的代码,但是,我遇到了另一个问题,我不知道为什么,但我认为也许该副本只是指向原始对象..(尽管我已尽力避免这种情况) 在我的游戏代码
我是一名优秀的程序员,十分优秀!