我想避免为此使用纯数组,因为我想要的东西至少具有以下命令
//grows in size if no null's are found.
key = indexOf(value);<br>
remove(key);<br>
add(value);<br>
contains(value);<br>
length(); //size();
向量具有所有这些,除了保持索引顺序不变的部分。
也许我想要的东西已经存在于Java SDK中?有人可以告诉我这叫什么吗?
码:
import java.util.Vector;
public class VectorDemo {
public static void main(String[] args) {
// create an empty Vector vec with an initial capacity of 4
Vector<Integer> vec = new Vector<Integer>(4);
// use add() method to add elements in the vector
vec.add(0,111);
vec.add(1,9999);
vec.add(2,191919);
vec.add(3,-12394);
System.out.println(vec);
vec.remove(2);
System.out.println(vec);
}
}
输出:
Executing the program....
$java -Xmx128M -Xms16M VectorDemo
[111, 9999, 191919, -12394]
[111, 9999, -12394]
当我想要这个输出时
输出:
[111, 9999, 191919, -12394]
[111, 9999, null, -12394]
最佳答案
您可以简单地使用
vec.set(2, null);
要在添加时重用null元素,您可以执行此操作
int i = vec.indexOf(null)
if (i == -1) {
vec.add(obj);
} else {
vec.set(i, obj);
}