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


Java ReentrantReadWriteLock類代碼示例

本文整理匯總了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;
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:25,代碼來源:CustomEntryConcurrentHashMap.java

示例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;
  }
}
 
開發者ID:Tencent,項目名稱:angel,代碼行數:26,代碼來源:ConsistencyController.java

示例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);
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:30,代碼來源:CustomEntryConcurrentHashMap.java

示例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;
}
 
開發者ID:ponkin,項目名稱:bloom,代碼行數:25,代碼來源:CuckooFilter.java

示例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();
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:17,代碼來源:ReentrantReadWriteLockTest.java

示例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>();
}
 
開發者ID:Tencent,項目名稱:angel,代碼行數:26,代碼來源:AMWorkerGroup.java

示例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();
  }
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:20,代碼來源:CustomEntryConcurrentHashMap.java

示例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;
}
 
開發者ID:meili,項目名稱:Aceso,代碼行數:26,代碼來源:AbstractPatchesLoaderImpl.java

示例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();
    }
  }
}
 
開發者ID:ponkin,項目名稱:bloom,代碼行數:17,代碼來源:StableBloomFilter.java

示例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;
    }
}
 
開發者ID:yifangyun,項目名稱:fangcloud-java-sdk,代碼行數:22,代碼來源:YfyBaseClient.java

示例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)
      );
}
 
開發者ID:ponkin,項目名稱:bloom,代碼行數:21,代碼來源:StableBloomFilter.java

示例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;
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:17,代碼來源:Translog.java

示例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;
}
 
開發者ID:ponkin,項目名稱:bloom,代碼行數:20,代碼來源:StableBloomFilter.java

示例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 );
        }
    };
}
 
開發者ID:eclipse,項目名稱:neoscada,代碼行數:17,代碼來源:HiveCommon.java

示例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;
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:27,代碼來源:RMAppAttemptImpl.java


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