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


Java ReferenceCountUtil.retain方法代碼示例

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


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

示例1: decode

import io.netty.util.ReferenceCountUtil; //導入方法依賴的package包/類
@Override
protected void decode(ChannelHandlerContext ctx, HttpObject msg, List<Object> out)
{
    if(!added && msg instanceof HttpRequest)
    {
        String path = ((HttpRequest)msg).getUri();
        WsServerHandler handler = findHandler(path);
        if(handler != null)
        {
            ctx.pipeline().addAfter("switch", "aggregator", new HttpObjectAggregator(65536));
            ctx.pipeline().addAfter("aggregator", "wsprotocol", new WebSocketServerProtocolHandler(path, null, true));
            ctx.pipeline().addAfter("wsprotocol", "wshandler", new WsFrameHandler(handler));
            added = true;
        }
    }
    ReferenceCountUtil.retain(msg);
    out.add(msg);
}
 
開發者ID:touwolf,項目名稱:bridje-framework,代碼行數:19,代碼來源:HttpWsSwitch.java

示例2: send

import io.netty.util.ReferenceCountUtil; //導入方法依賴的package包/類
/**
 * Sends a {@link Message}.
 *
 * @param message The message
 */
public void send(Message message) {
    checkNotNull(message, "message");
    if (!this.channel.isActive()) {
        return;
    }
    ReferenceCountUtil.retain(message);
    // Thrown exceptions will be delegated through the exceptionCaught method
    this.channel.writeAndFlush(message, this.channel.voidPromise());
}
 
開發者ID:LanternPowered,項目名稱:LanternServer,代碼行數:15,代碼來源:NetworkSession.java

示例3: channelRead0

import io.netty.util.ReferenceCountUtil; //導入方法依賴的package包/類
@Override
protected void channelRead0(ChannelHandlerContext ctx, Protocol msg) throws Exception {
	if (!ChannelUtil.clientSide(ctx) && msg.request() && msg.heartbeat()) {
		dealNegotiate(ctx, msg);
		return;
	}
	// no sense to Protocol in fact
	ReferenceCountUtil.retain(msg);
	ctx.fireChannelRead(msg);
}
 
開發者ID:spccold,項目名稱:sailfish,代碼行數:11,代碼來源:NegotiateChannelHandler.java

示例4: channelRead0

import io.netty.util.ReferenceCountUtil; //導入方法依賴的package包/類
@Override
protected void channelRead0(ChannelHandlerContext ctx, FullHttpRequest req)throws Exception {
	if(this.isValidRequest(ctx, req)){
		ReferenceCountUtil.retain(req);
		ctx.fireChannelRead(req);
	}
}
 
開發者ID:mwambler,項目名稱:xockets.io,代碼行數:8,代碼來源:WebSocketValidationHandler.java

示例5: doWrite

import io.netty.util.ReferenceCountUtil; //導入方法依賴的package包/類
@Override
protected void doWrite(ChannelOutboundBuffer in) throws Exception {
    for (;;) {
        Object msg = in.current();
        if (msg == null) {
            break;
        }

        ReferenceCountUtil.retain(msg);
        outboundMessages.add(msg);
        in.remove();
    }
}
 
開發者ID:wuyinxian124,項目名稱:netty4.0.27Learn,代碼行數:14,代碼來源:EmbeddedChannel.java

示例6: safeDuplicate

import io.netty.util.ReferenceCountUtil; //導入方法依賴的package包/類
private static Object safeDuplicate(Object message) {
    if (message instanceof ByteBuf) {
        return ((ByteBuf) message).duplicate().retain();
    } else if (message instanceof ByteBufHolder) {
        return ((ByteBufHolder) message).duplicate().retain();
    } else {
        return ReferenceCountUtil.retain(message);
    }
}
 
開發者ID:wuyinxian124,項目名稱:netty4.0.27Learn,代碼行數:10,代碼來源:DefaultChannelGroup.java

示例7: encode

