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


Java BlockingQueue.offer方法代碼示例

本文整理匯總了Java中java.util.concurrent.BlockingQueue.offer方法的典型用法代碼示例。如果您正苦於以下問題:Java BlockingQueue.offer方法的具體用法?Java BlockingQueue.offer怎麽用?Java BlockingQueue.offer使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.util.concurrent.BlockingQueue的用法示例。


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

示例1: rejectedExecution

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
public void rejectedExecution(Runnable task, ThreadPoolExecutor executor)
{
    ((DebuggableThreadPoolExecutor) executor).onInitialRejection(task);
    BlockingQueue<Runnable> queue = executor.getQueue();
    while (true)
    {
        if (executor.isShutdown())
        {
            ((DebuggableThreadPoolExecutor) executor).onFinalRejection(task);
            throw new RejectedExecutionException("ThreadPoolExecutor has shut down");
        }
        try
        {
            if (queue.offer(task, 1000, TimeUnit.MILLISECONDS))
            {
                ((DebuggableThreadPoolExecutor) executor).onFinalAccept(task);
                break;
            }
        }
        catch (InterruptedException e)
        {
            throw new AssertionError(e);
        }
    }
}
 
開發者ID:Netflix,項目名稱:sstable-adaptor,代碼行數:26,代碼來源:DebuggableThreadPoolExecutor.java

示例2: terminateSession

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
/**
 * The implementation for terminateSession() function.
 * It removes the session to queue association.
 * @param sessionid
 * @throws TException
 */
@Override
public void terminateSession(String sessionid)
        throws org.apache.thrift.TException {
    if (!msgQueues.containsKey(sessionid)) {
        return;
    }

    SessionQueue pQueue = msgQueues.get(sessionid);

    log.debug("terminateSession: SessionId: " + sessionid + "\n");
    String data = "FilterTimeout";
    ByteBuffer bb = ByteBuffer.wrap(data.getBytes());
    BlockingQueue<ByteBuffer> queue = pQueue.getQueue();
    if (queue != null) {
        if (!queue.offer(bb)) {
            log.error("Failed to queue message for session: " + sessionid);
        }
        msgQueues.remove(sessionid);
    } else {
        log.error("queue for session {} is null", sessionid);
    }
}
 
開發者ID:xuraylei,項目名稱:fresco_floodlight,代碼行數:29,代碼來源:PacketStreamerHandler.java

示例3: closeConnections

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
/**
 * Close connections that are idle or optionally close all connections.
 * Connections are considered "idle" if they have not been used in 10 seconds.
 *
 * @param closeNonIdleConnections if <code>true</code> will close all connection; if <code>false</code> will close only idle connections
 */
private void closeConnections(final boolean closeNonIdleConnections) {
    for (final Map.Entry<Tuple<String, Integer>, BlockingQueue<FileTransferIdleWrapper>> entry : fileTransferMap.entrySet()) {
        final BlockingQueue<FileTransferIdleWrapper> wrapperQueue = entry.getValue();

        final List<FileTransferIdleWrapper> putBack = new ArrayList<>();
        FileTransferIdleWrapper wrapper;
        while ((wrapper = wrapperQueue.poll()) != null) {
            final long lastUsed = wrapper.getLastUsed();
            final long nanosSinceLastUse = System.nanoTime() - lastUsed;
            if (!closeNonIdleConnections && TimeUnit.NANOSECONDS.toMillis(nanosSinceLastUse) < IDLE_CONNECTION_MILLIS) {
                putBack.add(wrapper);
            } else {
                try {
                    wrapper.getFileTransfer().close();
                } catch (final IOException ioe) {
                    getLogger().warn("Failed to close Idle Connection due to {}", new Object[] {ioe}, ioe);
                }
            }
        }

        for (final FileTransferIdleWrapper toPutBack : putBack) {
            wrapperQueue.offer(toPutBack);
        }
    }
}
 
