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


Java ByteBuf.release方法代碼示例

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


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

示例1: sendHttpResponse

import io.netty.buffer.ByteBuf; //導入方法依賴的package包/類
/**
 * 返回http信息
 * @param ctx
 * @param req
 * @param res
 */
private static void sendHttpResponse(
        ChannelHandlerContext ctx, FullHttpRequest req, FullHttpResponse res) {
    // Generate an error page if response getStatus code is not OK (200).
    if (res.getStatus().code() != 200) {
        ByteBuf buf = Unpooled.copiedBuffer(res.getStatus().toString(), CharsetUtil.UTF_8);
        res.content().writeBytes(buf);
        buf.release();
        HttpHeaders.setContentLength(res, res.content().readableBytes());
    }

    // Send the response and close the connection if necessary.
    ChannelFuture f = ctx.channel().writeAndFlush(res);
    if (!HttpHeaders.isKeepAlive(req) || res.getStatus().code() != 200) {
        f.addListener(ChannelFutureListener.CLOSE);
    }
}
 
開發者ID:ninelook,項目名稱:wecard-server,代碼行數:23,代碼來源:NettyServerHandler.java

示例2: shouldHandleConnect

import io.netty.buffer.ByteBuf; //導入方法依賴的package包/類
@Test
public void shouldHandleConnect() {
    Http1FrontendHandler handler = httpProxyHandler(true);
    inboundChannel.pipeline().addLast(handler);

    ByteBuf requestBytes = requestBytes(new DefaultHttpRequest(
            HttpVersion.HTTP_1_1, HttpMethod.CONNECT, "localhost:8000"));
    assertFalse(inboundChannel.writeInbound(requestBytes));

    assertNotNull(outboundChannel);
    assertTrue(outboundChannel.isActive());

    assertEquals(1, inboundChannel.outboundMessages().size());
    assertTrue(inboundChannel.outboundMessages().peek() instanceof ByteBuf);

    ByteBuf respByteBuf = (ByteBuf) inboundChannel.outboundMessages().poll();
    byte[] respBytes = new byte[respByteBuf.readableBytes()];
    respByteBuf.readBytes(respBytes);
    assertEquals("HTTP/1.1 200 OK\r\n\r\n", new String(respBytes));
    respByteBuf.release();
}
 
開發者ID:chhsiao90,項目名稱:nitmproxy,代碼行數:22,代碼來源:Http1FrontendHandlerTest.java

示例3: doReadMessages

import io.netty.buffer.ByteBuf; //導入方法依賴的package包/類
@Override
protected int doReadMessages(List<Object> buf) throws Exception {
    DatagramChannel ch = javaChannel();
    UkcpServerChannelConfig config = config();
    RecvByteBufAllocator.Handle allocHandle = unsafe().recvBufAllocHandle();

    ByteBuf data = allocHandle.allocate(config.getAllocator());
    allocHandle.attemptedBytesRead(data.writableBytes());
    boolean free = true;
    try {
        ByteBuffer nioData = data.internalNioBuffer(data.writerIndex(), data.writableBytes());
        int pos = nioData.position();
        InetSocketAddress remoteAddress = (InetSocketAddress) ch.receive(nioData);
        if (remoteAddress == null) {
            return 0;
        }

        allocHandle.lastBytesRead(nioData.position() - pos);
        buf.add(UkcpPacket.newInstance(data.writerIndex(data.writerIndex() + allocHandle.lastBytesRead()),
                remoteAddress));
        free = false;
        return 1;
    } catch (Throwable cause) {
        PlatformDependent.throwException(cause);
        return -1;
    } finally {
        if (free) {
            data.release();
        }
    }
}
 
開發者ID:szhnet,項目名稱:kcp-netty,代碼行數:32,代碼來源:UkcpServerChannel.java

示例4: sendHttpResponse

import io.netty.buffer.ByteBuf; //導入方法依賴的package包/類
public void sendHttpResponse(ChannelHandlerContext ctx, FullHttpRequest req, FullHttpResponse res) {
   if (res.getStatus().code() != 200) {
      ByteBuf f = Unpooled.copiedBuffer(res.getStatus().toString(), CharsetUtil.UTF_8);
      res.content().clear();
      res.content().writeBytes(f);
      f.release();
   }

   HttpHeaders.setContentLength(res, res.content().readableBytes());
   ChannelFuture f1;
   f1 = ctx.channel().writeAndFlush(res);

   if (!HttpHeaders.isKeepAlive(req) || res.getStatus().code() != 200) {
      f1.addListener(ChannelFutureListener.CLOSE);
   }
}
 
開發者ID:SpreadServe,項目名稱:TFWebSock,代碼行數:17,代碼來源:NettyHttpFileHandler.java

