java为什么实现_为什么在java中这样实现了这样的实现?
正如我看到的源代碼:
java.util.AbstractCollection.toArray(),它實現如下:
public Object[] toArray() {
// Estimate size of array; be prepared to see more or fewer elements
Object[] r = new Object[size()];
Iterator it = iterator();
for (int i = 0; i < r.length; i++) {
if (! it.hasNext()) // fewer elements than expected
return Arrays.copyOf(r, i);
r[i] = it.next();
}
return it.hasNext() ? finishToArray(r, it) : r;
}
private static T[] finishToArray(T[] r, Iterator> it) {
int i = r.length;
while (it.hasNext()) {
int cap = r.length;
if (i == cap) {
int newCap = cap + (cap >> 1) + 1;
// overflow-conscious code
if (newCap - MAX_ARRAY_SIZE > 0)
newCap = hugeCapacity(cap + 1);
r = Arrays.copyOf(r, newCap);
}
r[i++] = (T)it.next();
}
// trim if overallocated
return (i == r.length) ? r : Arrays.copyOf(r, i);
}
如您所見,實現并不那么容易理解,我的問題是:
>在迭代期間,當集合的元素發生變化(大小未更改)時,我會得到什么?我想迭代器可能是某種快照.
>當集合的大小發生變化時,我會得到什么?我想知道它是否可以正常工作.
總結
以上是生活随笔為你收集整理的java为什么实现_为什么在java中这样实现了这样的实现?的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 情哥哥情哥哥是哪首歌啊?
- 下一篇: idea java jni 调试_Int