I'm trying to use NIO to assemble a file out of several smaller files, using transferFrom.
The call to transferFrom returns 0. No exception. Nothing done to turn on synchronous behavior.
FileOutputStream fos = new FileOutputStream(path);
FileChannel fileBeingAssembled = fos.channel();
int progressiveOffset = 4096;
FileInputStream fis = new FileInputStream(tmpT5);
FileChannel channel = fis.getChannel();
channel.position(0);
int thisItemLength = (int)channel.size();
LOG.info("Writing " + tag + " at " + progressiveOffset + " length " + thisItemLength);
fileBeingAssembled.position(progressiveOffset);
long x = fileBeingAssembled.transferFrom(channel, progressiveOffset, thisItemLength);
LOG.info("transferred " + x);
progressiveOffset += thisItemLength;
An example log:
4409 [main] INFO com.basistech.seg.writing.ModelOutputTask - available 1856216
4409 [main] INFO com.basistech.seg.writing.ModelOutputTask - Writing word at 15024620 length 1856216
4419 [main] INFO com.basistech.seg.writing.ModelOutputTask - transferred 0