本文整理匯總了Java中java.util.concurrent.locks.ReentrantReadWriteLock類的典型用法代碼示例。如果您正苦於以下問題:Java ReentrantReadWriteLock類的具體用法?Java ReentrantReadWriteLock怎麽用?Java ReentrantReadWriteLock使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
ReentrantReadWriteLock類屬於java.util.concurrent.locks包,在下文中一共展示了ReentrantReadWriteLock類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: get
import java.util.concurrent.locks.ReentrantReadWriteLock; //導入依賴的package包/類
final V get(final Object key, final int hash, final MapCallback<K, V, ?, ?> readCallback) {
final ReentrantReadWriteLock.ReadLock readLock = super.readLock();
readLock.lock();
try {
if (this.count != 0) { // read-volatile
HashEntry<K, V> e = getFirst(hash);
while (e != null) {
if (e.getEntryHash() == hash && equalityKeyCompare(key, e)) {
final V v = e.getMapValue();
if (v != null) {
if (readCallback != null) {
readCallback.oldValueRead(v);
}
return v;
}
}
e = e.getNextEntry();
}
}
} finally {
readLock.unlock();
}
return null;
}
示例2: cloneRow
import java.util.concurrent.locks.ReentrantReadWriteLock; //導入依賴的package包/類
private TVector cloneRow(int matrixId, int rowIndex, TVector row, TaskContext taskContext) {
if (row == null) {
return null;
}
if (isNeedClone(matrixId)) {
ReentrantReadWriteLock globalStorage =
PSAgentContext.get().getMatrixStorageManager().getMatrixStoage(matrixId).getLock();
TVector taskRow = taskContext.getMatrixStorage().getRow(matrixId, rowIndex);
try {
globalStorage.readLock().lock();
if(taskRow == null || (taskRow.getClass() != row.getClass())){
taskRow = row.clone();
taskContext.getMatrixStorage().addRow(matrixId, rowIndex, taskRow);
} else {
taskRow.clone(row);
}
} finally {
globalStorage.readLock().unlock();
}
return taskRow;
} else {
return row;
}
}
示例3: writeObject
import java.util.concurrent.locks.ReentrantReadWriteLock; //導入依賴的package包/類
/**
* Save the state of the <tt>ConcurrentHashMap</tt> instance to a stream (i.e., serialize it).
*
* @param s the stream
* @serialData the key (Object) and value (Object) for each key-value mapping, followed by a null
* pair. The key-value mappings are emitted in no particular order.
*/
private void writeObject(final java.io.ObjectOutputStream s) throws IOException {
s.defaultWriteObject();
for (int k = 0; k < this.segments.length; ++k) {
final Segment<K, V> seg = this.segments[k];
final ReentrantReadWriteLock.ReadLock readLock = seg.readLock();
readLock.lock();
try {
final HashEntry<K, V>[] tab = seg.table;
for (int i = 0; i < tab.length; ++i) {
for (HashEntry<K, V> e = tab[i]; e != null; e = e.getNextEntry()) {
s.writeObject(e.getKey());
s.writeObject(e.getMapValue());
}
}
} finally {
readLock.unlock();
}
}
s.writeObject(null);
s.writeObject(null);
}
示例4: put
import java.util.concurrent.locks.ReentrantReadWriteLock; //導入依賴的package包/類
@Override
public boolean put(byte[] item) {
long[] hashes = new long[2];
strategy.hashes(item, hashes);
long bucketIdx = hashes[0] % numBuckets;
long tag = fingerprint(hashes[1]);
boolean itemAdded = false;
ReentrantReadWriteLock.WriteLock lock = segments[(int)(bucketIdx & FAST_MOD_32)].writeLock();
lock.lock();
try {
itemAdded = table.append(bucketIdx, tag);
} finally {
lock.unlock();
}
if(!itemAdded) {
itemAdded = putInAlt(bucketIdx, tag);
}
if(itemAdded) {
count.incrementAndGet();
} else {
log.log(Level.WARNING, String.format("Cucko table exceed capacity: %1$d elements", count.get()));
}
return itemAdded;
}
示例5: testMultipleReadLocks
import java.util.concurrent.locks.ReentrantReadWriteLock; //導入依賴的package包/類
public void testMultipleReadLocks(boolean fair) {
final ReentrantReadWriteLock lock = new ReentrantReadWriteLock(fair);
lock.readLock().lock();
Thread t = newStartedThread(new CheckedRunnable() {
public void realRun() throws InterruptedException {
assertTrue(lock.readLock().tryLock());
lock.readLock().unlock();
assertTrue(lock.readLock().tryLock(LONG_DELAY_MS, MILLISECONDS));
lock.readLock().unlock();
lock.readLock().lock();
lock.readLock().unlock();
}});
awaitTermination(t);
lock.readLock().unlock();
}
示例6: AMWorkerGroup
import java.util.concurrent.locks.ReentrantReadWriteLock; //導入依賴的package包/類
/**
* Create a AMWorkerGroup
* @param groupId worker group id
* @param context master context
* @param workerMap workers contains in worker group
* @param leader leader worker of worker group
* @param splitIndex training data block index assgined to this worker group
*/
public AMWorkerGroup(WorkerGroupId groupId, AMContext context, Map<WorkerId, AMWorker> workerMap,
WorkerId leader, int splitIndex) {
this.context = context;
this.groupId = groupId;
this.workerMap = workerMap;
this.leader = leader;
this.splitIndex = splitIndex;
ReadWriteLock readWriteLock = new ReentrantReadWriteLock();
readLock = readWriteLock.readLock();
writeLock = readWriteLock.writeLock();
stateMachine = stateMachineFactory.make(this);
diagnostics = new ArrayList<String>();
successWorkerSet = new HashSet<WorkerId>();
failedWorkerSet = new HashSet<WorkerId>();
killedWorkerSet = new HashSet<WorkerId>();
}
示例7: replace
import java.util.concurrent.locks.ReentrantReadWriteLock; //導入依賴的package包/類
final V replace(final K key, final int hash, final V newValue) {
final ReentrantReadWriteLock.WriteLock writeLock = super.writeLock();
writeLock.lock();
try {
HashEntry<K, V> e = getFirst(hash);
while (e != null && (e.getEntryHash() != hash || !equalityKeyCompare(key, e))) {
e = e.getNextEntry();
}
V oldValue = null;
if (e != null) {
oldValue = e.getMapValue();
e.setMapValue(newValue);
}
return oldValue;
} finally {
writeLock.unlock();
}
}
示例8: load
import java.util.concurrent.locks.ReentrantReadWriteLock; //導入依賴的package包/類
@Override
public boolean load() {
try {
InstantFixClassMap.setClassLoader(getClass().getClassLoader());
HashMap<Integer, ReadWriteLock> lockMap = new HashMap<>();
HashMap<Integer, String> classIndexMap = new HashMap<>();
String[] patchedClasses = getPatchedClasses();
int[] patchedClassIndexes = getPatchedClassIndexes();
if (patchedClasses.length != patchedClassIndexes.length) {
throw new IllegalArgumentException("patchedClasses's len is " + patchedClasses.length + ", but patchedClassIndexs's len is " + patchedClassIndexes.length);
}
for (int i = 0; i < patchedClasses.length; i++) {
String className = patchedClasses[i];
int classIndex = patchedClassIndexes[i];
lockMap.put(classIndex, new ReentrantReadWriteLock());
classIndexMap.put(classIndex, className);
Log.i(TAG, String.format("patched %s", className));
}
InstantFixClassMap.setAtomMap(new InstantFixClassMap.AtomMap(classIndexMap, lockMap));
} catch (Throwable e) {
e.printStackTrace();
return false;
}
return true;
}
示例9: decrement
import java.util.concurrent.locks.ReentrantReadWriteLock; //導入依賴的package包/類
private void decrement() {
long pivot = ThreadLocalRandom.current().nextLong(numOfBuckets);
for(int i=0; i<bucketsToDecrement; i++) {
long idx = (pivot + i) % numOfBuckets;
ReentrantReadWriteLock.WriteLock currentLock = segments[(int)(idx & FAST_MOD_32)].writeLock();
currentLock.lock();
try { // just in case something goes wrong
long bucketVal = bucketSet.readTag(idx, 0);
if(bucketVal != 0L) {
bucketSet.writeTag(idx, 0, bucketVal-1);
}
} finally {
currentLock.unlock();
}
}
}
示例10: YfyBaseClient
import java.util.concurrent.locks.ReentrantReadWriteLock; //導入依賴的package包/類
public YfyBaseClient(K key,
YfyRequestConfig requestConfig,
String accessToken,
String refreshToken,
YfyRefreshListener<K> refreshListener) {
if (accessToken == null) {
throw new NullPointerException("access token");
}
this.requestConfig = requestConfig;
this.host = YfyAppInfo.getHost();
this.refreshLock = new ReentrantReadWriteLock();
this.key = key;
this.accessToken = accessToken;
this.refreshToken = refreshToken;
if (refreshToken != null && refreshListener != null) {
this.autoRefresh = true;
this.refreshListener = refreshListener;
}
}
示例11: StableBloomFilter
import java.util.concurrent.locks.ReentrantReadWriteLock; //導入依賴的package包/類
StableBloomFilter(BitSet bitset, long numOfBuckets, int bitsPerBucket, long bucketsToDecrement, int numHashFunctions, HashFunction strategy) {
// allow 1 item per bucket
this.bucketSet = new BucketSet(bitsPerBucket, 1, numOfBuckets, bitset);
this.numHashFunctions = numHashFunctions;
this.numOfBuckets = numOfBuckets;
this.bitsPerBucket = bitsPerBucket;
this.strategy = strategy;
this.bucketsToDecrement = bucketsToDecrement;
for(int i=0;i<DEFAULT_CONCURRENCY_LEVEL;i++) {
segments[i] = new ReentrantReadWriteLock();
}
log.log(
Level.FINE,
String.format(
"Stable Bloom filter: %1$d hash functions, %2$d bits, %3$d bits per elemnent",
numHashFunctions,
bitset.bitSize(),
bitsPerBucket)
);
}
示例12: Translog
import java.util.concurrent.locks.ReentrantReadWriteLock; //導入依賴的package包/類
public Translog(TranslogConfig config, String nodeId) {
super(config.getShardId(), config.getIndexSettings());
this.config = null;
recoveredTranslogs = null;
syncScheduler = null;
bigArrays = null;
ReadWriteLock rwl = new ReentrantReadWriteLock();
readLock = new ReleasableLock(rwl.readLock());
writeLock = new ReleasableLock(rwl.writeLock());
location = null;
current = null;
currentCommittingTranslog = null;
lastCommittedTranslogFileGeneration = -1;
config = null;
translogUUID = null;
}
示例13: put
import java.util.concurrent.locks.ReentrantReadWriteLock; //導入依賴的package包/類
@Override
public boolean put(byte[] bytes) {
long[] hashes = new long[numHashFunctions];
strategy.hashes(bytes, hashes);
// make room for new values
decrement();
for (int i = 0; i < hashes.length; i++) {
long idx = hashes[i] % numOfBuckets;
ReentrantReadWriteLock.WriteLock currentLock = segments[(int)(idx & FAST_MOD_32)].writeLock();
currentLock.lock();
try { // just in case something goes wrong
bucketSet.writeTag(idx, 0, Utils.MASKS[bitsPerBucket]); // write max val for bucket
} finally {
currentLock.unlock();
}
}
// forever true since we always overwrite bucket content
return true;
}
示例14: HiveCommon
import java.util.concurrent.locks.ReentrantReadWriteLock; //導入依賴的package包/類
public HiveCommon ()
{
final ReentrantReadWriteLock itemMapLock = new ReentrantReadWriteLock ( Boolean.getBoolean ( "org.eclipse.scada.da.server.common.fairItemMapLock" ) );
this.itemMapReadLock = itemMapLock.readLock ();
this.itemMapWriteLock = itemMapLock.writeLock ();
this.subscriptionValidator = new SubscriptionValidator<String> () {
@Override
public boolean validate ( final SubscriptionListener<String> listener, final String topic )
{
return validateItem ( topic );
}
};
}
示例15: RMAppAttemptImpl
import java.util.concurrent.locks.ReentrantReadWriteLock; //導入依賴的package包/類
public RMAppAttemptImpl(ApplicationAttemptId appAttemptId,
RMContext rmContext, YarnScheduler scheduler,
ApplicationMasterService masterService,
ApplicationSubmissionContext submissionContext,
Configuration conf, boolean maybeLastAttempt, ResourceRequest amReq) {
this.conf = conf;
this.applicationAttemptId = appAttemptId;
this.rmContext = rmContext;
this.eventHandler = rmContext.getDispatcher().getEventHandler();
this.submissionContext = submissionContext;
this.scheduler = scheduler;
this.masterService = masterService;
ReentrantReadWriteLock lock = new ReentrantReadWriteLock();
this.readLock = lock.readLock();
this.writeLock = lock.writeLock();
this.proxiedTrackingUrl = generateProxyUriWithScheme();
this.maybeLastAttempt = maybeLastAttempt;
this.stateMachine = stateMachineFactory.make(this);
this.attemptMetrics =
new RMAppAttemptMetrics(applicationAttemptId, rmContext);
this.amReq = amReq;
}