開發者ID:clickha,項目名稱:nifi-tools,代碼行數:32,代碼來源:FetchFileTransferV2.java

示例4: main

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
public static void main(String[] args) throws InterruptedException {

        BlockingQueue<String> queue = new ArrayBlockingQueue<>(1);

        queue.add("add");

        //
        String peek = queue.peek();
        System.out.println(peek);

        queue.poll();
        boolean offer = queue.offer("offer");
        if (!offer) {
            System.out.println("it is't possible to do so immediately");
        }
        System.out.println(queue.take());

        queue.put("put operation");
        System.out.println(queue.take());
    }
 
開發者ID:daishicheng,項目名稱:outcomes,代碼行數:21,代碼來源:ArrayBlockingQueueExample.java

示例5: singleThreadExecutor

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
/**
 * Returns a single threaded executor which uses one invocation
 * of the parent executor to execute tasks (in sequence).
 *
 * Use a null valued Runnable to terminate.
 */
// TODO: this is a blocking way of doing this;
public static Executor singleThreadExecutor(Executor parent) {
    BlockingQueue<Optional<Runnable>> queue = new LinkedBlockingQueue<>();
    parent.execute(() -> {
        while (true) {
            try {
                Optional<Runnable> o = queue.take();
                if (!o.isPresent()) {
                    return;
                }
                o.get().run();
            } catch (InterruptedException ex) {
                return;
            }
        }
    });
    return new Executor() {
        @Override
        public void execute(Runnable command) {
            queue.offer(Optional.ofNullable(command));
        }
    };
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:30,代碼來源:Utils.java

示例6: rejectedExecution

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
@Override
public void rejectedExecution(Runnable runnable, ThreadPoolExecutor executor) {
    if (threadName != null) {
        LOG.error("txTransaction Thread pool [{}] is exhausted, executor={}", threadName, executor.toString());
    }

    if (!executor.isShutdown()) {
        BlockingQueue<Runnable> queue = executor.getQueue();
        int discardSize = queue.size() >> 1;
        for (int i = 0; i < discardSize; i++) {
            queue.poll();
        }
        queue.offer(runnable);
    }
}
 
開發者ID:yu199195,項目名稱:happylifeplat-transaction,代碼行數:16,代碼來源:DiscardedPolicy.java

示例7: put

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
/**
 * Put and offer follow the same pattern:
 * 1. Get a priorityLevel from the scheduler
 * 2. Get the nth sub-queue matching this priorityLevel
 * 3. delegate the call to this sub-queue.
 *
 * But differ in how they handle overflow:
 * - Put will move on to the next queue until it lands on the last queue
 * - Offer does not attempt other queues on overflow
 */
@Override
public void put(E e) throws InterruptedException {
  int priorityLevel = scheduler.getPriorityLevel(e);

  final int numLevels = this.queues.size();
  while (true) {
    BlockingQueue<E> q = this.queues.get(priorityLevel);
    boolean res = q.offer(e);
    if (!res) {
      // Update stats
      this.overflowedCalls.get(priorityLevel).getAndIncrement();

      // If we failed to insert, try again on the next level
      priorityLevel++;

      if (priorityLevel == numLevels) {
        // That was the last one, we will block on put in the last queue
        // Delete this line to drop the call
        this.queues.get(priorityLevel-1).put(e);
        break;
      }
    } else {
      break;
    }
  }


  signalNotEmpty();
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:40,代碼來源:FairCallQueue.java

示例8: offer

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
@Override
public boolean offer(E e, long timeout, TimeUnit unit)
    throws InterruptedException {
  int priorityLevel = scheduler.getPriorityLevel(e);
  BlockingQueue<E> q = this.queues.get(priorityLevel);
  boolean ret = q.offer(e, timeout, unit);

  signalNotEmpty();

  return ret;
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:12,代碼來源:FairCallQueue.java

示例9: pushMessageSync

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
/**
 * The implementation for pushMessageSync() function.
 * 
 * @param msg
 * @return 1 for success, 0 for failure
 * @throws TException
 */
@Override
public int pushMessageSync(Message msg)
        throws org.apache.thrift.TException {

    if (msg == null) {
        log.error("Could not push empty message");
        return 0;
    }

    List<String> sessionids = msg.getSessionIDs();
    for (String sid : sessionids) {
        SessionQueue pQueue = null;

        if (!msgQueues.containsKey(sid)) {
            pQueue = new SessionQueue();
            msgQueues.put(sid, pQueue);
        } else {
            pQueue = msgQueues.get(sid);
        }

        log.debug("pushMessageSync: SessionId: " + sid + 
                  " Receive a message, " + msg.toString() + "\n");
        ByteBuffer bb = ByteBuffer.wrap(msg.getPacket().getData());
        //ByteBuffer dst = ByteBuffer.wrap(msg.getPacket().toString().getBytes());
        BlockingQueue<ByteBuffer> queue = pQueue.getQueue();
        if (queue != null) {
            if (!queue.offer(bb)) {
                log.error("Failed to queue message for session: " + sid);
            } else {
                log.debug("insert a message to session: " + sid);
            }
        } else {
            log.error("queue for session {} is null", sid);
        }
    }

    return 1;
}
 
開發者ID:xuraylei,項目名稱:fresco_floodlight,代碼行數:46,代碼來源:PacketStreamerHandler.java

示例10: getResult

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
/**
 * 獲取結果
 * @param blockingQueue
 * @param timeout
 * @param unit
 * @return
 * @throws InterruptedIOException
 */
public static Object getResult(BlockingQueue<Object> blockingQueue,long timeout, TimeUnit unit) throws InterruptedIOException {
    Object result;
    try {
        result = blockingQueue.poll(timeout, unit);
        if (result == null) {
            if (!blockingQueue.offer("")) {
                result = blockingQueue.take();
            }
        }
    } catch (InterruptedException e) {
        throw ExceptionUtil.initCause(new InterruptedIOException(e.getMessage()), e);
    }
    return result;
}
 
開發者ID:DevopsJK,項目名稱:SuitAgent,代碼行數:23,代碼來源:BlockingQueueUtil.java

示例11: enqueue

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
protected void enqueue(BlockingQueue<T> outputQueue, T segment) throws InterruptedException {
	boolean enqueued = false;
	
	while(!enqueued) {
		enqueued = outputQueue.offer(segment, 500, TimeUnit.MILLISECONDS);
	}	
}
 
開發者ID:graphium-project,項目名稱:graphium,代碼行數:8,代碼來源:GenericQueuingJacksonSegmentInputFormat.java

示例12: rejectedExecution

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
@Override
public void rejectedExecution(Runnable runnable, ThreadPoolExecutor executor) {
    if (threadName != null) {
        LOG.error("MythTransaction Thread pool [{}] is exhausted, executor={}", threadName, executor.toString());
    }
    if (!executor.isShutdown()) {
        BlockingQueue<Runnable> queue = executor.getQueue();
        int discardSize = queue.size() >> 1;
        for (int i = 0; i < discardSize; i++) {
            queue.poll();
        }
        queue.offer(runnable);
    }
}
 
開發者ID:yu199195,項目名稱:myth,代碼行數:15,代碼來源:DiscardedPolicy.java

示例13: forceAdd

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
private static <T> void forceAdd(BlockingQueue<T> queue, T value) {
  while (!queue.offer(value)) {
    LOG.warning("Failed to add to queue, trying again...");
  }
}
 
開發者ID:EVelez79,項目名稱:CodeU-ProjectGroup6,代碼行數:6,代碼來源:Timeline.java

示例14: deserialize

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
/**
 * @param stream InputStream containing JSON data
 * @param segmentsQueue Queue retrieving parsed way segment objects
 * @param metadataQueue Queue retrieving parsed metadata object; there will be retrieved only one object 
 */
@Override
public void deserialize(InputStream stream, BlockingQueue<T> segmentsQueue, 
		BlockingQueue<IWayGraphVersionMetadata> metadataQueue)
		throws WaySegmentDeserializationException {
	
	try {
		JsonParser jp = jsonFactory.createParser(stream);
	
		JsonToken token = jp.nextToken();
		
   		long count = 0;
   		
   		ISegmentAdapter<IBaseSegmentDTO, T> adapter = null;
		while (!jp.isClosed()){
			token = jp.nextToken();
			if (token != null && token != JsonToken.END_ARRAY) {

				if (jp.getCurrentToken() == JsonToken.FIELD_NAME &&
					jp.getCurrentName().equals("graphVersionMetadata")) {

					jp.nextToken();
					IGraphVersionMetadataDTO dto = jp.readValueAs(GraphVersionMetadataDTOImpl.class);
					IWayGraphVersionMetadata metadata  = metadataAdapter.adapt(dto);
					metadataQueue.offer(metadata, 500, TimeUnit.MILLISECONDS);
				} 
				// extract type of segments. its encoded as the name of the array field holding the segments
				else if (jp.getCurrentToken() == JsonToken.FIELD_NAME) {    			
    				String segmentType = jp.getCurrentName();
					adapter = this.getAndRegisterDeserializers(segmentType);
    			}
				else if (jp.getCurrentToken() != JsonToken.END_OBJECT) {
    				enqueue(segmentsQueue, processSegment(jp, adapter));
    				count++;
				}					
			}				
		}
		log.info("parsed and enqueued: " + count + " segments");
	} catch (Exception e) {
		throw new WaySegmentDeserializationException(e.getMessage(),e);
    }
}
 
開發者ID:graphium-project,項目名稱:graphium,代碼行數:47,代碼來源:GenericQueuingJacksonGraphInputFormat.java

示例15: pushMessageSync

import java.util.concurrent.BlockingQueue; //導入方法依賴的package包/類
/**
 * The implementation for pushMessageSync() function.
 * 
 * @param msg
 * @return 1 for success, 0 for failure
 * @throws TException
 */
@Override
@LogMessageDocs({
    @LogMessageDoc(level="ERROR",
            message="Could not push empty message",
            explanation="An empty message was sent to the packet streamer",
            recommendation=LogMessageDoc.REPORT_CONTROLLER_BUG),
    @LogMessageDoc(level="ERROR",
            message="queue for session {sessionId} is null",
            explanation="The queue for the packet streamer session " +
            		"is missing",
            recommendation=LogMessageDoc.REPORT_CONTROLLER_BUG)
})

public int pushMessageSync(Message msg)
        throws org.apache.thrift.TException {

    if (msg == null) {
        log.error("Could not push empty message");
        return 0;
    }

    List<String> sessionids = msg.getSessionIDs();
    for (String sid : sessionids) {
        SessionQueue pQueue = null;

        if (!msgQueues.containsKey(sid)) {
            pQueue = new SessionQueue();
            msgQueues.put(sid, pQueue);
        } else {
            pQueue = msgQueues.get(sid);
        }

        log.debug("pushMessageSync: SessionId: " + sid + 
                  " Receive a message, " + msg.toString() + "\n");
        ByteBuffer bb = ByteBuffer.wrap(msg.getPacket().getData());
        //ByteBuffer dst = ByteBuffer.wrap(msg.getPacket().toString().getBytes());
        BlockingQueue<ByteBuffer> queue = pQueue.getQueue();
        if (queue != null) {
            if (!queue.offer(bb)) {
                log.error("Failed to queue message for session: " + sid);
            } else {
                log.debug("insert a message to session: " + sid);
            }
        } else {
            log.error("queue for session {} is null", sid);
        }
    }

    return 1;
}
 
開發者ID:nsg-ethz,項目名稱:iTAP-controller,代碼行數:58,代碼來源:PacketStreamerHandler.java


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