FileChannel.java revision 46805d66f32e857c885434b4fa8cb6b32dcc4bf7
1/*
2 * Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * This code is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License version 2 only, as
7 * published by the Free Software Foundation.  Oracle designates this
8 * particular file as subject to the "Classpath" exception as provided
9 * by Oracle in the LICENSE file that accompanied this code.
10 *
11 * This code is distributed in the hope that it will be useful, but WITHOUT
12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
14 * version 2 for more details (a copy is included in the LICENSE file that
15 * accompanied this code).
16 *
17 * You should have received a copy of the GNU General Public License version
18 * 2 along with this work; if not, write to the Free Software Foundation,
19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
20 *
21 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
22 * or visit www.oracle.com if you need additional information or have any
23 * questions.
24 */
25
26package java.nio.channels;
27
28import java.io.*;
29import java.nio.ByteBuffer;
30import java.nio.MappedByteBuffer;
31import java.nio.channels.spi.AbstractInterruptibleChannel;
32import java.nio.file.*;
33import java.nio.file.attribute.FileAttribute;
34import java.nio.file.spi.*;
35import java.util.Set;
36import java.util.HashSet;
37import java.util.Collections;
38
39/**
40 * A channel for reading, writing, mapping, and manipulating a file.
41 *
42 * <p> A file channel is a {@link SeekableByteChannel} that is connected to
43 * a file. It has a current <i>position</i> within its file which can
44 * be both {@link #position() <i>queried</i>} and {@link #position(long)
45 * <i>modified</i>}.  The file itself contains a variable-length sequence
46 * of bytes that can be read and written and whose current {@link #size
47 * <i>size</i>} can be queried.  The size of the file increases
48 * when bytes are written beyond its current size; the size of the file
49 * decreases when it is {@link #truncate <i>truncated</i>}.  The
50 * file may also have some associated <i>metadata</i> such as access
51 * permissions, content type, and last-modification time; this class does not
52 * define methods for metadata access.
53 *
54 * <p> In addition to the familiar read, write, and close operations of byte
55 * channels, this class defines the following file-specific operations: </p>
56 *
57 * <ul>
58 *
59 *   <li><p> Bytes may be {@link #read(ByteBuffer, long) read} or
60 *   {@link #write(ByteBuffer, long) <i>written</i>} at an absolute
61 *   position in a file in a way that does not affect the channel's current
62 *   position.  </p></li>
63 *
64 *   <li><p> A region of a file may be {@link #map <i>mapped</i>}
65 *   directly into memory; for large files this is often much more efficient
66 *   than invoking the usual <tt>read</tt> or <tt>write</tt> methods.
67 *   </p></li>
68 *
69 *   <li><p> Updates made to a file may be {@link #force <i>forced
70 *   out</i>} to the underlying storage device, ensuring that data are not
71 *   lost in the event of a system crash.  </p></li>
72 *
73 *   <li><p> Bytes can be transferred from a file {@link #transferTo <i>to
74 *   some other channel</i>}, and {@link #transferFrom <i>vice
75 *   versa</i>}, in a way that can be optimized by many operating systems
76 *   into a very fast transfer directly to or from the filesystem cache.
77 *   </p></li>
78 *
79 *   <li><p> A region of a file may be {@link FileLock <i>locked</i>}
80 *   against access by other programs.  </p></li>
81 *
82 * </ul>
83 *
84 * <p> File channels are safe for use by multiple concurrent threads.  The
85 * {@link Channel#close close} method may be invoked at any time, as specified
86 * by the {@link Channel} interface.  Only one operation that involves the
87 * channel's position or can change its file's size may be in progress at any
88 * given time; attempts to initiate a second such operation while the first is
89 * still in progress will block until the first operation completes.  Other
90 * operations, in particular those that take an explicit position, may proceed
91 * concurrently; whether they in fact do so is dependent upon the underlying
92 * implementation and is therefore unspecified.
93 *
94 * <p> The view of a file provided by an instance of this class is guaranteed
95 * to be consistent with other views of the same file provided by other
96 * instances in the same program.  The view provided by an instance of this
97 * class may or may not, however, be consistent with the views seen by other
98 * concurrently-running programs due to caching performed by the underlying
99 * operating system and delays induced by network-filesystem protocols.  This
100 * is true regardless of the language in which these other programs are
101 * written, and whether they are running on the same machine or on some other
102 * machine.  The exact nature of any such inconsistencies are system-dependent
103 * and are therefore unspecified.
104 *
105 * <p> A file channel is created by invoking one of the {@link #open open}
106 * methods defined by this class. A file channel can also be obtained from an
107 * existing {@link java.io.FileInputStream#getChannel FileInputStream}, {@link
108 * java.io.FileOutputStream#getChannel FileOutputStream}, or {@link
109 * java.io.RandomAccessFile#getChannel RandomAccessFile} object by invoking
110 * that object's <tt>getChannel</tt> method, which returns a file channel that
111 * is connected to the same underlying file. Where the file channel is obtained
112 * from an existing stream or random access file then the state of the file
113 * channel is intimately connected to that of the object whose <tt>getChannel</tt>
114 * method returned the channel.  Changing the channel's position, whether
115 * explicitly or by reading or writing bytes, will change the file position of
116 * the originating object, and vice versa. Changing the file's length via the
117 * file channel will change the length seen via the originating object, and vice
118 * versa.  Changing the file's content by writing bytes will change the content
119 * seen by the originating object, and vice versa.
120 *
121 * <a name="open-mode"></a> <p> At various points this class specifies that an
122 * instance that is "open for reading," "open for writing," or "open for
123 * reading and writing" is required.  A channel obtained via the {@link
124 * java.io.FileInputStream#getChannel getChannel} method of a {@link
125 * java.io.FileInputStream} instance will be open for reading.  A channel
126 * obtained via the {@link java.io.FileOutputStream#getChannel getChannel}
127 * method of a {@link java.io.FileOutputStream} instance will be open for
128 * writing.  Finally, a channel obtained via the {@link
129 * java.io.RandomAccessFile#getChannel getChannel} method of a {@link
130 * java.io.RandomAccessFile} instance will be open for reading if the instance
131 * was created with mode <tt>"r"</tt> and will be open for reading and writing
132 * if the instance was created with mode <tt>"rw"</tt>.
133 *
134 * <a name="append-mode"></a><p> A file channel that is open for writing may be in
135 * <i>append mode</i>, for example if it was obtained from a file-output stream
136 * that was created by invoking the {@link
137 * java.io.FileOutputStream#FileOutputStream(java.io.File,boolean)
138 * FileOutputStream(File,boolean)} constructor and passing <tt>true</tt> for
139 * the second parameter.  In this mode each invocation of a relative write
140 * operation first advances the position to the end of the file and then writes
141 * the requested data.  Whether the advancement of the position and the writing
142 * of the data are done in a single atomic operation is system-dependent and
143 * therefore unspecified.
144 *
145 * @see java.io.FileInputStream#getChannel()
146 * @see java.io.FileOutputStream#getChannel()
147 * @see java.io.RandomAccessFile#getChannel()
148 *
149 * @author Mark Reinhold
150 * @author Mike McCloskey
151 * @author JSR-51 Expert Group
152 * @since 1.4
153 */
154
155public abstract class FileChannel
156    extends AbstractInterruptibleChannel
157    implements SeekableByteChannel, GatheringByteChannel, ScatteringByteChannel
158{
159    /**
160     * Initializes a new instance of this class.
161     */
162    protected FileChannel() { }
163
164    /**
165     * Opens or creates a file, returning a file channel to access the file.
166     *
167     * <p> The {@code options} parameter determines how the file is opened.
168     * The {@link StandardOpenOption#READ READ} and {@link StandardOpenOption#WRITE
169     * WRITE} options determine if the file should be opened for reading and/or
170     * writing. If neither option (or the {@link StandardOpenOption#APPEND APPEND}
171     * option) is contained in the array then the file is opened for reading.
172     * By default reading or writing commences at the beginning of the file.
173     *
174     * <p> In the addition to {@code READ} and {@code WRITE}, the following
175     * options may be present:
176     *
177     * <table border=1 cellpadding=5 summary="">
178     * <tr> <th>Option</th> <th>Description</th> </tr>
179     * <tr>
180     *   <td> {@link StandardOpenOption#APPEND APPEND} </td>
181     *   <td> If this option is present then the file is opened for writing and
182     *     each invocation of the channel's {@code write} method first advances
183     *     the position to the end of the file and then writes the requested
184     *     data. Whether the advancement of the position and the writing of the
185     *     data are done in a single atomic operation is system-dependent and
186     *     therefore unspecified. This option may not be used in conjunction
187     *     with the {@code READ} or {@code TRUNCATE_EXISTING} options. </td>
188     * </tr>
189     * <tr>
190     *   <td> {@link StandardOpenOption#TRUNCATE_EXISTING TRUNCATE_EXISTING} </td>
191     *   <td> If this option is present then the existing file is truncated to
192     *   a size of 0 bytes. This option is ignored when the file is opened only
193     *   for reading. </td>
194     * </tr>
195     * <tr>
196     *   <td> {@link StandardOpenOption#CREATE_NEW CREATE_NEW} </td>
197     *   <td> If this option is present then a new file is created, failing if
198     *   the file already exists. When creating a file the check for the
199     *   existence of the file and the creation of the file if it does not exist
200     *   is atomic with respect to other file system operations. This option is
201     *   ignored when the file is opened only for reading. </td>
202     * </tr>
203     * <tr>
204     *   <td > {@link StandardOpenOption#CREATE CREATE} </td>
205     *   <td> If this option is present then an existing file is opened if it
206     *   exists, otherwise a new file is created. When creating a file the check
207     *   for the existence of the file and the creation of the file if it does
208     *   not exist is atomic with respect to other file system operations. This
209     *   option is ignored if the {@code CREATE_NEW} option is also present or
210     *   the file is opened only for reading. </td>
211     * </tr>
212     * <tr>
213     *   <td > {@link StandardOpenOption#DELETE_ON_CLOSE DELETE_ON_CLOSE} </td>
214     *   <td> When this option is present then the implementation makes a
215     *   <em>best effort</em> attempt to delete the file when closed by the
216     *   the {@link #close close} method. If the {@code close} method is not
217     *   invoked then a <em>best effort</em> attempt is made to delete the file
218     *   when the Java virtual machine terminates. </td>
219     * </tr>
220     * <tr>
221     *   <td>{@link StandardOpenOption#SPARSE SPARSE} </td>
222     *   <td> When creating a new file this option is a <em>hint</em> that the
223     *   new file will be sparse. This option is ignored when not creating
224     *   a new file. </td>
225     * </tr>
226     * <tr>
227     *   <td> {@link StandardOpenOption#SYNC SYNC} </td>
228     *   <td> Requires that every update to the file's content or metadata be
229     *   written synchronously to the underlying storage device. (see <a
230     *   href="../file/package-summary.html#integrity"> Synchronized I/O file
231     *   integrity</a>). </td>
232     * </tr>
233     * <tr>
234     *   <td> {@link StandardOpenOption#DSYNC DSYNC} </td>
235     *   <td> Requires that every update to the file's content be written
236     *   synchronously to the underlying storage device. (see <a
237     *   href="../file/package-summary.html#integrity"> Synchronized I/O file
238     *   integrity</a>). </td>
239     * </tr>
240     * </table>
241     *
242     * <p> An implementation may also support additional options.
243     *
244     * <p> The {@code attrs} parameter is an optional array of file {@link
245     * FileAttribute file-attributes} to set atomically when creating the file.
246     *
247     * <p> The new channel is created by invoking the {@link
248     * FileSystemProvider#newFileChannel newFileChannel} method on the
249     * provider that created the {@code Path}.
250     *
251     * @param   path
252     *          The path of the file to open or create
253     * @param   options
254     *          Options specifying how the file is opened
255     * @param   attrs
256     *          An optional list of file attributes to set atomically when
257     *          creating the file
258     *
259     * @return  A new file channel
260     *
261     * @throws  IllegalArgumentException
262     *          If the set contains an invalid combination of options
263     * @throws  UnsupportedOperationException
264     *          If the {@code path} is associated with a provider that does not
265     *          support creating file channels, or an unsupported open option is
266     *          specified, or the array contains an attribute that cannot be set
267     *          atomically when creating the file
268     * @throws  IOException
269     *          If an I/O error occurs
270     * @throws  SecurityException
271     *          If a security manager is installed and it denies an
272     *          unspecified permission required by the implementation.
273     *          In the case of the default provider, the {@link
274     *          SecurityManager#checkRead(String)} method is invoked to check
275     *          read access if the file is opened for reading. The {@link
276     *          SecurityManager#checkWrite(String)} method is invoked to check
277     *          write access if the file is opened for writing
278     *
279     * @since   1.7
280     */
281    public static FileChannel open(Path path,
282                                   Set<? extends OpenOption> options,
283                                   FileAttribute<?>... attrs)
284        throws IOException
285    {
286        FileSystemProvider provider = path.getFileSystem().provider();
287        return provider.newFileChannel(path, options, attrs);
288    }
289
290    @SuppressWarnings({"unchecked", "rawtypes"}) // generic array construction
291    private static final FileAttribute<?>[] NO_ATTRIBUTES = new FileAttribute[0];
292
293    /**
294     * Opens or creates a file, returning a file channel to access the file.
295     *
296     * <p> An invocation of this method behaves in exactly the same way as the
297     * invocation
298     * <pre>
299     *     fc.{@link #open(Path,Set,FileAttribute[]) open}(file, opts, new FileAttribute&lt;?&gt;[0]);
300     * </pre>
301     * where {@code opts} is a set of the options specified in the {@code
302     * options} array.
303     *
304     * @param   path
305     *          The path of the file to open or create
306     * @param   options
307     *          Options specifying how the file is opened
308     *
309     * @return  A new file channel
310     *
311     * @throws  IllegalArgumentException
312     *          If the set contains an invalid combination of options
313     * @throws  UnsupportedOperationException
314     *          If the {@code path} is associated with a provider that does not
315     *          support creating file channels, or an unsupported open option is
316     *          specified
317     * @throws  IOException
318     *          If an I/O error occurs
319     * @throws  SecurityException
320     *          If a security manager is installed and it denies an
321     *          unspecified permission required by the implementation.
322     *          In the case of the default provider, the {@link
323     *          SecurityManager#checkRead(String)} method is invoked to check
324     *          read access if the file is opened for reading. The {@link
325     *          SecurityManager#checkWrite(String)} method is invoked to check
326     *          write access if the file is opened for writing
327     *
328     * @since   1.7
329     */
330    public static FileChannel open(Path path, OpenOption... options)
331        throws IOException
332    {
333        Set<OpenOption> set = new HashSet<OpenOption>(options.length);
334        Collections.addAll(set, options);
335        return open(path, set, NO_ATTRIBUTES);
336    }
337
338    // -- Channel operations --
339
340    /**
341     * Reads a sequence of bytes from this channel into the given buffer.
342     *
343     * <p> Bytes are read starting at this channel's current file position, and
344     * then the file position is updated with the number of bytes actually
345     * read.  Otherwise this method behaves exactly as specified in the {@link
346     * ReadableByteChannel} interface. </p>
347     */
348    public abstract int read(ByteBuffer dst) throws IOException;
349
350    /**
351     * Reads a sequence of bytes from this channel into a subsequence of the
352     * given buffers.
353     *
354     * <p> Bytes are read starting at this channel's current file position, and
355     * then the file position is updated with the number of bytes actually
356     * read.  Otherwise this method behaves exactly as specified in the {@link
357     * ScatteringByteChannel} interface.  </p>
358     */
359    public abstract long read(ByteBuffer[] dsts, int offset, int length)
360        throws IOException;
361
362    /**
363     * Reads a sequence of bytes from this channel into the given buffers.
364     *
365     * <p> Bytes are read starting at this channel's current file position, and
366     * then the file position is updated with the number of bytes actually
367     * read.  Otherwise this method behaves exactly as specified in the {@link
368     * ScatteringByteChannel} interface.  </p>
369     */
370    public final long read(ByteBuffer[] dsts) throws IOException {
371        return read(dsts, 0, dsts.length);
372    }
373
374    /**
375     * Writes a sequence of bytes to this channel from the given buffer.
376     *
377     * <p> Bytes are written starting at this channel's current file position
378     * unless the channel is in append mode, in which case the position is
379     * first advanced to the end of the file.  The file is grown, if necessary,
380     * to accommodate the written bytes, and then the file position is updated
381     * with the number of bytes actually written.  Otherwise this method
382     * behaves exactly as specified by the {@link WritableByteChannel}
383     * interface. </p>
384     */
385    public abstract int write(ByteBuffer src) throws IOException;
386
387    /**
388     * Writes a sequence of bytes to this channel from a subsequence of the
389     * given buffers.
390     *
391     * <p> Bytes are written starting at this channel's current file position
392     * unless the channel is in append mode, in which case the position is
393     * first advanced to the end of the file.  The file is grown, if necessary,
394     * to accommodate the written bytes, and then the file position is updated
395     * with the number of bytes actually written.  Otherwise this method
396     * behaves exactly as specified in the {@link GatheringByteChannel}
397     * interface.  </p>
398     */
399    public abstract long write(ByteBuffer[] srcs, int offset, int length)
400        throws IOException;
401
402    /**
403     * Writes a sequence of bytes to this channel from the given buffers.
404     *
405     * <p> Bytes are written starting at this channel's current file position
406     * unless the channel is in append mode, in which case the position is
407     * first advanced to the end of the file.  The file is grown, if necessary,
408     * to accommodate the written bytes, and then the file position is updated
409     * with the number of bytes actually written.  Otherwise this method
410     * behaves exactly as specified in the {@link GatheringByteChannel}
411     * interface.  </p>
412     */
413    public final long write(ByteBuffer[] srcs) throws IOException {
414        return write(srcs, 0, srcs.length);
415    }
416
417
418    // -- Other operations --
419
420    /**
421     * Returns this channel's file position.
422     *
423     * @return  This channel's file position,
424     *          a non-negative integer counting the number of bytes
425     *          from the beginning of the file to the current position
426     *
427     * @throws  ClosedChannelException
428     *          If this channel is closed
429     *
430     * @throws  IOException
431     *          If some other I/O error occurs
432     */
433    public abstract long position() throws IOException;
434
435    /**
436     * Sets this channel's file position.
437     *
438     * <p> Setting the position to a value that is greater than the file's
439     * current size is legal but does not change the size of the file.  A later
440     * attempt to read bytes at such a position will immediately return an
441     * end-of-file indication.  A later attempt to write bytes at such a
442     * position will cause the file to be grown to accommodate the new bytes;
443     * the values of any bytes between the previous end-of-file and the
444     * newly-written bytes are unspecified.  </p>
445     *
446     * @param  newPosition
447     *         The new position, a non-negative integer counting
448     *         the number of bytes from the beginning of the file
449     *
450     * @return  This file channel
451     *
452     * @throws  ClosedChannelException
453     *          If this channel is closed
454     *
455     * @throws  IllegalArgumentException
456     *          If the new position is negative
457     *
458     * @throws  IOException
459     *          If some other I/O error occurs
460     */
461    public abstract FileChannel position(long newPosition) throws IOException;
462
463    /**
464     * Returns the current size of this channel's file.
465     *
466     * @return  The current size of this channel's file,
467     *          measured in bytes
468     *
469     * @throws  ClosedChannelException
470     *          If this channel is closed
471     *
472     * @throws  IOException
473     *          If some other I/O error occurs
474     */
475    public abstract long size() throws IOException;
476
477    /**
478     * Truncates this channel's file to the given size.
479     *
480     * <p> If the given size is less than the file's current size then the file
481     * is truncated, discarding any bytes beyond the new end of the file.  If
482     * the given size is greater than or equal to the file's current size then
483     * the file is not modified.  In either case, if this channel's file
484     * position is greater than the given size then it is set to that size.
485     * </p>
486     *
487     * @param  size
488     *         The new size, a non-negative byte count
489     *
490     * @return  This file channel
491     *
492     * @throws  NonWritableChannelException
493     *          If this channel was not opened for writing
494     *
495     * @throws  ClosedChannelException
496     *          If this channel is closed
497     *
498     * @throws  IllegalArgumentException
499     *          If the new size is negative
500     *
501     * @throws  IOException
502     *          If some other I/O error occurs
503     */
504    public abstract FileChannel truncate(long size) throws IOException;
505
506    /**
507     * Forces any updates to this channel's file to be written to the storage
508     * device that contains it.
509     *
510     * <p> If this channel's file resides on a local storage device then when
511     * this method returns it is guaranteed that all changes made to the file
512     * since this channel was created, or since this method was last invoked,
513     * will have been written to that device.  This is useful for ensuring that
514     * critical information is not lost in the event of a system crash.
515     *
516     * <p> If the file does not reside on a local device then no such guarantee
517     * is made.
518     *
519     * <p> The <tt>metaData</tt> parameter can be used to limit the number of
520     * I/O operations that this method is required to perform.  Passing
521     * <tt>false</tt> for this parameter indicates that only updates to the
522     * file's content need be written to storage; passing <tt>true</tt>
523     * indicates that updates to both the file's content and metadata must be
524     * written, which generally requires at least one more I/O operation.
525     * Whether this parameter actually has any effect is dependent upon the
526     * underlying operating system and is therefore unspecified.
527     *
528     * <p> Invoking this method may cause an I/O operation to occur even if the
529     * channel was only opened for reading.  Some operating systems, for
530     * example, maintain a last-access time as part of a file's metadata, and
531     * this time is updated whenever the file is read.  Whether or not this is
532     * actually done is system-dependent and is therefore unspecified.
533     *
534     * <p> This method is only guaranteed to force changes that were made to
535     * this channel's file via the methods defined in this class.  It may or
536     * may not force changes that were made by modifying the content of a
537     * {@link MappedByteBuffer <i>mapped byte buffer</i>} obtained by
538     * invoking the {@link #map map} method.  Invoking the {@link
539     * MappedByteBuffer#force force} method of the mapped byte buffer will
540     * force changes made to the buffer's content to be written.  </p>
541     *
542     * @param   metaData
543     *          If <tt>true</tt> then this method is required to force changes
544     *          to both the file's content and metadata to be written to
545     *          storage; otherwise, it need only force content changes to be
546     *          written
547     *
548     * @throws  ClosedChannelException
549     *          If this channel is closed
550     *
551     * @throws  IOException
552     *          If some other I/O error occurs
553     */
554    public abstract void force(boolean metaData) throws IOException;
555
556    /**
557     * Transfers bytes from this channel's file to the given writable byte
558     * channel.
559     *
560     * <p> An attempt is made to read up to <tt>count</tt> bytes starting at
561     * the given <tt>position</tt> in this channel's file and write them to the
562     * target channel.  An invocation of this method may or may not transfer
563     * all of the requested bytes; whether or not it does so depends upon the
564     * natures and states of the channels.  Fewer than the requested number of
565     * bytes are transferred if this channel's file contains fewer than
566     * <tt>count</tt> bytes starting at the given <tt>position</tt>, or if the
567     * target channel is non-blocking and it has fewer than <tt>count</tt>
568     * bytes free in its output buffer.
569     *
570     * <p> This method does not modify this channel's position.  If the given
571     * position is greater than the file's current size then no bytes are
572     * transferred.  If the target channel has a position then bytes are
573     * written starting at that position and then the position is incremented
574     * by the number of bytes written.
575     *
576     * <p> This method is potentially much more efficient than a simple loop
577     * that reads from this channel and writes to the target channel.  Many
578     * operating systems can transfer bytes directly from the filesystem cache
579     * to the target channel without actually copying them.  </p>
580     *
581     * @param  position
582     *         The position within the file at which the transfer is to begin;
583     *         must be non-negative
584     *
585     * @param  count
586     *         The maximum number of bytes to be transferred; must be
587     *         non-negative
588     *
589     * @param  target
590     *         The target channel
591     *
592     * @return  The number of bytes, possibly zero,
593     *          that were actually transferred
594     *
595     * @throws IllegalArgumentException
596     *         If the preconditions on the parameters do not hold
597     *
598     * @throws  NonReadableChannelException
599     *          If this channel was not opened for reading
600     *
601     * @throws  NonWritableChannelException
602     *          If the target channel was not opened for writing
603     *
604     * @throws  ClosedChannelException
605     *          If either this channel or the target channel is closed
606     *
607     * @throws  AsynchronousCloseException
608     *          If another thread closes either channel
609     *          while the transfer is in progress
610     *
611     * @throws  ClosedByInterruptException
612     *          If another thread interrupts the current thread while the
613     *          transfer is in progress, thereby closing both channels and
614     *          setting the current thread's interrupt status
615     *
616     * @throws  IOException
617     *          If some other I/O error occurs
618     */
619    public abstract long transferTo(long position, long count,
620                                    WritableByteChannel target)
621        throws IOException;
622
623    /**
624     * Transfers bytes into this channel's file from the given readable byte
625     * channel.
626     *
627     * <p> An attempt is made to read up to <tt>count</tt> bytes from the
628     * source channel and write them to this channel's file starting at the
629     * given <tt>position</tt>.  An invocation of this method may or may not
630     * transfer all of the requested bytes; whether or not it does so depends
631     * upon the natures and states of the channels.  Fewer than the requested
632     * number of bytes will be transferred if the source channel has fewer than
633     * <tt>count</tt> bytes remaining, or if the source channel is non-blocking
634     * and has fewer than <tt>count</tt> bytes immediately available in its
635     * input buffer.
636     *
637     * <p> This method does not modify this channel's position.  If the given
638     * position is greater than the file's current size then no bytes are
639     * transferred.  If the source channel has a position then bytes are read
640     * starting at that position and then the position is incremented by the
641     * number of bytes read.
642     *
643     * <p> This method is potentially much more efficient than a simple loop
644     * that reads from the source channel and writes to this channel.  Many
645     * operating systems can transfer bytes directly from the source channel
646     * into the filesystem cache without actually copying them.  </p>
647     *
648     * @param  src
649     *         The source channel
650     *
651     * @param  position
652     *         The position within the file at which the transfer is to begin;
653     *         must be non-negative
654     *
655     * @param  count
656     *         The maximum number of bytes to be transferred; must be
657     *         non-negative
658     *
659     * @return  The number of bytes, possibly zero,
660     *          that were actually transferred
661     *
662     * @throws IllegalArgumentException
663     *         If the preconditions on the parameters do not hold
664     *
665     * @throws  NonReadableChannelException
666     *          If the source channel was not opened for reading
667     *
668     * @throws  NonWritableChannelException
669     *          If this channel was not opened for writing
670     *
671     * @throws  ClosedChannelException
672     *          If either this channel or the source channel is closed
673     *
674     * @throws  AsynchronousCloseException
675     *          If another thread closes either channel
676     *          while the transfer is in progress
677     *
678     * @throws  ClosedByInterruptException
679     *          If another thread interrupts the current thread while the
680     *          transfer is in progress, thereby closing both channels and
681     *          setting the current thread's interrupt status
682     *
683     * @throws  IOException
684     *          If some other I/O error occurs
685     */
686    public abstract long transferFrom(ReadableByteChannel src,
687                                      long position, long count)
688        throws IOException;
689
690    /**
691     * Reads a sequence of bytes from this channel into the given buffer,
692     * starting at the given file position.
693     *
694     * <p> This method works in the same manner as the {@link
695     * #read(ByteBuffer)} method, except that bytes are read starting at the
696     * given file position rather than at the channel's current position.  This
697     * method does not modify this channel's position.  If the given position
698     * is greater than the file's current size then no bytes are read.  </p>
699     *
700     * @param  dst
701     *         The buffer into which bytes are to be transferred
702     *
703     * @param  position
704     *         The file position at which the transfer is to begin;
705     *         must be non-negative
706     *
707     * @return  The number of bytes read, possibly zero, or <tt>-1</tt> if the
708     *          given position is greater than or equal to the file's current
709     *          size
710     *
711     * @throws  IllegalArgumentException
712     *          If the position is negative
713     *
714     * @throws  NonReadableChannelException
715     *          If this channel was not opened for reading
716     *
717     * @throws  ClosedChannelException
718     *          If this channel is closed
719     *
720     * @throws  AsynchronousCloseException
721     *          If another thread closes this channel
722     *          while the read operation is in progress
723     *
724     * @throws  ClosedByInterruptException
725     *          If another thread interrupts the current thread
726     *          while the read operation is in progress, thereby
727     *          closing the channel and setting the current thread's
728     *          interrupt status
729     *
730     * @throws  IOException
731     *          If some other I/O error occurs
732     */
733    public abstract int read(ByteBuffer dst, long position) throws IOException;
734
735    /**
736     * Writes a sequence of bytes to this channel from the given buffer,
737     * starting at the given file position.
738     *
739     * <p> This method works in the same manner as the {@link
740     * #write(ByteBuffer)} method, except that bytes are written starting at
741     * the given file position rather than at the channel's current position.
742     * This method does not modify this channel's position.  If the given
743     * position is greater than the file's current size then the file will be
744     * grown to accommodate the new bytes; the values of any bytes between the
745     * previous end-of-file and the newly-written bytes are unspecified.  </p>
746     *
747     * @param  src
748     *         The buffer from which bytes are to be transferred
749     *
750     * @param  position
751     *         The file position at which the transfer is to begin;
752     *         must be non-negative
753     *
754     * @return  The number of bytes written, possibly zero
755     *
756     * @throws  IllegalArgumentException
757     *          If the position is negative
758     *
759     * @throws  NonWritableChannelException
760     *          If this channel was not opened for writing
761     *
762     * @throws  ClosedChannelException
763     *          If this channel is closed
764     *
765     * @throws  AsynchronousCloseException
766     *          If another thread closes this channel
767     *          while the write operation is in progress
768     *
769     * @throws  ClosedByInterruptException
770     *          If another thread interrupts the current thread
771     *          while the write operation is in progress, thereby
772     *          closing the channel and setting the current thread's
773     *          interrupt status
774     *
775     * @throws  IOException
776     *          If some other I/O error occurs
777     */
778    public abstract int write(ByteBuffer src, long position) throws IOException;
779
780
781    // -- Memory-mapped buffers --
782
783    /**
784     * A typesafe enumeration for file-mapping modes.
785     *
786     * @since 1.4
787     *
788     * @see java.nio.channels.FileChannel#map
789     */
790    public static class MapMode {
791
792        /**
793         * Mode for a read-only mapping.
794         */
795        public static final MapMode READ_ONLY
796            = new MapMode("READ_ONLY");
797
798        /**
799         * Mode for a read/write mapping.
800         */
801        public static final MapMode READ_WRITE
802            = new MapMode("READ_WRITE");
803
804        /**
805         * Mode for a private (copy-on-write) mapping.
806         */
807        public static final MapMode PRIVATE
808            = new MapMode("PRIVATE");
809
810        private final String name;
811
812        private MapMode(String name) {
813            this.name = name;
814        }
815
816        /**
817         * Returns a string describing this file-mapping mode.
818         *
819         * @return  A descriptive string
820         */
821        public String toString() {
822            return name;
823        }
824
825    }
826
827    /**
828     * Maps a region of this channel's file directly into memory.
829     *
830     * <p> A region of a file may be mapped into memory in one of three modes:
831     * </p>
832     *
833     * <ul>
834     *
835     *   <li><p> <i>Read-only:</i> Any attempt to modify the resulting buffer
836     *   will cause a {@link java.nio.ReadOnlyBufferException} to be thrown.
837     *   ({@link MapMode#READ_ONLY MapMode.READ_ONLY}) </p></li>
838     *
839     *   <li><p> <i>Read/write:</i> Changes made to the resulting buffer will
840     *   eventually be propagated to the file; they may or may not be made
841     *   visible to other programs that have mapped the same file.  ({@link
842     *   MapMode#READ_WRITE MapMode.READ_WRITE}) </p></li>
843     *
844     *   <li><p> <i>Private:</i> Changes made to the resulting buffer will not
845     *   be propagated to the file and will not be visible to other programs
846     *   that have mapped the same file; instead, they will cause private
847     *   copies of the modified portions of the buffer to be created.  ({@link
848     *   MapMode#PRIVATE MapMode.PRIVATE}) </p></li>
849     *
850     * </ul>
851     *
852     * <p> For a read-only mapping, this channel must have been opened for
853     * reading; for a read/write or private mapping, this channel must have
854     * been opened for both reading and writing.
855     *
856     * <p> The {@link MappedByteBuffer <i>mapped byte buffer</i>}
857     * returned by this method will have a position of zero and a limit and
858     * capacity of <tt>size</tt>; its mark will be undefined.  The buffer and
859     * the mapping that it represents will remain valid until the buffer itself
860     * is garbage-collected.
861     *
862     * <p> A mapping, once established, is not dependent upon the file channel
863     * that was used to create it.  Closing the channel, in particular, has no
864     * effect upon the validity of the mapping.
865     *
866     * <p> Many of the details of memory-mapped files are inherently dependent
867     * upon the underlying operating system and are therefore unspecified.  The
868     * behavior of this method when the requested region is not completely
869     * contained within this channel's file is unspecified.  Whether changes
870     * made to the content or size of the underlying file, by this program or
871     * another, are propagated to the buffer is unspecified.  The rate at which
872     * changes to the buffer are propagated to the file is unspecified.
873     *
874     * <p> For most operating systems, mapping a file into memory is more
875     * expensive than reading or writing a few tens of kilobytes of data via
876     * the usual {@link #read read} and {@link #write write} methods.  From the
877     * standpoint of performance it is generally only worth mapping relatively
878     * large files into memory.  </p>
879     *
880     * @param  mode
881     *         One of the constants {@link MapMode#READ_ONLY READ_ONLY}, {@link
882     *         MapMode#READ_WRITE READ_WRITE}, or {@link MapMode#PRIVATE
883     *         PRIVATE} defined in the {@link MapMode} class, according to
884     *         whether the file is to be mapped read-only, read/write, or
885     *         privately (copy-on-write), respectively
886     *
887     * @param  position
888     *         The position within the file at which the mapped region
889     *         is to start; must be non-negative
890     *
891     * @param  size
892     *         The size of the region to be mapped; must be non-negative and
893     *         no greater than {@link java.lang.Integer#MAX_VALUE}
894     *
895     * @return  The mapped byte buffer
896     *
897     * @throws NonReadableChannelException
898     *         If the <tt>mode</tt> is {@link MapMode#READ_ONLY READ_ONLY} but
899     *         this channel was not opened for reading
900     *
901     * @throws NonWritableChannelException
902     *         If the <tt>mode</tt> is {@link MapMode#READ_WRITE READ_WRITE} or
903     *         {@link MapMode#PRIVATE PRIVATE} but this channel was not opened
904     *         for both reading and writing
905     *
906     * @throws IllegalArgumentException
907     *         If the preconditions on the parameters do not hold
908     *
909     * @throws IOException
910     *         If some other I/O error occurs
911     *
912     * @see java.nio.channels.FileChannel.MapMode
913     * @see java.nio.MappedByteBuffer
914     */
915    public abstract MappedByteBuffer map(MapMode mode,
916                                         long position, long size)
917        throws IOException;
918
919
920    // -- Locks --
921
922    /**
923     * Acquires a lock on the given region of this channel's file.
924     *
925     * <p> An invocation of this method will block until the region can be
926     * locked, this channel is closed, or the invoking thread is interrupted,
927     * whichever comes first.
928     *
929     * <p> If this channel is closed by another thread during an invocation of
930     * this method then an {@link AsynchronousCloseException} will be thrown.
931     *
932     * <p> If the invoking thread is interrupted while waiting to acquire the
933     * lock then its interrupt status will be set and a {@link
934     * FileLockInterruptionException} will be thrown.  If the invoker's
935     * interrupt status is set when this method is invoked then that exception
936     * will be thrown immediately; the thread's interrupt status will not be
937     * changed.
938     *
939     * <p> The region specified by the <tt>position</tt> and <tt>size</tt>
940     * parameters need not be contained within, or even overlap, the actual
941     * underlying file.  Lock regions are fixed in size; if a locked region
942     * initially contains the end of the file and the file grows beyond the
943     * region then the new portion of the file will not be covered by the lock.
944     * If a file is expected to grow in size and a lock on the entire file is
945     * required then a region starting at zero, and no smaller than the
946     * expected maximum size of the file, should be locked.  The zero-argument
947     * {@link #lock()} method simply locks a region of size {@link
948     * Long#MAX_VALUE}.
949     *
950     * <p> Some operating systems do not support shared locks, in which case a
951     * request for a shared lock is automatically converted into a request for
952     * an exclusive lock.  Whether the newly-acquired lock is shared or
953     * exclusive may be tested by invoking the resulting lock object's {@link
954     * FileLock#isShared() isShared} method.
955     *
956     * <p> File locks are held on behalf of the entire Java virtual machine.
957     * They are not suitable for controlling access to a file by multiple
958     * threads within the same virtual machine.  </p>
959     *
960     * @param  position
961     *         The position at which the locked region is to start; must be
962     *         non-negative
963     *
964     * @param  size
965     *         The size of the locked region; must be non-negative, and the sum
966     *         <tt>position</tt>&nbsp;+&nbsp;<tt>size</tt> must be non-negative
967     *
968     * @param  shared
969     *         <tt>true</tt> to request a shared lock, in which case this
970     *         channel must be open for reading (and possibly writing);
971     *         <tt>false</tt> to request an exclusive lock, in which case this
972     *         channel must be open for writing (and possibly reading)
973     *
974     * @return  A lock object representing the newly-acquired lock
975     *
976     * @throws  IllegalArgumentException
977     *          If the preconditions on the parameters do not hold
978     *
979     * @throws  ClosedChannelException
980     *          If this channel is closed
981     *
982     * @throws  AsynchronousCloseException
983     *          If another thread closes this channel while the invoking
984     *          thread is blocked in this method
985     *
986     * @throws  FileLockInterruptionException
987     *          If the invoking thread is interrupted while blocked in this
988     *          method
989     *
990     * @throws  OverlappingFileLockException
991     *          If a lock that overlaps the requested region is already held by
992     *          this Java virtual machine, or if another thread is already
993     *          blocked in this method and is attempting to lock an overlapping
994     *          region
995     *
996     * @throws  NonReadableChannelException
997     *          If <tt>shared</tt> is <tt>true</tt> this channel was not
998     *          opened for reading
999     *
1000     * @throws  NonWritableChannelException
1001     *          If <tt>shared</tt> is <tt>false</tt> but this channel was not
1002     *          opened for writing
1003     *
1004     * @throws  IOException
1005     *          If some other I/O error occurs
1006     *
1007     * @see     #lock()
1008     * @see     #tryLock()
1009     * @see     #tryLock(long,long,boolean)
1010     */
1011    public abstract FileLock lock(long position, long size, boolean shared)
1012        throws IOException;
1013
1014    /**
1015     * Acquires an exclusive lock on this channel's file.
1016     *
1017     * <p> An invocation of this method of the form <tt>fc.lock()</tt> behaves
1018     * in exactly the same way as the invocation
1019     *
1020     * <pre>
1021     *     fc.{@link #lock(long,long,boolean) lock}(0L, Long.MAX_VALUE, false) </pre>
1022     *
1023     * @return  A lock object representing the newly-acquired lock
1024     *
1025     * @throws  ClosedChannelException
1026     *          If this channel is closed
1027     *
1028     * @throws  AsynchronousCloseException
1029     *          If another thread closes this channel while the invoking
1030     *          thread is blocked in this method
1031     *
1032     * @throws  FileLockInterruptionException
1033     *          If the invoking thread is interrupted while blocked in this
1034     *          method
1035     *
1036     * @throws  OverlappingFileLockException
1037     *          If a lock that overlaps the requested region is already held by
1038     *          this Java virtual machine, or if another thread is already
1039     *          blocked in this method and is attempting to lock an overlapping
1040     *          region of the same file
1041     *
1042     * @throws  NonWritableChannelException
1043     *          If this channel was not opened for writing
1044     *
1045     * @throws  IOException
1046     *          If some other I/O error occurs
1047     *
1048     * @see     #lock(long,long,boolean)
1049     * @see     #tryLock()
1050     * @see     #tryLock(long,long,boolean)
1051     */
1052    public final FileLock lock() throws IOException {
1053        return lock(0L, Long.MAX_VALUE, false);
1054    }
1055
1056    /**
1057     * Attempts to acquire a lock on the given region of this channel's file.
1058     *
1059     * <p> This method does not block.  An invocation always returns
1060     * immediately, either having acquired a lock on the requested region or
1061     * having failed to do so.  If it fails to acquire a lock because an
1062     * overlapping lock is held by another program then it returns
1063     * <tt>null</tt>.  If it fails to acquire a lock for any other reason then
1064     * an appropriate exception is thrown.
1065     *
1066     * <p> The region specified by the <tt>position</tt> and <tt>size</tt>
1067     * parameters need not be contained within, or even overlap, the actual
1068     * underlying file.  Lock regions are fixed in size; if a locked region
1069     * initially contains the end of the file and the file grows beyond the
1070     * region then the new portion of the file will not be covered by the lock.
1071     * If a file is expected to grow in size and a lock on the entire file is
1072     * required then a region starting at zero, and no smaller than the
1073     * expected maximum size of the file, should be locked.  The zero-argument
1074     * {@link #tryLock()} method simply locks a region of size {@link
1075     * Long#MAX_VALUE}.
1076     *
1077     * <p> Some operating systems do not support shared locks, in which case a
1078     * request for a shared lock is automatically converted into a request for
1079     * an exclusive lock.  Whether the newly-acquired lock is shared or
1080     * exclusive may be tested by invoking the resulting lock object's {@link
1081     * FileLock#isShared() isShared} method.
1082     *
1083     * <p> File locks are held on behalf of the entire Java virtual machine.
1084     * They are not suitable for controlling access to a file by multiple
1085     * threads within the same virtual machine.  </p>
1086     *
1087     * @param  position
1088     *         The position at which the locked region is to start; must be
1089     *         non-negative
1090     *
1091     * @param  size
1092     *         The size of the locked region; must be non-negative, and the sum
1093     *         <tt>position</tt>&nbsp;+&nbsp;<tt>size</tt> must be non-negative
1094     *
1095     * @param  shared
1096     *         <tt>true</tt> to request a shared lock,
1097     *         <tt>false</tt> to request an exclusive lock
1098     *
1099     * @return  A lock object representing the newly-acquired lock,
1100     *          or <tt>null</tt> if the lock could not be acquired
1101     *          because another program holds an overlapping lock
1102     *
1103     * @throws  IllegalArgumentException
1104     *          If the preconditions on the parameters do not hold
1105     *
1106     * @throws  ClosedChannelException
1107     *          If this channel is closed
1108     *
1109     * @throws  OverlappingFileLockException
1110     *          If a lock that overlaps the requested region is already held by
1111     *          this Java virtual machine, or if another thread is already
1112     *          blocked in this method and is attempting to lock an overlapping
1113     *          region of the same file
1114     *
1115     * @throws  IOException
1116     *          If some other I/O error occurs
1117     *
1118     * @see     #lock()
1119     * @see     #lock(long,long,boolean)
1120     * @see     #tryLock()
1121     */
1122    public abstract FileLock tryLock(long position, long size, boolean shared)
1123        throws IOException;
1124
1125    /**
1126     * Attempts to acquire an exclusive lock on this channel's file.
1127     *
1128     * <p> An invocation of this method of the form <tt>fc.tryLock()</tt>
1129     * behaves in exactly the same way as the invocation
1130     *
1131     * <pre>
1132     *     fc.{@link #tryLock(long,long,boolean) tryLock}(0L, Long.MAX_VALUE, false) </pre>
1133     *
1134     * @return  A lock object representing the newly-acquired lock,
1135     *          or <tt>null</tt> if the lock could not be acquired
1136     *          because another program holds an overlapping lock
1137     *
1138     * @throws  ClosedChannelException
1139     *          If this channel is closed
1140     *
1141     * @throws  OverlappingFileLockException
1142     *          If a lock that overlaps the requested region is already held by
1143     *          this Java virtual machine, or if another thread is already
1144     *          blocked in this method and is attempting to lock an overlapping
1145     *          region
1146     *
1147     * @throws  IOException
1148     *          If some other I/O error occurs
1149     *
1150     * @see     #lock()
1151     * @see     #lock(long,long,boolean)
1152     * @see     #tryLock(long,long,boolean)
1153     */
1154    public final FileLock tryLock() throws IOException {
1155        return tryLock(0L, Long.MAX_VALUE, false);
1156    }
1157
1158}
1159