import io.netty.util.ReferenceCountUtil; //導入方法依賴的package包/類
@Override
protected void encode(ChannelHandlerContext ctx, Object msg, List<Object> out) throws Exception {
    if(msg instanceof DatagramPacket){
        ReferenceCountUtil.retain(msg);
        out.add(msg);
    }else{
        out.add(wrappedBuffer((byte[]) msg));
    }
}
 
開發者ID:tctxl,項目名稱:Seed,代碼行數:10,代碼來源:Encoder.java

示例8: onData

import io.netty.util.ReferenceCountUtil; //導入方法依賴的package包/類
@Override
public void onData(final ByteBuf incoming) {

   // We need to retain until the serializer gets around to processing it.
   ReferenceCountUtil.retain(incoming);

   serializer.execute(new Runnable() {

      @Override
      public void run() {
         ByteBuffer source = incoming.nioBuffer();
         LOG.trace("Client Received from Broker {} bytes:", source.remaining());

         if (protonTransport.isClosed()) {
            LOG.debug("Ignoring incoming data because transport is closed");
            return;
         }

         do {
            ByteBuffer buffer = protonTransport.getInputBuffer();
            int limit = Math.min(buffer.remaining(), source.remaining());
            ByteBuffer duplicate = source.duplicate();
            duplicate.limit(source.position() + limit);
            buffer.put(duplicate);
            protonTransport.processInput();
            source.position(source.position() + limit);
         }
         while (source.hasRemaining());

         ReferenceCountUtil.release(incoming);

         // Process the state changes from the latest data and then answer back
         // any pending updates to the Broker.
         processUpdates();
         pumpToProtonTransport();
      }
   });
}
 
開發者ID:apache,項目名稱:activemq-artemis,代碼行數:39,代碼來源:AmqpConnection.java

示例9: claim

import io.netty.util.ReferenceCountUtil; //導入方法依賴的package包/類
private void claim(ByteBuf buf) {
  if (buf == null) {
    return;
  }
  ReferenceCountUtil.retain(buf);
  trailer.add(buf);
}
 
開發者ID:salesforce,項目名稱:coyote,代碼行數:8,代碼來源:NettyInboundRoadRunnerMessage.java

示例10: decode

import io.netty.util.ReferenceCountUtil; //導入方法依賴的package包/類
@Override
	protected void decode(final ChannelHandlerContext ctx, final HttpRequest msg, final List<Object> out) throws Exception {
		final String uri = msg.uri();
		log.info("-----------------------> URI [{}]", uri);
		if(uri.endsWith("/favicon.ico")) {
			final DefaultFullHttpResponse resp = new DefaultFullHttpResponse(HttpVersion.HTTP_1_1, HttpResponseStatus.OK, favicon);
			resp.headers().set(HttpHeaders.CONTENT_TYPE, "image/x-icon");
			resp.headers().setInt(HttpHeaders.CONTENT_LENGTH, favSize);				
			ctx.writeAndFlush(resp);
			return;
		}			
		ReferenceCountUtil.retain(msg);
		final ChannelPipeline p = ctx.pipeline();
		
		final int index = uri.indexOf("/api/");
		final String endpoint = index==-1 ? "" : uri.substring(5);
		if(index != -1 && pureJsonEndPoints.contains(endpoint) ) {
			log.info("Switching to PureJSON handler");
			p.addLast(eventExecutorGroup, "httpToJson", httpToJson);
//			p.addLast("jsonLogger", loggingHandler);
			p.addLast("jsonDecoder", new JsonObjectDecoder(true));
//			p.addLast("jsonLogger", loggingHandler);
			p.addLast("traceHandler", traceHandler);
			p.remove(this);
			if(msg instanceof FullHttpMessage) {
				out.add(msg);
			}
			
		} else {
			log.info("Switching to Http Request Manager");
			out.add(msg);
			p.addLast(eventExecutorGroup, "requestManager", HttpRequestManager.getInstance());
			p.remove(this);			
		}
	}
 