示例5: getBase64EncodedString

import io.netty.buffer.ByteBuf; //導入方法依賴的package包/類
/** Return a Base64-encoded string. */
private static String getBase64EncodedString(String str) {
  ByteBuf byteBuf = null;
  ByteBuf encodedByteBuf = null;
  try {
    byteBuf = Unpooled.wrappedBuffer(str.getBytes(StandardCharsets.UTF_8));
    encodedByteBuf = Base64.encode(byteBuf);
    return encodedByteBuf.toString(StandardCharsets.UTF_8);
  } finally {
    // The release is called to suppress the memory leak error messages raised by netty.
    if (byteBuf != null) {
      byteBuf.release();
      if (encodedByteBuf != null) {
        encodedByteBuf.release();
      }
    }
  }
}
 
開發者ID:spafka,項目名稱:spark_deep,代碼行數:19,代碼來源:SparkSaslServer.java

示例6: encode

import io.netty.buffer.ByteBuf; //導入方法依賴的package包/類
private byte[] encode(Object task) {
    // erase RedissonClient field to avoid its serialization
    Injector.inject(task, null);
    
    ByteBuf buf = null;
    try {
        buf = codec.getValueEncoder().encode(task);
        byte[] dst = new byte[buf.readableBytes()];
        buf.readBytes(dst);
        return dst;
    } catch (IOException e) {
        throw new IllegalArgumentException(e);
    } finally {
        if (buf != null) {
            buf.release();
        }
    }
}
 
開發者ID:qq1588518,項目名稱:JRediClients,代碼行數:19,代碼來源:RedissonExecutorService.java

示例7: decode

import io.netty.buffer.ByteBuf; //導入方法依賴的package包/類
@Override
public Object decode(ByteBuf buf, State state) throws IOException {
    ByteBuf out = ByteBufAllocator.DEFAULT.buffer();
    try {
        snappyDecoder.get().decode(buf, out);
        return innerCodec.getValueDecoder().decode(out, state);
    } finally {
        snappyDecoder.get().reset();
        out.release();
    }
}
 
開發者ID:qq1588518,項目名稱:JRediClients,代碼行數:12,代碼來源:SnappyCodec.java

示例8: returnBuffer

import io.netty.buffer.ByteBuf; //導入方法依賴的package包/類
private void returnBuffer(Request item) {
  ByteBuf buf = item.getContext().getSerializedData();
  if(buf != null && buf.refCnt() > 0) {
    try {
      buf.release();
    } catch (Throwable x) {
      LOG.error("Release Buffer failed." , x);
    }
    item.getContext().setSerializedData(null);
  }
}
 
開發者ID:Tencent,項目名稱:angel,代碼行數:12,代碼來源:MatrixTransportClient.java

示例9: hash

import io.netty.buffer.ByteBuf; //導入方法依賴的package包/類
public static byte[] hash(ByteBuf objectState) {
    ByteBuffer b = objectState.internalNioBuffer(objectState.readerIndex(), objectState.readableBytes());
    long h1 = LongHashFunction.farmUo().hashBytes(b);
    long h2 = LongHashFunction.xx().hashBytes(b);

    ByteBuf buf = ByteBufAllocator.DEFAULT.buffer((2 * Long.SIZE) / Byte.SIZE);
    try {
        buf.writeLong(h1).writeLong(h2);
        byte[] dst = new byte[buf.readableBytes()];
        buf.readBytes(dst);
        return dst;
    } finally {
        buf.release();
    }
}
 
開發者ID:qq1588518,項目名稱:JRediClients,代碼行數:16,代碼來源:Hash.java

示例10: decode

import io.netty.buffer.ByteBuf; //導入方法依賴的package包/類
@Override
protected void decode(ChannelHandlerContext ctx, ByteBuf in, List<Object> out) throws Exception {
	in.markReaderIndex();
	byte[] lengthBytes = new byte[3];

	for (int i = 0; i < 3; i++)
	{
		if (!in.isReadable())
		{
			in.resetReaderIndex();
			return;
		}
		lengthBytes[i] = in.readByte();
		if (lengthBytes[i] >= 0)
		{
			ByteBuf buffer = Unpooled.wrappedBuffer(lengthBytes);

			try
			{
				int packetLength = readVarInt(buffer);
				if (in.readableBytes() < packetLength)
				{
					in.resetReaderIndex();
					return;
				}

				out.add(in.readBytes(packetLength));
			}
			finally
			{
				buffer.release();
			}

			return;
		}
	}
}
 
開發者ID:Dytanic,項目名稱:CloudNet,代碼行數:38,代碼來源:ProtocolLengthDeserializer.java

示例11: testBuffers

