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


Java ByteBuffer.compact方法代碼示例

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


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

示例1: main

import java.nio.ByteBuffer; //導入方法依賴的package包/類
public static void main(String[] args) throws IOException {

        RandomAccessFile file = new RandomAccessFile(FILE_PATH, "rw");

        FileChannel channel = file.getChannel();

        ByteBuffer byteBuffer = ByteBuffer.allocate(48);

        int read = channel.read(byteBuffer);
        while (read != -1) {
            byteBuffer.flip();

            while (byteBuffer.hasRemaining()) {
                System.out.print((char)byteBuffer.get());
            }

            byteBuffer.compact();
            read = channel.read(byteBuffer);
        }
        file.close();
    }
 
開發者ID:daishicheng,項目名稱:outcomes,代碼行數:22,代碼來源:Main.java

示例2: fastCopy

import java.nio.ByteBuffer; //導入方法依賴的package包/類
/**
     * copy
     *
     * @param src
     * @param dest
     * @throws IOException
     */
    public static void fastCopy(final ReadableByteChannel src, final WritableByteChannel dest) throws IOException {
        final ByteBuffer buffer = ByteBuffer.allocateDirect(8 * 1024);
        int count = 0;

        while ((count = src.read(buffer)) != -1) {
//            LogUtil.d("luaviewp-fastCopy", count, buffer.capacity(), buffer.remaining(), buffer.array().length);
            // prepare the buffer to be drained
            buffer.flip();
            // write to the channel, may block
            dest.write(buffer);
            // If partial transfer, shift remainder down
            // If buffer is empty, same as doing clear()
            buffer.compact();
        }
        // EOF will leave buffer in fill state
        buffer.flip();
        // make sure the buffer is fully drained.
        while (buffer.hasRemaining()) {
            dest.write(buffer);
        }
    }
 
開發者ID:alibaba,項目名稱:LuaViewPlayground,代碼行數:29,代碼來源:ChannelTools.java

示例3: channelCopy

import java.nio.ByteBuffer; //導入方法依賴的package包/類
private static void channelCopy(final ReadableByteChannel src, final WritableByteChannel dest) throws IOException
{
    final ByteBuffer buffer = ByteBuffer.allocateDirect(2 * 1024);
    while (src.read(buffer) != -1)
    {
        // prepare the buffer to be drained
        buffer.flip();
        // write to the channel, may block
         dest.write(buffer);

        // If partial transfer, shift remainder down
        // If buffer is empty, same as doing clear()
        buffer.compact();
    }

    // EOF will leave buffer in fill state
    buffer.flip();

    // make sure the buffer is fully drained.
    while (buffer.hasRemaining())
    {
        dest.write(buffer);
    }
}
 
開發者ID:Alfresco,項目名稱:alfresco-repository,代碼行數:25,代碼來源:HttpClientTransmitterImpl.java

示例4: deleteTagChunk

import java.nio.ByteBuffer; //導入方法依賴的package包/類
/**
 * Delete Tag Chunk
 * <p/>
 * Can be used when chunk is not the last chunk
 * <p/>
 * Continually copy a 4mb chunk, write the chunk and repeat until the rest of the file after the tag
 * is rewritten
 *
 * @param fc
 * @param endOfExistingChunk
 * @param lengthTagChunk
 * @throws IOException
 */
private void deleteTagChunk(final FileChannel fc, int endOfExistingChunk, final int lengthTagChunk) throws IOException {
    //Position for reading after the tag
    fc.position(endOfExistingChunk);

    final ByteBuffer buffer = ByteBuffer.allocate((int) TagOptionSingleton.getInstance().getWriteChunkSize());
    while (fc.read(buffer) >= 0 || buffer.position() != 0) {
        buffer.flip();
        final long readPosition = fc.position();
        fc.position(readPosition - lengthTagChunk - buffer.limit());
        fc.write(buffer);
        fc.position(readPosition);
        buffer.compact();
    }
    //Truncate the file after the last chunk
    final long newLength = fc.size() - lengthTagChunk;
    logger.config(loggingName + " Setting new length to:" + newLength);
    fc.truncate(newLength);
}
 