開發者ID:nickman,項目名稱:tsdblite,代碼行數:36,代碼來源:HttpSwitch.java

示例11: messageArrived

import io.netty.util.ReferenceCountUtil; //導入方法依賴的package包/類
@Override
public void messageArrived(JConnection conn, HttpResponse msg) {
	ReferenceCountUtil.retain(msg,1);
	this.response=msg;
	latch.countDown();//釋放計數器
}
 
開發者ID:juebanlin,項目名稱:util4j,代碼行數:7,代碼來源:NettyHttpClient.java

示例12: channelRead

import io.netty.util.ReferenceCountUtil; //導入方法依賴的package包/類
/**
 * {@inheritDoc}
 * @see io.netty.channel.ChannelInboundHandlerAdapter#channelRead(io.netty.channel.ChannelHandlerContext, java.lang.Object)
 */
@Override
public void channelRead(final ChannelHandlerContext ctx, final Object msg) throws Exception {		
	ReferenceCountUtil.retain(msg);
	super.channelRead(ctx, msg);
}
 
開發者ID:nickman,項目名稱:HeliosStreams,代碼行數:10,代碼來源:ConnectionManager.java

示例13: sendWithFuture

import io.netty.util.ReferenceCountUtil; //導入方法依賴的package包/類
/**
 * Sends a array of {@link Message}s and returns the {@link ChannelFuture}.
 *
 * @param messages The messages
 * @return The channel future
 */
public ChannelFuture sendWithFuture(Message... messages) {
    checkNotNull(messages, "messages");
    checkArgument(messages.length != 0, "messages cannot be empty");
    final ChannelPromise promise = this.channel.newPromise();
    if (!this.channel.isActive()) {
        return promise;
    }
    promise.addListener(ChannelFutureListener.FIRE_EXCEPTION_ON_FAILURE);
    // Don't bother checking if we are in the event loop,
    // there is only one message.
    if (messages.length == 1) {
        this.channel.writeAndFlush(messages[0], promise);
    } else {
        final EventLoop eventLoop = this.channel.eventLoop();
        final ChannelPromise voidPromise = this.channel.voidPromise();
        if (eventLoop.inEventLoop()) {
            final int last = messages.length - 1;
            for (int i = 0; i < last; i++) {
                ReferenceCountUtil.retain(messages[i]);
                this.channel.writeAndFlush(messages[i], voidPromise);
            }
            ReferenceCountUtil.retain(messages[last]);
            this.channel.writeAndFlush(messages[last], promise);
        } else {
            // If there are more then one message, combine them inside the
            // event loop to reduce overhead of wakeup calls and object creation

            // Create a copy of the list, to avoid concurrent modifications
            final List<Message> messages0 = ImmutableList.copyOf(messages);
            messages0.forEach(ReferenceCountUtil::retain);
            eventLoop.submit(() -> {
                final Iterator<Message> it0 = messages0.iterator();
                do {
                    final Message message0 = it0.next();
                    // Only use a normal channel promise for the last message
                    this.channel.writeAndFlush(message0, it0.hasNext() ? voidPromise : promise);
                } while (it0.hasNext());
            });
        }
    }
    return promise;
}
 
開發者ID:LanternPowered,項目名稱:LanternServer,代碼行數:49,代碼來源:NetworkSession.java

示例14: retain

import io.netty.util.ReferenceCountUtil; //導入方法依賴的package包/類
@Override
public FullHttpRequest retain(int increment) {
    ReferenceCountUtil.retain(message, increment);
    return this;
}
 
開發者ID:playframework,項目名稱:netty-reactive-streams,代碼行數:6,代碼來源:EmptyHttpRequest.java

示例15: retain

import io.netty.util.ReferenceCountUtil; //導入方法依賴的package包/類
@Override
public FullHttpResponse retain(int increment) {
    ReferenceCountUtil.retain(message, increment);
    return this;
}
 
開發者ID:playframework,項目名稱:netty-reactive-streams,代碼行數:6,代碼來源:EmptyHttpResponse.java


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