本文整理匯總了Java中java.nio.channels.FileChannel.position方法的典型用法代碼示例。如果您正苦於以下問題:Java FileChannel.position方法的具體用法?Java FileChannel.position怎麽用?Java FileChannel.position使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類java.nio.channels.FileChannel
的用法示例。
在下文中一共展示了FileChannel.position方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: getNextTokenSize
import java.nio.channels.FileChannel; //導入方法依賴的package包/類
public static long getNextTokenSize(FileChannel fileChannel, long position, byte[]... btsArr)
throws IOException {
long ret = -1;
ByteBuffer buffer = ByteBuffer.allocateDirect(8192);
if (position >= 0) {
fileChannel.position(position);
}
long startPosition = fileChannel.position();
outer:
while (fileChannel.read(buffer) != -1) {
buffer.flip();
int index;
while ((index = findBytes(buffer, btsArr)) != -1) {
ret = fileChannel.position() - startPosition - buffer.limit() + index;
break outer;
}
buffer.clear();
}
fileChannel.position(startPosition);
return ret;
}
示例2: insertContent
import java.nio.channels.FileChannel; //導入方法依賴的package包/類
public static void insertContent(String path, long offset, byte[] content) throws IOException {
RandomAccessFile sourceRaf = new RandomAccessFile(path, "rw");
File tempFile = FileUtil.createFile(path + ".tmp");
RandomAccessFile tempRaf = new RandomAccessFile(tempFile, "rw");
long fileSize = sourceRaf.length();
FileChannel sourceChannel = sourceRaf.getChannel();
FileChannel targetChannel = tempRaf.getChannel();
long remaining = fileSize - offset;
long position = offset;
while (remaining > 0) {
long transferred = sourceChannel.transferTo(position, remaining, targetChannel);
remaining -= transferred;
position += transferred;
}
sourceChannel.truncate(offset);
sourceRaf.seek(offset);
sourceRaf.write(content);
long newOffset = sourceRaf.getFilePointer();
targetChannel.position(0);
sourceChannel.transferFrom(targetChannel, newOffset, (fileSize - offset));
sourceChannel.close();
targetChannel.close();
FileUtil.deleteIfExists(tempFile);
}
示例3: read
import java.nio.channels.FileChannel; //導入方法依賴的package包/類
/**
* Read editable Metadata
*
* @param file
* @return
* @throws CannotReadException
* @throws IOException
*/
public AiffTag read(File file) throws CannotReadException, IOException {
FileChannel fc = new FileOutputStream(file.getAbsolutePath(), false).getChannel();
AiffAudioHeader aiffAudioHeader = new AiffAudioHeader();
AiffTag aiffTag = new AiffTag();
final AiffFileHeader fileHeader = new AiffFileHeader();
fileHeader.readHeader(fc, aiffAudioHeader, file.toString());
while (fc.position() < fc.size()) {
if (!readChunk(fc, aiffTag, file.toString())) {
logger.severe(file + " UnableToReadProcessChunk");
break;
}
}
if (aiffTag.getID3Tag() == null) {
aiffTag.setID3Tag(AiffTag.createDefaultID3Tag());
}
return aiffTag;
}
示例4: storeSession
import java.nio.channels.FileChannel; //導入方法依賴的package包/類
@Override
public void storeSession(@NonNull SignalProtocolAddress address, @NonNull SessionRecord record) {
synchronized (FILE_LOCK) {
try {
RandomAccessFile sessionFile = new RandomAccessFile(getSessionFile(address), "rw");
FileChannel out = sessionFile.getChannel();
out.position(0);
writeInteger(CURRENT_VERSION, out);
writeBlob(record.serialize(), out);
out.truncate(out.position());
sessionFile.close();
} catch (IOException e) {
throw new AssertionError(e);
}
}
}
示例5: copyResource
import java.nio.channels.FileChannel; //導入方法依賴的package包/類
public void copyResource(OpenForReadResult input, OutputStream outputStream) throws IOException {
assertBackgroundThread();
try {
InputStream inputStream = input.inputStream;
if (inputStream instanceof FileInputStream && outputStream instanceof FileOutputStream) {
FileChannel inChannel = ((FileInputStream)input.inputStream).getChannel();
FileChannel outChannel = ((FileOutputStream)outputStream).getChannel();
long offset = 0;
long length = input.length;
if (input.assetFd != null) {
offset = input.assetFd.getStartOffset();
}
// transferFrom()'s 2nd arg is a relative position. Need to set the absolute
// position first.
inChannel.position(offset);
outChannel.transferFrom(inChannel, 0, length);
} else {
final int BUFFER_SIZE = 8192;
byte[] buffer = new byte[BUFFER_SIZE];
for (;;) {
int bytesRead = inputStream.read(buffer, 0, BUFFER_SIZE);
if (bytesRead <= 0) {
break;
}
outputStream.write(buffer, 0, bytesRead);
}
}
} finally {
input.inputStream.close();
if (outputStream != null) {
outputStream.close();
}
}
}
示例6: writeMetadataSameSize
import java.nio.channels.FileChannel; //導入方法依賴的package包/類
/**
* Replace the ilst metadata
* <p/>
* Because it is the same size as the original data nothing else has to be modified
*
* @param rawIlstData
* @param oldIlstSize
* @param startIstWithinFile
* @param fileReadChannel
* @param fileWriteChannel
* @throws CannotWriteException
* @throws IOException
*/
private void writeMetadataSameSize(ByteBuffer rawIlstData,
long oldIlstSize,
long startIstWithinFile,
FileChannel fileReadChannel,
FileChannel fileWriteChannel,
Mp4BoxHeader tagsHeader) throws CannotWriteException, IOException {
fileReadChannel.position(0);
fileWriteChannel.transferFrom(fileReadChannel, 0, startIstWithinFile);
fileWriteChannel.position(startIstWithinFile);
fileWriteChannel.write(rawIlstData);
fileReadChannel.position(startIstWithinFile + oldIlstSize);
writeDataAfterIlst(fileReadChannel, fileWriteChannel, tagsHeader);
}
示例7: performTransfer
import java.nio.channels.FileChannel; //導入方法依賴的package包/類
private void performTransfer(FileChannel source, IoCallback callback) {
ByteBuffer buffer = ByteBuffer.allocate(BUFFER_SIZE);
try {
long pos = source.position();
long size = source.size();
while (size - pos > 0) {
int ret = source.read(buffer);
if (ret <= 0) {
break;
}
pos += ret;
buffer.flip();
if (!writeBuffer(buffer, callback)) {
return;
}
buffer.clear();
}
if (pos != size) {
throw new EOFException("Unexpected EOF reading file");
}
} catch (IOException e) {
callback.onException(exchange, this, e);
}
invokeOnComplete(callback);
}
示例8: getBytes
import java.nio.channels.FileChannel; //導入方法依賴的package包/類
public long getBytes(ByteBuffer readInto, long offset, int length) throws IOException {
final long offsetInThisBucket = offsetInThisBucket(offset);
final long lengthInThisBucket = calcLengthInThisBucket(offsetInThisBucket, length);
final int read;
ByteBuffer encrypted = ByteBuffer.allocate(length);
synchronized (this) {
final FileChannel openChannel = getOpenChannel();
openChannel.position(offsetInThisBucket);
read = openChannel.read(encrypted);
if (read > 0) {
encrypted.flip();
encrypted.limit(read);
final ByteBuffer decrypted = encryption.encrypt(offset, encrypted);
readInto.put(decrypted);
}
}
if (read != lengthInThisBucket) {
final byte[] zeroes;
if (read == -1) {
zeroes = new byte[(int) lengthInThisBucket];
} else {
zeroes = new byte[(int) (lengthInThisBucket - read)];
}
LOGGER.debug("tried to read more bytes from this file than ever were written, replacing with {} zeroes", zeroes.length);
readInto.put(zeroes);
}
return lengthInThisBucket;
}
示例9: isFilePortionNull
import java.nio.channels.FileChannel; //導入方法依賴的package包/類
/**
* @param startByte
* @param endByte
* @return true if all the bytes between in the file between startByte and endByte are null, false
* otherwise
* @throws Exception
*/
private boolean isFilePortionNull(int startByte, int endByte) throws IOException {
logger.config("Checking file portion:" + Hex.asHex(startByte) + ":" + Hex.asHex(endByte));
FileInputStream fis = null;
FileChannel fc = null;
try {
fis = new FileInputStream(file);
fc = fis.getChannel();
fc.position(startByte);
ByteBuffer bb = ByteBuffer.allocateDirect(endByte - startByte);
fc.read(bb);
while (bb.hasRemaining()) {
if (bb.get() != 0) {
return false;
}
}
} finally {
if (fc != null) {
fc.close();
}
if (fis != null) {
fis.close();
}
}
return true;
}
示例10: nioByteBuffer
import java.nio.channels.FileChannel; //導入方法依賴的package包/類
@Override
public ByteBuffer nioByteBuffer() throws IOException {
FileChannel channel = null;
try {
channel = new RandomAccessFile(file, "r").getChannel();
// Just copy the buffer if it's sufficiently small, as memory mapping has a high overhead.
if (length < conf.memoryMapBytes()) {
ByteBuffer buf = ByteBuffer.allocate((int) length);
channel.position(offset);
while (buf.remaining() != 0) {
if (channel.read(buf) == -1) {
throw new IOException(String.format("Reached EOF before filling buffer\n" +
"offset=%s\nfile=%s\nbuf.remaining=%s",
offset, file.getAbsoluteFile(), buf.remaining()));
}
}
buf.flip();
return buf;
} else {
return channel.map(FileChannel.MapMode.READ_ONLY, offset, length);
}
} catch (IOException e) {
try {
if (channel != null) {
long size = channel.size();
throw new IOException("Error in reading " + this + " (actual file length " + size + ")",
e);
}
} catch (IOException ignored) {
// ignore
}
throw new IOException("Error in opening " + this, e);
} finally {
JavaUtils.closeQuietly(channel);
}
}
示例11: run
import java.nio.channels.FileChannel; //導入方法依賴的package包/類
public boolean run(boolean complete) {
try {
FileChannel source = fileChannel;
long pos = source.position();
long size = source.size();
StreamSinkChannel dest = channel;
if (dest == null) {
if (callback == IoCallback.END_EXCHANGE) {
if (exchange.getResponseContentLength() == -1 && !exchange.getResponseHeaders().contains(Headers.TRANSFER_ENCODING)) {
exchange.setResponseContentLength(size);
}
}
channel = dest = exchange.getResponseChannel();
if (dest == null) {
throw UndertowMessages.MESSAGES.responseChannelAlreadyProvided();
}
}
while (size - pos > 0) {
long ret = dest.transferFrom(source, pos, size - pos);
pos += ret;
if (ret == 0) {
source.position(pos);
dest.getWriteSetter().set(this);
dest.resumeWrites();
return false;
}
}
if (complete) {
invokeOnComplete();
}
} catch (IOException e) {
invokeOnException(callback, e);
}
return true;
}
示例12: ID3v11Tag
import java.nio.channels.FileChannel; //導入方法依賴的package包/類
/**
* Creates a new ID3v11 datatype.
*
* @param file
* @param loggingFilename
* @throws TagNotFoundException
* @throws IOException
*/
public ID3v11Tag(RandomAccessFile file, String loggingFilename) throws TagNotFoundException, IOException
{
setLoggingFilename(loggingFilename);
FileChannel fc;
ByteBuffer byteBuffer = ByteBuffer.allocate(TAG_LENGTH);
fc = file.getChannel();
fc.position(file.length() - TAG_LENGTH);
fc.read(byteBuffer);
byteBuffer.flip();
read(byteBuffer);
}
示例13: delete
import java.nio.channels.FileChannel; //導入方法依賴的package包/類
/**
* Delete tag from file
* Looks for tag and if found lops it off the file.
*
* @param file to delete the tag from
* @throws IOException if there was a problem accessing the file
*/
public void delete(RandomAccessFile file) throws IOException
{
//Read into Byte Buffer
logger.config("Deleting ID3v1 from file if exists");
FileChannel fc;
ByteBuffer byteBuffer;
fc = file.getChannel();
if(file.length() < TAG_LENGTH)
{
throw new IOException("File not not appear large enough to contain a tag");
}
fc.position(file.length() - TAG_LENGTH);
byteBuffer = ByteBuffer.allocate(TAG_LENGTH);
fc.read(byteBuffer);
byteBuffer.rewind();
if (AbstractID3v1Tag.seekForV1OrV11Tag(byteBuffer))
{
try
{
logger.config("Deleted ID3v1 tag");
file.setLength(file.length() - TAG_LENGTH);
}
catch(IOException ex)
{
logger.severe("Unable to delete existing ID3v1 Tag:"+ex.getMessage());
}
}
else
{
logger.config("Unable to find ID3v1 tag to deleteField");
}
}
示例14: writeNeroData
import java.nio.channels.FileChannel; //導入方法依賴的package包/類
/**
* If the existing files contains a tags atom and chp1 atom underneath the meta atom that means the file was
* encoded by Nero. Applications such as foobar read this non-standard tag before the more usual data within
* {@code ilst} causing problems. So the solution is to convert the tags atom and its children into a free atom whilst
* leaving the chp1 atom alone.
*
* @param fileReadChannel
* @param fileWriteChannel
* @param tagsHeader
* @throws IOException
*/
private void writeNeroData(FileChannel fileReadChannel, FileChannel fileWriteChannel, Mp4BoxHeader tagsHeader) throws IOException, CannotWriteException
{
//Write from after ilst upto tags atom
long writeBetweenIlstAndTags = tagsHeader.getFilePos() - fileReadChannel.position();
fileWriteChannel.transferFrom(fileReadChannel, fileWriteChannel.position(), writeBetweenIlstAndTags);
fileWriteChannel.position(fileWriteChannel.position() + writeBetweenIlstAndTags);
//Replace tags atom (and children) by a free atom
convertandWriteTagsAtomToFreeAtom(fileWriteChannel, tagsHeader);
//Write after tags atom
fileReadChannel.position(tagsHeader.getFileEndPos());
writeDataInChunks(fileReadChannel, fileWriteChannel);
}
示例15: read
import java.nio.channels.FileChannel; //導入方法依賴的package包/類
public void
read(
RandomAccessFile raf,
DirectByteBuffer buffer,
long offset )
throws FMFileManagerException
{
if (raf == null){
throw new FMFileManagerException( "read: raf is null" );
}
FileChannel fc = raf.getChannel();
if ( !fc.isOpen()){
Debug.out("FileChannel is closed: " + owner.getName());
throw( new FMFileManagerException( "read - file is closed"));
}
AEThread2.setDebug( owner );
try{
if(USE_MMAP)
{
long remainingInFile = fc.size()-offset;
long remainingInTargetBuffer = buffer.remaining(DirectByteBuffer.SS_FILE);
MappedByteBuffer buf = fc.map(MapMode.READ_ONLY, offset, Math.min(remainingInFile,remainingInTargetBuffer));
buffer.put(DirectByteBuffer.SS_FILE, buf);
} else {
fc.position(offset);
while (fc.position() < fc.size() && buffer.hasRemaining(DirectByteBuffer.SS_FILE))
buffer.read(DirectByteBuffer.SS_FILE,fc);
}
}catch ( Exception e ){
Debug.printStackTrace( e );
throw( new FMFileManagerException( "read fails", e ));
}
}