📄 testcursorablelinkedlist.java
字号:
HashSet set = new HashSet();
set.add("A");
set.add("2");
set.add("C");
set.add("4");
set.add("D");
assertTrue(list.removeAll(set));
assertEquals("[1, 3, 5]",list.toString());
assertTrue(!list.removeAll(set));
}
public void testRemoveByIndex() {
list.add("1");
list.add("2");
list.add("3");
list.add("4");
list.add("5");
assertEquals("[1, 2, 3, 4, 5]",list.toString());
assertEquals("1",list.remove(0));
assertEquals("[2, 3, 4, 5]",list.toString());
assertEquals("3",list.remove(1));
assertEquals("[2, 4, 5]",list.toString());
assertEquals("4",list.remove(1));
assertEquals("[2, 5]",list.toString());
assertEquals("5",list.remove(1));
assertEquals("[2]",list.toString());
assertEquals("2",list.remove(0));
assertEquals("[]",list.toString());
}
public void testRemove() {
list.add("1");
list.add("1");
list.add("2");
list.add("3");
list.add("4");
list.add("5");
list.add("2");
list.add("3");
list.add("4");
list.add("5");
assertEquals("[1, 1, 2, 3, 4, 5, 2, 3, 4, 5]",list.toString());
assertTrue(!list.remove("6"));
assertTrue(list.remove("5"));
assertEquals("[1, 1, 2, 3, 4, 2, 3, 4, 5]",list.toString());
assertTrue(list.remove("5"));
assertEquals("[1, 1, 2, 3, 4, 2, 3, 4]",list.toString());
assertTrue(!list.remove("5"));
assertTrue(list.remove("1"));
assertEquals("[1, 2, 3, 4, 2, 3, 4]",list.toString());
assertTrue(list.remove("1"));
assertEquals("[2, 3, 4, 2, 3, 4]",list.toString());
assertTrue(list.remove("2"));
assertEquals("[3, 4, 2, 3, 4]",list.toString());
assertTrue(list.remove("2"));
assertEquals("[3, 4, 3, 4]",list.toString());
assertTrue(list.remove("3"));
assertEquals("[4, 3, 4]",list.toString());
assertTrue(list.remove("3"));
assertEquals("[4, 4]",list.toString());
assertTrue(list.remove("4"));
assertEquals("[4]",list.toString());
assertTrue(list.remove("4"));
assertEquals("[]",list.toString());
}
public void testRetainAll() {
list.add("1");
list.add("1");
list.add("2");
list.add("2");
list.add("3");
list.add("3");
list.add("4");
list.add("4");
list.add("5");
list.add("5");
HashSet set = new HashSet();
set.add("A");
set.add("2");
set.add("C");
set.add("4");
set.add("D");
assertTrue(list.retainAll(set));
assertEquals("[2, 2, 4, 4]",list.toString());
assertTrue(!list.retainAll(set));
}
public void testSet() {
list.add("1");
list.add("2");
list.add("3");
list.add("4");
list.add("5");
assertEquals("[1, 2, 3, 4, 5]",list.toString());
list.set(0,"A");
assertEquals("[A, 2, 3, 4, 5]",list.toString());
list.set(1,"B");
assertEquals("[A, B, 3, 4, 5]",list.toString());
list.set(2,"C");
assertEquals("[A, B, C, 4, 5]",list.toString());
list.set(3,"D");
assertEquals("[A, B, C, D, 5]",list.toString());
list.set(4,"E");
assertEquals("[A, B, C, D, E]",list.toString());
}
public void testSubList() {
list.add("A");
list.add("B");
list.add("C");
list.add("D");
list.add("E");
assertEquals("[A, B, C, D, E]",list.toString());
assertEquals("[A, B, C, D, E]",list.subList(0,5).toString());
assertEquals("[B, C, D, E]",list.subList(1,5).toString());
assertEquals("[C, D, E]",list.subList(2,5).toString());
assertEquals("[D, E]",list.subList(3,5).toString());
assertEquals("[E]",list.subList(4,5).toString());
assertEquals("[]",list.subList(5,5).toString());
}
public void testSubListAddEnd() {
list.add("A");
list.add("B");
list.add("C");
list.add("D");
list.add("E");
List sublist = list.subList(5,5);
sublist.add("F");
assertEquals("[A, B, C, D, E, F]",list.toString());
assertEquals("[F]",sublist.toString());
sublist.add("G");
assertEquals("[A, B, C, D, E, F, G]",list.toString());
assertEquals("[F, G]",sublist.toString());
}
public void testSubListAddBegin() {
list.add("A");
list.add("B");
list.add("C");
list.add("D");
list.add("E");
List sublist = list.subList(0,0);
sublist.add("a");
assertEquals("[a, A, B, C, D, E]",list.toString());
assertEquals("[a]",sublist.toString());
sublist.add("b");
assertEquals("[a, b, A, B, C, D, E]",list.toString());
assertEquals("[a, b]",sublist.toString());
}
public void testSubListAddMiddle() {
list.add("A");
list.add("B");
list.add("C");
list.add("D");
list.add("E");
List sublist = list.subList(1,3);
sublist.add("a");
assertEquals("[A, B, C, a, D, E]",list.toString());
assertEquals("[B, C, a]",sublist.toString());
sublist.add("b");
assertEquals("[A, B, C, a, b, D, E]",list.toString());
assertEquals("[B, C, a, b]",sublist.toString());
}
public void testSubListRemove() {
list.add("A");
list.add("B");
list.add("C");
list.add("D");
list.add("E");
List sublist = list.subList(1,4);
assertEquals("[B, C, D]",sublist.toString());
assertEquals("[A, B, C, D, E]",list.toString());
sublist.remove("C");
assertEquals("[B, D]",sublist.toString());
assertEquals("[A, B, D, E]",list.toString());
sublist.remove(1);
assertEquals("[B]",sublist.toString());
assertEquals("[A, B, E]",list.toString());
sublist.clear();
assertEquals("[]",sublist.toString());
assertEquals("[A, E]",list.toString());
}
public void testToArray() {
list.add("1");
list.add("2");
list.add("3");
list.add("4");
list.add("5");
Object[] elts = list.toArray();
assertEquals("1",elts[0]);
assertEquals("2",elts[1]);
assertEquals("3",elts[2]);
assertEquals("4",elts[3]);
assertEquals("5",elts[4]);
assertEquals(5,elts.length);
String[] elts2 = (String[])(list.toArray(new String[0]));
assertEquals("1",elts2[0]);
assertEquals("2",elts2[1]);
assertEquals("3",elts2[2]);
assertEquals("4",elts2[3]);
assertEquals("5",elts2[4]);
assertEquals(5,elts2.length);
String[] elts3 = new String[5];
assertSame(elts3,list.toArray(elts3));
assertEquals("1",elts3[0]);
assertEquals("2",elts3[1]);
assertEquals("3",elts3[2]);
assertEquals("4",elts3[3]);
assertEquals("5",elts3[4]);
assertEquals(5,elts3.length);
String[] elts4 = new String[3];
String[] elts4b = (String[])(list.toArray(elts4));
assertTrue(elts4 != elts4b);
assertEquals("1",elts4b[0]);
assertEquals("2",elts4b[1]);
assertEquals("3",elts4b[2]);
assertEquals("4",elts4b[3]);
assertEquals("5",elts4b[4]);
assertEquals(5,elts4b.length);
}
public void testSerialization() throws Exception {
list.add("A");
list.add("B");
list.add("C");
list.add("D");
list.add("E");
java.io.ByteArrayOutputStream buf = new java.io.ByteArrayOutputStream();
java.io.ObjectOutputStream out = new java.io.ObjectOutputStream(buf);
out.writeObject(list);
out.flush();
out.close();
java.io.ByteArrayInputStream bufin = new java.io.ByteArrayInputStream(buf.toByteArray());
java.io.ObjectInputStream in = new java.io.ObjectInputStream(bufin);
Object list2 = in.readObject();
assertTrue(list != list2);
assertTrue(list2.equals(list));
assertTrue(list.equals(list2));
}
public void testLongSerialization() throws Exception {
// recursive serialization will cause a stack
// overflow exception with long lists
for(int i=0;i<10000;i++) {
list.add(new Integer(i));
}
java.io.ByteArrayOutputStream buf = new java.io.ByteArrayOutputStream();
java.io.ObjectOutputStream out = new java.io.ObjectOutputStream(buf);
out.writeObject(list);
out.flush();
out.close();
java.io.ByteArrayInputStream bufin = new java.io.ByteArrayInputStream(buf.toByteArray());
java.io.ObjectInputStream in = new java.io.ObjectInputStream(bufin);
Object list2 = in.readObject();
assertTrue(list != list2);
assertTrue(list2.equals(list));
assertTrue(list.equals(list2));
}
/**
* Ignore the serialization tests for sublists and sub-sublists.
*
* @return an array of sublist serialization test names
*/
public String[] ignoredSimpleTests() {
ArrayList list = new ArrayList();
String prefix = "TestCursorableLinkedList";
String bulk = ".bulkTestSubList";
String[] ignored = new String[] {
".testEmptyListSerialization",
".testFullListSerialization",
".testEmptyListCompatibility",
".testFullListCompatibility",
".testSimpleSerialization",
".testCanonicalEmptyCollectionExists",
".testCanonicalFullCollectionExists"
};
for (int i = 0; i < ignored.length; i++) {
list.add(prefix + bulk + ignored[i]);
list.add(prefix + bulk + bulk + ignored[i]);
}
return (String[])list.toArray(new String[0]);
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -