當前位置: 首頁>>代碼示例>>Java>>正文


Java ConcurrentModificationException類代碼示例

本文整理匯總了Java中java.util.ConcurrentModificationException的典型用法代碼示例。如果您正苦於以下問題:Java ConcurrentModificationException類的具體用法?Java ConcurrentModificationException怎麽用?Java ConcurrentModificationException使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


ConcurrentModificationException類屬於java.util包,在下文中一共展示了ConcurrentModificationException類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: remove

import java.util.ConcurrentModificationException; //導入依賴的package包/類
public void remove() {
    if (lastReturned == null) {
        throw new IllegalStateException();
    }
    if (fast) {
        synchronized (WeakFastHashMap.this) {
            if (expected != map) {
                throw new ConcurrentModificationException();
            }
            WeakFastHashMap.this.remove(lastReturned.getKey());
            lastReturned = null;
            expected = map;
        }
    } else {
        iterator.remove();
        lastReturned = null;
    }
}
 
開發者ID:yippeesoft,項目名稱:NotifyTools,代碼行數:19,代碼來源:WeakFastHashMap.java

示例2: forEachRemaining

import java.util.ConcurrentModificationException; //導入依賴的package包/類
@Override
public void forEachRemaining(Consumer<? super T> action) {
    Objects.requireNonNull(action);
    Object eol = endOfList;
    Object p;
    int n;
    if ((n = getEst()) > 0 && (p = current) != eol) {
        current = eol;
        est = 0;
        do {
            T item = getNodeItem(p);
            p = getNextNode(p);
            action.accept(item);
        } while (p != eol && --n > 0);
    }
    if (expectedModCount != getModCount(list)) {
        throw new ConcurrentModificationException();
    }
}
 
開發者ID:retrostreams,項目名稱:android-retrostreams,代碼行數:20,代碼來源:LinkedListSpliterator.java

示例3: next

import java.util.ConcurrentModificationException; //導入依賴的package包/類
/**
 * Returns the next element in the iteration.
 * @return The next element in the iteration.
 * @throws ConcurrentModificationException If collection is updated while iterating through.
 * @throws NoSuchElementException If the iteration has no more elements.
 */
@Override
public TableEntry next() {
	if(expModificationCount != modificationCount) {
		throw new ConcurrentModificationException("Collection is updated while iterating through!");
	}
	for(; currentIndex < table.length; currentIndex++) {
		if(table[currentIndex] != null) {
			if(current == null) {
				current = lastReturned = table[currentIndex];
				current = current.next;
			} else {
				lastReturned = current;
				current = current.next;
			}
			if(current == null) {
				currentIndex++;
			}
			count++;
			return lastReturned;
		}
	}
	throw new NoSuchElementException("There is no more elements in collection!");
}
 
開發者ID:fgulan,項目名稱:java-course,代碼行數:30,代碼來源:SimpleHashtable.java

示例4: statusSolutionInfo

import java.util.ConcurrentModificationException; //導入依賴的package包/類
@Override
public Map<String,String> statusSolutionInfo() {
	if (isPassivated())
		return (iBestSolutionInfoBeforePassivation == null ? iCurrentSolutionInfoBeforePassivation : iBestSolutionInfoBeforePassivation);
    Lock lock = currentSolution().getLock().readLock();
    lock.lock();
    try {
		Map<String,String> info = super.currentSolution().getBestInfo();
		try {
			Solution<V, T> solution = getWorkingSolution();
			if (info == null || getSolutionComparator().isBetterThanBestSolution(solution))
				info = solution.getModel().getInfo(solution.getAssignment());
		} catch (ConcurrentModificationException e) {}
		return info;
    } finally {
    	lock.unlock();
	}
}
 
開發者ID:Jenner4S,項目名稱:unitimes,代碼行數:19,代碼來源:AbstractSolver.java

示例5: remove

import java.util.ConcurrentModificationException; //導入依賴的package包/類
public void remove() {
    if (lastRet < 0) {
        throw new IllegalStateException();
    }

    if (modCount != expectedModCount) {
        throw new ConcurrentModificationException();
    }

    try {
        UnsafeList.this.remove(lastRet);
        index = lastRet;
        lastRet = -1;
        expectedModCount = modCount;
    } catch (IndexOutOfBoundsException ex) {
        throw new ConcurrentModificationException();
    }
}
 
開發者ID:UraniumMC,項目名稱:Uranium,代碼行數:19,代碼來源:UnsafeList.java

示例6: replaceAll

import java.util.ConcurrentModificationException; //導入依賴的package包/類
public void replaceAll(UnaryOperator<E> operator) {
    if (operator == null) throw new NullPointerException();
    final ReentrantLock lock = l.lock;
    lock.lock();
    try {
        int lo = offset;
        int hi = offset + size;
        Object[] elements = expectedArray;
        if (l.getArray() != elements)
            throw new ConcurrentModificationException();
        int len = elements.length;
        if (lo < 0 || hi > len)
            throw new IndexOutOfBoundsException();
        Object[] newElements = Arrays.copyOf(elements, len);
        for (int i = lo; i < hi; ++i) {
            @SuppressWarnings("unchecked") E e = (E) elements[i];
            newElements[i] = operator.apply(e);
        }
        l.setArray(expectedArray = newElements);
    } finally {
        lock.unlock();
    }
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:24,代碼來源:CopyOnWriteArrayList.java

示例7: next

import java.util.ConcurrentModificationException; //導入依賴的package包/類
@Override
public Long next() {
    if (modCount != expectedModCount) {
        throw new ConcurrentModificationException();
    }

    int length = values.length;
    if (index >= length) {
        lastReturned = -2;
        throw new NoSuchElementException();
    }

    lastReturned = index;
    for (index += 1; index < length && (values[index] == FREE || values[index] == REMOVED); index++) {
        // This is just to drive the index forward to the next valid entry
    }

    if (values[lastReturned] == FREE) {
        return FREE;
    } else {
        return values[lastReturned];
    }
}
 
開發者ID:UraniumMC,項目名稱:Uranium,代碼行數:24,代碼來源:LongHashSet.java

示例8: toString

import java.util.ConcurrentModificationException; //導入依賴的package包/類
@Override
public String toString() {
    String ret = super.toString();
    if (this.responses.isEmpty() == false) {
        ret += "\n-------------\n";
        String debug = "";
        while (true) {
            try {
                debug = StringUtil.join("\n", this.responses); 
            } catch (ConcurrentModificationException ex) {
                continue;
            }
            break;
        }
        ret += debug;
    }
    return (ret);
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:19,代碼來源:LocalInitQueueCallback.java

示例9: doBuildCache

import java.util.ConcurrentModificationException; //導入依賴的package包/類
private BridgeTable<String> doBuildCache(String tenantId)
{
    List<AuthorityBridgeLink> links = authorityBridgeDAO.getAuthorityBridgeLinks();
    BridgeTable<String> bridgeTable = new BridgeTable<String>();
    try
    {
        for (AuthorityBridgeLink link : links)
        {
            bridgeTable.addLink(link.getParentName(), link.getChildName());
        }
    }
    catch (ConcurrentModificationException e)
    {
        // Explain exception
        checkCyclic(links);
        // If cyclic groups is not the cause then rethrow
        throw e;
    }
    return bridgeTable;
}
 
開發者ID:Alfresco,項目名稱:alfresco-repository,代碼行數:21,代碼來源:AuthorityBridgeTableAsynchronouslyRefreshedCache.java

示例10: ensureNext

import java.util.ConcurrentModificationException; //導入依賴的package包/類
private void ensureNext() {
  if (trackModification && modification != iterModification) {
    throw new ConcurrentModificationException("modification=" + modification
        + " != iterModification = " + iterModification);
  }
  if (next != null) {
    return;
  }
  if (cur == null) {
    return;
  }
  next = cur.getNext();
  if (next == null) {
    next = nextNonemptyEntry();
  }
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:17,代碼來源:LightWeightGSet.java

示例11: remove

import java.util.ConcurrentModificationException; //導入依賴的package包/類
/**
 * Removes the last entry returned by the iterator.
 * Invoking this method more than once for a single entry
 * will leave the underlying data structure in a confused
 * state.
 */
public void remove() {
    if (_expectedSize != _hash.size()) {
        throw new ConcurrentModificationException();
    }

    // Disable auto compaction during the remove. This is a workaround for bug 1642768.
    try {
        _hash.tempDisableAutoCompaction();
        _hash.removeAt(_index);
    }
    finally {
        _hash.reenableAutoCompaction( false );
    }

    _expectedSize--;
}
 
開發者ID:JianpingZeng,項目名稱:xcc,代碼行數:23,代碼來源:THashPrimitiveIterator.java

示例12: next

import java.util.ConcurrentModificationException; //導入依賴的package包/類
@Override
public T next() {
  if (modification != startModification) {
    throw new ConcurrentModificationException("modification="
        + modification + " != startModification = " + startModification);
  }
  if (next == null) {
    throw new NoSuchElementException();
  }
  final T e = next.element;
  // find the next element
  final LinkedElement<T> n = next.next;
  next = n != null ? n : nextNonemptyEntry();
  return e;
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:16,代碼來源:LightWeightHashSet.java

示例13: testPutAbsentConcurrentWithValueIteration

import java.util.ConcurrentModificationException; //導入依賴的package包/類
@MapFeature.Require({FAILS_FAST_ON_CONCURRENT_MODIFICATION, SUPPORTS_PUT})
@CollectionSize.Require(absent = ZERO)
public void testPutAbsentConcurrentWithValueIteration() {
  try {
    Iterator<V> iterator = getMap().values().iterator();
    put(e3());
    iterator.next();
    fail("Expected ConcurrentModificationException");
  } catch (ConcurrentModificationException expected) {
    // success
  }
}
 
開發者ID:zugzug90,項目名稱:guava-mock,代碼行數:13,代碼來源:MapPutTester.java

示例14: retainAll

import java.util.ConcurrentModificationException; //導入依賴的package包/類
public boolean retainAll(Collection<?> c) {
    if (c == null) throw new NullPointerException();
    boolean removed = false;
    final ReentrantLock lock = l.lock;
    lock.lock();
    try {
        int n = size;
        if (n > 0) {
            int lo = offset;
            int hi = offset + n;
            Object[] elements = expectedArray;
            if (l.getArray() != elements)
                throw new ConcurrentModificationException();
            int len = elements.length;
            if (lo < 0 || hi > len)
                throw new IndexOutOfBoundsException();
            int newSize = 0;
            Object[] temp = new Object[n];
            for (int i = lo; i < hi; ++i) {
                Object element = elements[i];
                if (c.contains(element))
                    temp[newSize++] = element;
            }
            if (newSize != n) {
                Object[] newElements = new Object[len - n + newSize];
                System.arraycopy(elements, 0, newElements, 0, lo);
                System.arraycopy(temp, 0, newElements, lo, newSize);
                System.arraycopy(elements, hi, newElements,
                                 lo + newSize, len - hi);
                size = newSize;
                removed = true;
                l.setArray(expectedArray = newElements);
            }
        }
    } finally {
        lock.unlock();
    }
    return removed;
}
 
開發者ID:SunburstApps,項目名稱:OpenJSharp,代碼行數:40,代碼來源:CopyOnWriteArrayList.java

示例15: reset

import java.util.ConcurrentModificationException; //導入依賴的package包/類
public void reset() {
	setIncremental(true);
	for (Edge edge : super.getEdges())
		super.removeEdge(edge);

	Collection<Vertex> vertices = super.getVertices();
	while (!vertices.isEmpty()) {
		try {
			for (Vertex vertex : vertices)
				super.removeVertex(vertex);
		} catch (ConcurrentModificationException e) {
		}
	}
	update(0);
}
 
開發者ID:dev-cuttlefish,項目名稱:cuttlefish,代碼行數:16,代碼來源:ContestSimulation.java


注:本文中的java.util.ConcurrentModificationException類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。