我想避免为此使用纯数组,因为我想要的东西至少具有以下命令

//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);
   }

07-24 09:45
查看更多