開發者ID:GlennioTech,項目名稱:MetadataEditor,代碼行數:32,代碼來源:WavTagWriter.java

示例5: shift

import java.nio.ByteBuffer; //導入方法依賴的package包/類
ByteBufferReference shift(ByteBufferReference ref1, ByteBufferReference ref2) {
    ByteBuffer buf1 = ref1.get();
    if (buf1.capacity() < engine.getSession().getPacketBufferSize()) {
        ByteBufferReference newRef = getNetBuffer();
        ByteBuffer newBuf = newRef.get();
        newBuf.put(buf1);
        buf1 = newBuf;
        ref1.clear();
        ref1 = newRef;
    } else {
        buf1.compact();
    }
    ByteBuffer buf2 = ref2.get();
    Utils.copy(buf2, buf1, Math.min(buf1.remaining(), buf2.remaining()));
    buf1.flip();
    return ref1;
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:18,代碼來源:AsyncSSLDelegate.java

示例6: combine

import java.nio.ByteBuffer; //導入方法依賴的package包/類
ByteBufferReference combine(ByteBufferReference ref1, ByteBufferReference ref2) {
    ByteBuffer buf1 = ref1.get();
    ByteBuffer buf2 = ref2.get();
    int avail1 = buf1.capacity() - buf1.remaining();
    if (buf2.remaining() < avail1) {
        buf1.compact();
        buf1.put(buf2);
        buf1.flip();
        ref2.clear();
        return ref1;
    }
    int newsize = buf1.remaining() + buf2.remaining();
    ByteBuffer newbuf = ByteBuffer.allocate(newsize); // getting rid of buffer pools
    newbuf.put(buf1);
    newbuf.put(buf2);
    newbuf.flip();
    ref1.clear();
    ref2.clear();
    return ByteBufferReference.of(newbuf);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:21,代碼來源:AsyncSSLDelegate.java

示例7: xorFiles

import java.nio.ByteBuffer; //導入方法依賴的package包/類
public static void xorFiles(SeekableByteChannel inputA, SeekableByteChannel inputB,
                            SeekableByteChannel outputChannel, long limit) throws IOException {
	ByteBuffer aBuffer = ByteBuffer.allocateDirect(BUFFER_SIZE);
	ByteBuffer bBuffer = ByteBuffer.allocateDirect(BUFFER_SIZE);
	ByteBuffer outBuffer = ByteBuffer.allocateDirect(BUFFER_SIZE);

	do {
		if (inputA.position() == inputA.size()) inputA.position(0);
		if (inputB.position() == inputB.size()) inputB.position(0);

		inputA.read(aBuffer);
		inputB.read(bBuffer);
		aBuffer.flip();
		bBuffer.flip();
		int cap = min(aBuffer.remaining(), bBuffer.remaining(), outBuffer.remaining());
		for (int i = 0; i < cap; i += 8) {
			long a = aBuffer.getLong();
			long b = bBuffer.getLong();
			outBuffer.putLong(a ^ b);
		}
		aBuffer.compact();
		bBuffer.compact();

		outBuffer.flip();
		long bytesRequired = limit - outputChannel.size();
		if (outBuffer.limit() > bytesRequired) outBuffer.limit((int) bytesRequired);
		outputChannel.write(outBuffer);
		outBuffer.compact();
	} while (outputChannel.size() < limit);
}
 
開發者ID:zeobviouslyfakeacc,項目名稱:ModLoaderInstaller,代碼行數:31,代碼來源:FileUtils.java

示例8: compactReadBuffer

import java.nio.ByteBuffer; //導入方法依賴的package包/類
private ByteBuffer compactReadBuffer(ByteBuffer buffer, int offset) {
	if(buffer == null) {
		return null;
	}
	buffer.limit(buffer.position());
	buffer.position(offset);
	buffer = buffer.compact();
	readBufferOffset = 0;
	return buffer;
}
 
開發者ID:huang-up,項目名稱:mycat-src-1.6.1-RELEASE,代碼行數:11,代碼來源:AbstractConnection.java

示例9: write0

import java.nio.ByteBuffer; //導入方法依賴的package包/類
/**
 * return true ,means no more data
 *
 * @return
 */
private boolean write0() {
    if (!writing.compareAndSet(false, true)) {
        return false;
    }
    ByteBuffer theBuffer = con.writeBuffer;
    if (theBuffer == null || !theBuffer.hasRemaining()) { // writeFinished,if buffer not NULL,recycle
        if (theBuffer != null) {
            con.recycle(theBuffer);
            con.writeBuffer = null;

        }
        // poll again
        ByteBuffer buffer = con.writeQueue.poll();
        // more data
        if (buffer != null) {
            if (buffer.limit() == 0) {
                con.recycle(buffer);
                con.writeBuffer = null;
                con.close("quit cmd");
                writing.set(false);
                return true;
            } else {
                con.writeBuffer = buffer;
                asyncWrite(buffer);
                return false;
            }
        } else {
            // no buffer
            writing.set(false);
            return true;
        }
    } else {
        theBuffer.compact();
        asyncWrite(theBuffer);
        return false;
    }

}
 
開發者ID:actiontech,項目名稱:dble,代碼行數:44,代碼來源:AIOSocketWR.java

示例10: decode

import java.nio.ByteBuffer; //導入方法依賴的package包/類
public final void decode(SocketAddress address, byte[] array, int offset, int length) {
    ByteBuffer buffer = mAddressByteBufferMap.get(address);
    if (buffer == null) {
        buffer = ByteBuffer.allocate(CACHE_BUFFER_LENGTH);
        mAddressByteBufferMap.put(address, buffer);
        buffer.flip();
        LoggerFactory.getLogger().info("創建 " + address.toString() + " 數據緩衝區ByteBuffer");
    }
    LoggerFactory.getLogger().info(String.format("%s 上次未解碼 position=%d limit=%d", address.toString(), buffer.position(), buffer.limit()));
    if (buffer.limit() + length > buffer.capacity()) {
        LoggerFactory.getLogger().warn(address.toString() + " -> decode緩存區已滿,讀取的數據被丟棄!!!!!");
        return;
    }
    buffer.compact();
    buffer.put(array, offset, length);
    buffer.flip();
    buffer.mark();
    LoggerFactory.getLogger().info(String.format("%s 合並未解碼 position=%d limit=%d", address.toString(), buffer.position(), buffer.limit()));
    LoggerFactory.getLogger().info(address.toString() + " 開始解碼數據");
    while (buffer.hasRemaining() && (decode(address, buffer) != null)) {
        LoggerFactory.getLogger().info(address.toString() + " 成功解碼一條數據");
        buffer.compact();
        buffer.flip();
        buffer.mark();
    }
    LoggerFactory.getLogger().info(address.toString() + " 退出解碼");
    buffer.reset();
    LoggerFactory.getLogger().info(String.format("%s 未解碼數據 position=%d limit=%d", address.toString(), buffer.position(), buffer.limit()));
}
 
開發者ID:spacetimeme,項目名稱:DreamSocket,代碼行數:30,代碼來源:MessageDecode.java

示例11: ungetRequestBytes

import java.nio.ByteBuffer; //導入方法依賴的package包/類
/**
 * Pushes back the given data. This should only be used by transfer coding handlers that have read past
 * the end of the request when handling pipelined requests
 *
 * @param unget The buffer to push back
 */
public void ungetRequestBytes(final Pooled<ByteBuffer> unget) {
    if (getExtraBytes() == null) {
        setExtraBytes(unget);
    } else {
        Pooled<ByteBuffer> eb = getExtraBytes();
        ByteBuffer buf = eb.getResource();
        final ByteBuffer ugBuffer = unget.getResource();

        if (ugBuffer.limit() - ugBuffer.remaining() > buf.remaining()) {
            //stuff the existing data after the data we are ungetting
            ugBuffer.compact();
            ugBuffer.put(buf);
            ugBuffer.flip();
            eb.free();
            setExtraBytes(unget);
        } else {
            //TODO: this is horrible, but should not happen often
            final byte[] data = new byte[ugBuffer.remaining() + buf.remaining()];
            int first = ugBuffer.remaining();
            ugBuffer.get(data, 0, ugBuffer.remaining());
            buf.get(data, first, buf.remaining());
            eb.free();
            unget.free();
            final ByteBuffer newBuffer = ByteBuffer.wrap(data);
            setExtraBytes(new ImmediatePooled<>(newBuffer));
        }
    }
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:35,代碼來源:HttpServerConnection.java

示例12: readBlocking

import java.nio.ByteBuffer; //導入方法依賴的package包/類
public void readBlocking(StreamSourceFrameChannel channel) throws IOException {
    Pooled<ByteBuffer> pooled = channel.getWebSocketChannel().getBufferPool().allocate();
    final ByteBuffer buffer = pooled.getResource();
    try {
        for (; ; ) {
            int res = channel.read(buffer);
            if (res == -1) {
                buffer.flip();
                data.write(buffer);
                this.complete = true;
                return;
            } else if (res == 0) {
                channel.awaitReadable();
            }
            checkMaxSize(channel, res);
            if (!buffer.hasRemaining()) {
                buffer.flip();
                data.write(buffer);
                buffer.compact();
                if (!bufferFullMessage) {
                    //if we are not reading the full message we return
                    return;
                }
            }
        }
    } finally {
        pooled.free();
    }
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:30,代碼來源:BufferedTextMessage.java

示例13: handleWrite

import java.nio.ByteBuffer; //導入方法依賴的package包/類
public static void handleWrite(SelectionKey key) throws IOException {
	ByteBuffer buf = (ByteBuffer) key.attachment();
	buf.flip();
	SocketChannel sc = (SocketChannel) key.channel();
	while (buf.hasRemaining()) {
		sc.write(buf);
	}
	buf.compact();
}
 
開發者ID:spafka,項目名稱:spark_deep,代碼行數:10,代碼來源:NioServer.java

示例14: copy

import java.nio.ByteBuffer; //導入方法依賴的package包/類
public static void copy(ReadableByteChannel src, WritableByteChannel dest) throws IOException {
	final ByteBuffer buffer = ByteBuffer.allocateDirect(16 * 1024);

	while (src.read(buffer) != -1) {
		buffer.flip();
		dest.write(buffer);
		buffer.compact();
	}
	buffer.flip();
	dest.write(buffer);
}
 
開發者ID:xtf-cz,項目名稱:xtf,代碼行數:12,代碼來源:IOUtils.java

示例15: isStreamEqual

import java.nio.ByteBuffer; //導入方法依賴的package包/類
private static boolean isStreamEqual(InputStream i1, InputStream i2)
        throws IOException {

    ReadableByteChannel ch1 = Channels.newChannel(i1);
    ReadableByteChannel ch2 = Channels.newChannel(i2);

    ByteBuffer buf1 = ByteBuffer.allocateDirect(1024);
    ByteBuffer buf2 = ByteBuffer.allocateDirect(1024);

    try {
        while (true) {

            int n1 = ch1.read(buf1);
            int n2 = ch2.read(buf2);

            if (n1 == -1 || n2 == -1) return n1 == n2;

            buf1.flip();
            buf2.flip();

            for (int i = 0; i < Math.min(n1, n2); i++)
                if (buf1.get() != buf2.get())
                    return false;

            buf1.compact();
            buf2.compact();
        }

    } finally {
        if (i1 != null) i1.close();
        if (i2 != null) i2.close();
    }
}
 
開發者ID:eclipse,項目名稱:gemoc-studio,代碼行數:34,代碼來源:IFileUtils.java


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