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


Java GatheringByteChannel類代碼示例

本文整理匯總了Java中java.nio.channels.GatheringByteChannel的典型用法代碼示例。如果您正苦於以下問題:Java GatheringByteChannel類的具體用法?Java GatheringByteChannel怎麽用?Java GatheringByteChannel使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: divideProcessing

import java.nio.channels.GatheringByteChannel; //導入依賴的package包/類
protected void divideProcessing (int bufferSize, StringBuffer bf, ByteBuffer bb, GatheringByteChannel outChannel, String charset) throws IOException {
	int bfsCnt = bf.length()/bufferSize+1;
	for(int i=0;i<bfsCnt;i++) {
		String sub = null;
		if(i<bfsCnt-1) {
			sub = bf.substring(i*bufferSize, (i+1)*bufferSize);
		} else {
			sub = bf.substring(i*bufferSize, i*bufferSize+(bf.length()%bufferSize));
		}
		if(sub != null){
			bb.put(sub.getBytes(charset));
			bb.flip();
   			
   			outChannel.write(bb);
   			bb.clear();
		}
	}
	bf.setLength(0);
}
 
開發者ID:experdb,項目名稱:eXperDB-DB2PG,代碼行數:20,代碼來源:ExecuteQuery.java

示例2: writeTo

import java.nio.channels.GatheringByteChannel; //導入依賴的package包/類
@Override
public void writeTo(GatheringByteChannel channel) throws IOException {
    // nothing to do
    if (length == 0) {
        return;
    }

    int currentLength = length;
    int currentOffset = offset;
    BytesRef ref = new BytesRef();

    while (currentLength > 0) {
        // try to align to the underlying pages while writing, so no new arrays will be created.
        int fragmentSize = Math.min(currentLength, PAGE_SIZE - (currentOffset % PAGE_SIZE));
        boolean newArray = bytearray.get(currentOffset, fragmentSize, ref);
        assert !newArray : "PagedBytesReference failed to align with underlying bytearray. offset [" + currentOffset + "], size [" + fragmentSize + "]";
        Channels.writeToChannel(ref.bytes, ref.offset, ref.length, channel);
        currentLength -= ref.length;
        currentOffset += ref.length;
    }

    assert currentLength == 0;
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:24,代碼來源:PagedBytesReference.java

示例3: writeTo

import java.nio.channels.GatheringByteChannel; //導入依賴的package包/類
@Override
public long writeTo(GatheringByteChannel channel) throws IOException {
    if (completed())
        throw new KafkaException("This operation cannot be invoked on a complete request.");

    int totalWrittenPerCall = 0;
    boolean sendComplete;
    do {
        long written = current.writeTo(channel);
        totalWrittenPerCall += written;
        sendComplete = current.completed();
        if (sendComplete)
            nextSendOrDone();
    } while (!completed() && sendComplete);

    totalWritten += totalWrittenPerCall;

    if (completed() && totalWritten != size)
        log.error("mismatch in sending bytes over socket; expected: " + size + " actual: " + totalWritten);

    log.trace("Bytes written as part of multi-send call: {}, total bytes written so far: {}, expected bytes to write: {}",
            totalWrittenPerCall, totalWritten, size);

    return totalWrittenPerCall;
}
 
開發者ID:YMCoding,項目名稱:kafka-0.11.0.0-src-with-comment,代碼行數:26,代碼來源:MultiSend.java

示例4: writeTo

import java.nio.channels.GatheringByteChannel; //導入依賴的package包/類
@Override
public long writeTo(GatheringByteChannel destChannel, long offset, int length) throws IOException {
    long newSize = Math.min(channel.size(), end) - start;
    int oldSize = sizeInBytes();
    if (newSize < oldSize)
        throw new KafkaException(String.format(
                "Size of FileRecords %s has been truncated during write: old size %d, new size %d",
                file.getAbsolutePath(), oldSize, newSize));

    long position = start + offset;
    int count = Math.min(length, oldSize);
    final long bytesTransferred;
    if (destChannel instanceof TransportLayer) {
        TransportLayer tl = (TransportLayer) destChannel;
        bytesTransferred = tl.transferFrom(channel, position, count);
    } else {
        bytesTransferred = channel.transferTo(position, count, destChannel);
    }
    return bytesTransferred;
}
 
開發者ID:YMCoding,項目名稱:kafka-0.11.0.0-src-with-comment,代碼行數:21,代碼來源:FileRecords.java

示例5: writeTo

import java.nio.channels.GatheringByteChannel; //導入依賴的package包/類
@Override
public long writeTo(GatheringByteChannel channel) throws IOException {
    long written = 0;

    if (remaining > 0) {
        written = records.writeTo(channel, size() - remaining, remaining);
        if (written < 0)
            throw new EOFException("Wrote negative bytes to channel. This shouldn't happen.");
        remaining -= written;
    }

    pending = TransportLayers.hasPendingWrites(channel);
    if (remaining <= 0 && pending)
        channel.write(EMPTY_BYTE_BUFFER);

    return written;
}
 
開發者ID:YMCoding,項目名稱:kafka-0.11.0.0-src-with-comment,代碼行數:18,代碼來源:RecordsSend.java

示例6: writeTo

import java.nio.channels.GatheringByteChannel; //導入依賴的package包/類
@Override
public long writeTo(GatheringByteChannel channel) throws IOException {
    if (completed())
        throw new KafkaException("This operation cannot be completed on a complete request.");

    int totalWrittenPerCall = 0;
    boolean sendComplete = false;
    do {
        long written = current.writeTo(channel);
        totalWritten += written;
        totalWrittenPerCall += written;
        sendComplete = current.completed();
        if (sendComplete)
            nextSendOrDone();
    } while (!completed() && sendComplete);
    if (log.isTraceEnabled())
        log.trace("Bytes written as part of multisend call : " + totalWrittenPerCall +  "Total bytes written so far : " + totalWritten + "Expected bytes to write : " + size);
    return totalWrittenPerCall;
}
 
開發者ID:txazo,項目名稱:kafka,代碼行數:20,代碼來源:MultiSend.java

示例7: transfer

import java.nio.channels.GatheringByteChannel; //導入依賴的package包/類
protected long transfer(ByteBuf source, WritableByteChannel target, MultipartState sourceFullyWrittenState) throws IOException {

        int transferred = 0;
        if (target instanceof GatheringByteChannel) {
            transferred = source.readBytes((GatheringByteChannel) target, (int) source.readableBytes());
        } else {
            for (ByteBuffer byteBuffer : source.nioBuffers()) {
                int len = byteBuffer.remaining();
                int written = target.write(byteBuffer);
                transferred += written;
                if (written != len) {
                    // couldn't write full buffer, exit loop
                    break;
                }
            }
            // assume this is a basic single ByteBuf
            source.readerIndex(source.readerIndex() + transferred);
        }

        if (source.isReadable()) {
            slowTarget = true;
        } else {
            state = sourceFullyWrittenState;
        }
        return transferred;
    }
 
開發者ID:amaralDaniel,項目名稱:megaphone,代碼行數:27,代碼來源:MultipartPart.java

示例8: getBytes

import java.nio.channels.GatheringByteChannel; //導入依賴的package包/類
private int getBytes(int index, GatheringByteChannel out, int length, boolean internal) throws IOException {
    checkIndex(index, length);
    if (length == 0) {
        return 0;
    }

    ByteBuffer tmpBuf;
    if (internal) {
        tmpBuf = internalNioBuffer();
    } else {
        tmpBuf = memory.duplicate();
    }
    index = idx(index);
    tmpBuf.clear().position(index).limit(index + length);
    return out.write(tmpBuf);
}
 
開發者ID:wuyinxian124,項目名稱:netty4.0.27Learn,代碼行數:17,代碼來源:PooledUnsafeDirectByteBuf.java

示例9: gather

import java.nio.channels.GatheringByteChannel; //導入依賴的package包/類
public static void gather() {
	ByteBuffer header = ByteBuffer.allocate(14);
	ByteBuffer body = ByteBuffer.allocate(100);

	header.put(headers.getBytes());
	body.put(bodys.getBytes());

	GatheringByteChannel channel = getChannel();

	try {
		header.flip();
		body.flip();
		channel.write(new ByteBuffer[] { header, body });
	} catch (IOException e) {
		e.printStackTrace();
	}

}
 
開發者ID:zoopaper,項目名稱:netty-study,代碼行數:19,代碼來源:ScatterAndGather.java

示例10: sendBuffer

import java.nio.channels.GatheringByteChannel; //導入依賴的package包/類
private void sendBuffer (ByteBuffer data,
	GatheringByteChannel channel, String contentType)
	throws Exception
{
	ByteBuffer [] buffers = { staticHdr, dynHdr, data };

	staticHdr.rewind();

	cbtemp.clear();
	cbtemp.put ("Content-Length: " + data.limit());
	cbtemp.put (LINE_SEP);
	cbtemp.put ("Content-Type: ");
	cbtemp.put (contentType);
	cbtemp.put (LINE_SEP);
	cbtemp.put (LINE_SEP);
	cbtemp.flip();

	buffers [1] = utf8.encode (cbtemp);

	while (channel.write (buffers) != 0) {
		// nothing
	}
}
 
開發者ID:jt120,項目名稱:nio,代碼行數:24,代碼來源:HttpServer.java

示例11: main

import java.nio.channels.GatheringByteChannel; //導入依賴的package包/類
public static void main (String [] argv)
	throws Exception
{
	int reps = 10;

	if (argv.length > 0) {
		reps = Integer.parseInt (argv [0]);
	}

	FileOutputStream fos = new FileOutputStream (DEMOGRAPHIC);
	GatheringByteChannel gatherChannel = fos.getChannel();

	// generate some brilliant marcom, er, repurposed content
	ByteBuffer [] bs = utterBS (reps);

	// deliver the message to the waiting market
	while (gatherChannel.write (bs) > 0) {
		// empty body
		// loop until write() returns zero
	}

	System.out.println ("Mindshare paradigms synergized to "
		+ DEMOGRAPHIC);

	fos.close();
}
 
開發者ID:jt120,項目名稱:nio,代碼行數:27,代碼來源:Marketing.java

示例12: writeTo

import java.nio.channels.GatheringByteChannel; //導入依賴的package包/類
/**
 * Write some of this set to the given channel.
 *
 * @param destChannel   The channel to write to.
 * @param writePosition The position in the message set to begin writing from.
 * @param size          The maximum number of bytes to write
 * @return The number of bytes actually written.
 */
@Override
public int writeTo(final GatheringByteChannel destChannel, final long writePosition, final int size) throws IOException {
    // Ensure that the underlying size has not changed.
    int newSize = Math.min((int) channel.size(), end) - start;
    if (newSize < _size.get()) {
        throw new SamsaException(String.format(
                "Size of FileMessageSet %s has been truncated during write: old size %d, new size %d",
                file.getAbsolutePath(), _size.get(), newSize));
    }
    int bytesTransferred = (int) channel.transferTo(start + writePosition, Math.min(size, sizeInBytes()), destChannel);
    if (LOG.isTraceEnabled()) {
        LOG.trace("FileMessageSet {} : bytes transferred : {} bytes requested for transfer : {}",
                file.getAbsolutePath(), bytesTransferred, Math.min(size, sizeInBytes()));
    }
    return bytesTransferred;
}
 
開發者ID:bernd,項目名稱:samsa,代碼行數:25,代碼來源:FileMessageSet.java

示例13: newSink

import java.nio.channels.GatheringByteChannel; //導入依賴的package包/類
private static Sink newSink(Object out) {
    if (out instanceof OutputStream) {
        return new OioSink((OutputStream) out);
    }
    if (out instanceof GatheringByteChannel) {
        return new NioSink((GatheringByteChannel) out);
    }
    throw new FastdfsException("unknown sink output type " + out.getClass().getName());
}
 
開發者ID:rodbate,項目名稱:fastdfs-spring-boot,代碼行數:10,代碼來源:StreamReplier.java

示例14: getBox

import java.nio.channels.GatheringByteChannel; //導入依賴的package包/類
public void getBox(WritableByteChannel writableByteChannel) throws IOException {
    ByteBuffer bb = ByteBuffer.allocate(16);
    long size = getSize();
    if (isSmallBox(size)) {
        IsoTypeWriter.writeUInt32(bb, size);
    } else {
        IsoTypeWriter.writeUInt32(bb, 1);
    }
    bb.put(IsoFile.fourCCtoBytes("mdat"));
    if (isSmallBox(size)) {
        bb.put(new byte[8]);
    } else {
        IsoTypeWriter.writeUInt64(bb, size);
    }
    bb.rewind();
    writableByteChannel.write(bb);
    if (writableByteChannel instanceof GatheringByteChannel) {
        List<ByteBuffer> nuSamples = unifyAdjacentBuffers(samples);


        for (int i = 0; i < Math.ceil((double) nuSamples.size() / STEPSIZE); i++) {
            List<ByteBuffer> sublist = nuSamples.subList(
                    i * STEPSIZE, // start
                    (i + 1) * STEPSIZE < nuSamples.size() ? (i + 1) * STEPSIZE : nuSamples.size()); // end
            ByteBuffer sampleArray[] = sublist.toArray(new ByteBuffer[sublist.size()]);
            do {
                ((GatheringByteChannel) writableByteChannel).write(sampleArray);
            } while (sampleArray[sampleArray.length - 1].remaining() > 0);
        }
        //System.err.println(bytesWritten);
    } else {
        for (ByteBuffer sample : samples) {
            sample.rewind();
            writableByteChannel.write(sample);
        }
    }
}
 
開發者ID:begeekmyfriend,項目名稱:mp4parser_android,代碼行數:38,代碼來源:DefaultMp4Builder.java

示例15: writeToChannel

import java.nio.channels.GatheringByteChannel; //導入依賴的package包/類
/**
 * Copies bytes from source {@link org.jboss.netty.buffer.ChannelBuffer} to a {@link java.nio.channels.GatheringByteChannel}
 *
 * @param source      ChannelBuffer to copy from
 * @param sourceIndex index in <i>source</i> to start copying from
 * @param length      how many bytes to copy
 * @param channel     target GatheringByteChannel
 */
public static void writeToChannel(ChannelBuffer source, int sourceIndex, int length, GatheringByteChannel channel) throws IOException {
    while (length > 0) {
        int written = source.getBytes(sourceIndex, channel, length);
        sourceIndex += written;
        length -= written;
    }
    assert length == 0;
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:17,代碼來源:Channels.java


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