import io.netty.buffer.ByteBuf; //導入方法依賴的package包/類
private void testBuffers(ByteBuf[] buffers, SerializedField.Builder[] fields) {
  int i = 0;
  for (SerializedField.Builder field : fields) {
    i += fieldBuffersCount(field, buffers, i, buffers.length);
  }
  while (i < buffers.length && buffers[i].readableBytes() == 0) {
    ++ i;
  }
  assertEquals(buffers.length, i);
  for (ByteBuf byteBuf : buffers) {
    byteBuf.release();
  }
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:14,代碼來源:TestBackwardsCompatibilityEncoder.java

示例12: writeToStream

import io.netty.buffer.ByteBuf; //導入方法依賴的package包/類
public void writeToStream(FSDataOutputStream stream) throws IOException {
  Stopwatch watch = new Stopwatch();
  watch.start();
  available = false;
  check = ThreadLocalRandom.current().nextLong();
  start = stream.getPos();
  logger.debug("Writing check value {} at position {}", check, start);
  stream.writeLong(check);
  batch.getHeader().writeDelimitedTo(stream);
  ByteBuf buf = batch.getBody();
  if (buf != null) {
    bodyLength = buf.capacity();
  } else {
    bodyLength = 0;
  }
  if (bodyLength > 0) {
    buf.getBytes(0, stream, bodyLength);
  }
  stream.hsync();
  FileStatus status = fs.getFileStatus(path);
  long len = status.getLen();
  logger.debug("After spooling batch, stream at position {}. File length {}", stream.getPos(), len);
  batch.sendOk();
  latch.countDown();
  long t = watch.elapsed(TimeUnit.MICROSECONDS);
  logger.debug("Took {} us to spool {} to disk. Rate {} mb/s", t, bodyLength, bodyLength / t);
  if (buf != null) {
    buf.release();
  }
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:31,代碼來源:SpoolingRawBatchBuffer.java

示例13: addFaviconToStatusResponse

import io.netty.buffer.ByteBuf; //導入方法依賴的package包/類
private void addFaviconToStatusResponse(ServerStatusResponse response)
{
    File file1 = this.getFile("server-icon.png");

    if (file1.isFile())
    {
        ByteBuf bytebuf = Unpooled.buffer();

        try
        {
            BufferedImage bufferedimage = ImageIO.read(file1);
            Validate.validState(bufferedimage.getWidth() == 64, "Must be 64 pixels wide", new Object[0]);
            Validate.validState(bufferedimage.getHeight() == 64, "Must be 64 pixels high", new Object[0]);
            ImageIO.write(bufferedimage, "PNG", (OutputStream)(new ByteBufOutputStream(bytebuf)));
            ByteBuf bytebuf1 = Base64.encode(bytebuf);
            response.setFavicon("data:image/png;base64," + bytebuf1.toString(Charsets.UTF_8));
        }
        catch (Exception exception)
        {
            logger.error((String)"Couldn\'t load server icon", (Throwable)exception);
        }
        finally
        {
            bytebuf.release();
        }
    }
}
 
開發者ID:Notoh,項目名稱:DecompiledMinecraft,代碼行數:28,代碼來源:MinecraftServer.java

示例14: decode

import io.netty.buffer.ByteBuf; //導入方法依賴的package包/類
@Override
protected void decode( ChannelHandlerContext channelHandlerContext, ByteBuf input, List<Object> output ) throws Exception {
    input.markReaderIndex();

    byte[] bytes = new byte[3];
    for ( int i = 0; i < bytes.length; i++ ) {
        if ( !input.isReadable() ) {
            input.resetReaderIndex();
            return;
        }
        bytes[i] = input.readByte();
        if ( bytes[i] >= 0 ) {
            ByteBuf buf = Unpooled.wrappedBuffer( bytes );
            try {
                int j = Message.readVarInt( buf );
                if ( input.readableBytes() < j ) {
                    input.resetReaderIndex();
                    return;
                }
                output.add( input.readBytes( j ) );
                return;
            } finally {
                buf.release();
            }
        }
    }
    throw new CorruptedFrameException( "length wider than 21-bit" );
}
 
開發者ID:lukas81298,項目名稱:FlexMC,代碼行數:29,代碼來源:MessageSplitter.java

示例15: encode

import io.netty.buffer.ByteBuf; //導入方法依賴的package包/類
@Override
protected void encode(ChannelHandlerContext ctx, NetoOutboundByteMessage msg, ByteBuf out) throws Exception {
    ByteBuf buffer = msg.buildMessage(charset);
    out.writeBytes(buffer);
    logger.debug("encode - {}", buffer);
    buffer.release();
}
 
開發者ID:veritasware,項目名稱:neto,代碼行數:8,代碼來源:NetoByteToMessageEncoder.java


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