Home | History | Annotate | Download | only in channels
      1 /*
      2  * Copyright (c) 2007, 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 
     26 package java.nio.channels;
     27 
     28 import java.nio.file.*;
     29 import java.nio.file.attribute.FileAttribute;
     30 import java.nio.file.spi.*;
     31 import java.nio.ByteBuffer;
     32 import java.io.IOException;
     33 import java.util.concurrent.Future;
     34 import java.util.concurrent.ExecutorService;
     35 import java.util.Set;
     36 import java.util.HashSet;
     37 import java.util.Collections;
     38 
     39 /**
     40  * An asynchronous channel for reading, writing, and manipulating a file.
     41  *
     42  * <p> An asynchronous file channel is created when a file is opened by invoking
     43  * one of the {@link #open open} methods defined by this class. The file contains
     44  * a variable-length sequence of bytes that can be read and written and whose
     45  * current size can be {@link #size() queried}. The size of the file increases
     46  * when bytes are written beyond its  current size; the size of the file decreases
     47  * when it is {@link #truncate truncated}.
     48  *
     49  * <p> An asynchronous file channel does not have a <i>current position</i>
     50  * within the file. Instead, the file position is specified to each read and
     51  * write method that initiates asynchronous operations. A {@link CompletionHandler}
     52  * is specified as a parameter and is invoked to consume the result of the I/O
     53  * operation. This class also defines read and write methods that initiate
     54  * asynchronous operations, returning a {@link Future} to represent the pending
     55  * result of the operation. The {@code Future} may be used to check if the
     56  * operation has completed, wait for its completion, and retrieve the result.
     57  *
     58  * <p> In addition to read and write operations, this class defines the
     59  * following operations: </p>
     60  *
     61  * <ul>
     62  *
     63  *   <li><p> Updates made to a file may be {@link #force <i>forced
     64  *   out</i>} to the underlying storage device, ensuring that data are not
     65  *   lost in the event of a system crash.  </p></li>
     66  *
     67  *   <li><p> A region of a file may be {@link #lock <i>locked</i>} against
     68  *   access by other programs.  </p></li>
     69  *
     70  * </ul>
     71  *
     72  * <p> An {@code AsynchronousFileChannel} is associated with a thread pool to
     73  * which tasks are submitted to handle I/O events and dispatch to completion
     74  * handlers that consume the results of I/O operations on the channel. The
     75  * completion handler for an I/O operation initiated on a channel is guaranteed
     76  * to be invoked by one of the threads in the thread pool (This ensures that the
     77  * completion handler is run by a thread with the expected <em>identity</em>).
     78  * Where an I/O operation completes immediately, and the initiating thread is
     79  * itself a thread in the thread pool, then the completion handler may be invoked
     80  * directly by the initiating thread. When an {@code AsynchronousFileChannel} is
     81  * created without specifying a thread pool then the channel is associated with
     82  * a system-dependent default thread pool that may be shared with other
     83  * channels. The default thread pool is configured by the system properties
     84  * defined by the {@link AsynchronousChannelGroup} class.
     85  *
     86  * <p> Channels of this type are safe for use by multiple concurrent threads. The
     87  * {@link Channel#close close} method may be invoked at any time, as specified
     88  * by the {@link Channel} interface. This causes all outstanding asynchronous
     89  * operations on the channel to complete with the exception {@link
     90  * AsynchronousCloseException}. Multiple read and write operations may be
     91  * outstanding at the same time. When multiple read and write operations are
     92  * outstanding then the ordering of the I/O operations, and the order that the
     93  * completion handlers are invoked, is not specified; they are not, in particular,
     94  * guaranteed to execute in the order that the operations were initiated. The
     95  * {@link java.nio.ByteBuffer ByteBuffers} used when reading or writing are not
     96  * safe for use by multiple concurrent I/O operations. Furthermore, after an I/O
     97  * operation is initiated then care should be taken to ensure that the buffer is
     98  * not accessed until after the operation has completed.
     99  *
    100  * <p> As with {@link FileChannel}, the view of a file provided by an instance of
    101  * this class is guaranteed to be consistent with other views of the same file
    102  * provided by other instances in the same program.  The view provided by an
    103  * instance of this class may or may not, however, be consistent with the views
    104  * seen by other concurrently-running programs due to caching performed by the
    105  * underlying operating system and delays induced by network-filesystem protocols.
    106  * This is true regardless of the language in which these other programs are
    107  * written, and whether they are running on the same machine or on some other
    108  * machine.  The exact nature of any such inconsistencies are system-dependent
    109  * and are therefore unspecified.
    110  *
    111  * @since 1.7
    112  */
    113 
    114 public abstract class AsynchronousFileChannel
    115     implements AsynchronousChannel
    116 {
    117     /**
    118      * Initializes a new instance of this class.
    119      */
    120     protected AsynchronousFileChannel() {
    121     }
    122 
    123     /**
    124      * Opens or creates a file for reading and/or writing, returning an
    125      * asynchronous file channel to access the file.
    126      *
    127      * <p> The {@code options} parameter determines how the file is opened.
    128      * The {@link StandardOpenOption#READ READ} and {@link StandardOpenOption#WRITE
    129      * WRITE} options determines if the file should be opened for reading and/or
    130      * writing. If neither option is contained in the array then an existing file
    131      * is opened for  reading.
    132      *
    133      * <p> In addition to {@code READ} and {@code WRITE}, the following options
    134      * may be present:
    135      *
    136      * <table border=1 cellpadding=5 summary="">
    137      * <tr> <th>Option</th> <th>Description</th> </tr>
    138      * <tr>
    139      *   <td> {@link StandardOpenOption#TRUNCATE_EXISTING TRUNCATE_EXISTING} </td>
    140      *   <td> When opening an existing file, the file is first truncated to a
    141      *   size of 0 bytes. This option is ignored when the file is opened only
    142      *   for reading.</td>
    143      * </tr>
    144      * <tr>
    145      *   <td> {@link StandardOpenOption#CREATE_NEW CREATE_NEW} </td>
    146      *   <td> If this option is present then a new file is created, failing if
    147      *   the file already exists. When creating a file the check for the
    148      *   existence of the file and the creation of the file if it does not exist
    149      *   is atomic with respect to other file system operations. This option is
    150      *   ignored when the file is opened only for reading. </td>
    151      * </tr>
    152      * <tr>
    153      *   <td > {@link StandardOpenOption#CREATE CREATE} </td>
    154      *   <td> If this option is present then an existing file is opened if it
    155      *   exists, otherwise a new file is created. When creating a file the check
    156      *   for the existence of the file and the creation of the file if it does
    157      *   not exist is atomic with respect to other file system operations. This
    158      *   option is ignored if the {@code CREATE_NEW} option is also present or
    159      *   the file is opened only for reading. </td>
    160      * </tr>
    161      * <tr>
    162      *   <td > {@link StandardOpenOption#DELETE_ON_CLOSE DELETE_ON_CLOSE} </td>
    163      *   <td> When this option is present then the implementation makes a
    164      *   <em>best effort</em> attempt to delete the file when closed by the
    165      *   the {@link #close close} method. If the {@code close} method is not
    166      *   invoked then a <em>best effort</em> attempt is made to delete the file
    167      *   when the Java virtual machine terminates. </td>
    168      * </tr>
    169      * <tr>
    170      *   <td>{@link StandardOpenOption#SPARSE SPARSE} </td>
    171      *   <td> When creating a new file this option is a <em>hint</em> that the
    172      *   new file will be sparse. This option is ignored when not creating
    173      *   a new file. </td>
    174      * </tr>
    175      * <tr>
    176      *   <td> {@link StandardOpenOption#SYNC SYNC} </td>
    177      *   <td> Requires that every update to the file's content or metadata be
    178      *   written synchronously to the underlying storage device. (see <a
    179      *   href="../file/package-summary.html#integrity"> Synchronized I/O file
    180      *   integrity</a>). </td>
    181      * </tr>
    182      * <tr>
    183      *   <td> {@link StandardOpenOption#DSYNC DSYNC} </td>
    184      *   <td> Requires that every update to the file's content be written
    185      *   synchronously to the underlying storage device. (see <a
    186      *   href="../file/package-summary.html#integrity"> Synchronized I/O file
    187      *   integrity</a>). </td>
    188      * </tr>
    189      * </table>
    190      *
    191      * <p> An implementation may also support additional options.
    192      *
    193      * <p> The {@code executor} parameter is the {@link ExecutorService} to
    194      * which tasks are submitted to handle I/O events and dispatch completion
    195      * results for operations initiated on resulting channel.
    196      * The nature of these tasks is highly implementation specific and so care
    197      * should be taken when configuring the {@code Executor}. Minimally it
    198      * should support an unbounded work queue and should not run tasks on the
    199      * caller thread of the {@link ExecutorService#execute execute} method.
    200      * Shutting down the executor service while the channel is open results in
    201      * unspecified behavior.
    202      *
    203      * <p> The {@code attrs} parameter is an optional array of file {@link
    204      * FileAttribute file-attributes} to set atomically when creating the file.
    205      *
    206      * <p> The new channel is created by invoking the {@link
    207      * FileSystemProvider#newFileChannel newFileChannel} method on the
    208      * provider that created the {@code Path}.
    209      *
    210      * @param   file
    211      *          The path of the file to open or create
    212      * @param   options
    213      *          Options specifying how the file is opened
    214      * @param   executor
    215      *          The thread pool or {@code null} to associate the channel with
    216      *          the default thread pool
    217      * @param   attrs
    218      *          An optional list of file attributes to set atomically when
    219      *          creating the file
    220      *
    221      * @return  A new asynchronous file channel
    222      *
    223      * @throws  IllegalArgumentException
    224      *          If the set contains an invalid combination of options
    225      * @throws  UnsupportedOperationException
    226      *          If the {@code file} is associated with a provider that does not
    227      *          support creating asynchronous file channels, or an unsupported
    228      *          open option is specified, or the array contains an attribute that
    229      *          cannot be set atomically when creating the file
    230      * @throws  IOException
    231      *          If an I/O error occurs
    232      * @throws  SecurityException
    233      *          If a security manager is installed and it denies an
    234      *          unspecified permission required by the implementation.
    235      *          In the case of the default provider, the {@link
    236      *          SecurityManager#checkRead(String)} method is invoked to check
    237      *          read access if the file is opened for reading. The {@link
    238      *          SecurityManager#checkWrite(String)} method is invoked to check
    239      *          write access if the file is opened for writing
    240      */
    241     public static AsynchronousFileChannel open(Path file,
    242                                                Set<? extends OpenOption> options,
    243                                                ExecutorService executor,
    244                                                FileAttribute<?>... attrs)
    245         throws IOException
    246     {
    247         FileSystemProvider provider = file.getFileSystem().provider();
    248         return provider.newAsynchronousFileChannel(file, options, executor, attrs);
    249     }
    250 
    251     @SuppressWarnings({"unchecked", "rawtypes"}) // generic array construction
    252     private static final FileAttribute<?>[] NO_ATTRIBUTES = new FileAttribute[0];
    253 
    254     /**
    255      * Opens or creates a file for reading and/or writing, returning an
    256      * asynchronous file channel to access the file.
    257      *
    258      * <p> An invocation of this method behaves in exactly the same way as the
    259      * invocation
    260      * <pre>
    261      *     ch.{@link #open(Path,Set,ExecutorService,FileAttribute[])
    262      *       open}(file, opts, null, new FileAttribute&lt;?&gt;[0]);
    263      * </pre>
    264      * where {@code opts} is a {@code Set} containing the options specified to
    265      * this method.
    266      *
    267      * <p> The resulting channel is associated with default thread pool to which
    268      * tasks are submitted to handle I/O events and dispatch to completion
    269      * handlers that consume the result of asynchronous operations performed on
    270      * the resulting channel.
    271      *
    272      * @param   file
    273      *          The path of the file to open or create
    274      * @param   options
    275      *          Options specifying how the file is opened
    276      *
    277      * @return  A new asynchronous file channel
    278      *
    279      * @throws  IllegalArgumentException
    280      *          If the set contains an invalid combination of options
    281      * @throws  UnsupportedOperationException
    282      *          If the {@code file} is associated with a provider that does not
    283      *          support creating file channels, or an unsupported open option is
    284      *          specified
    285      * @throws  IOException
    286      *          If an I/O error occurs
    287      * @throws  SecurityException
    288      *          If a security manager is installed and it denies an
    289      *          unspecified permission required by the implementation.
    290      *          In the case of the default provider, the {@link
    291      *          SecurityManager#checkRead(String)} method is invoked to check
    292      *          read access if the file is opened for reading. The {@link
    293      *          SecurityManager#checkWrite(String)} method is invoked to check
    294      *          write access if the file is opened for writing
    295      */
    296     public static AsynchronousFileChannel open(Path file, OpenOption... options)
    297         throws IOException
    298     {
    299         Set<OpenOption> set = new HashSet<OpenOption>(options.length);
    300         Collections.addAll(set, options);
    301         return open(file, set, null, NO_ATTRIBUTES);
    302     }
    303 
    304     /**
    305      * Returns the current size of this channel's file.
    306      *
    307      * @return  The current size of this channel's file, measured in bytes
    308      *
    309      * @throws  ClosedChannelException
    310      *          If this channel is closed
    311      * @throws  IOException
    312      *          If some other I/O error occurs
    313      */
    314     public abstract long size() throws IOException;
    315 
    316     /**
    317      * Truncates this channel's file to the given size.
    318      *
    319      * <p> If the given size is less than the file's current size then the file
    320      * is truncated, discarding any bytes beyond the new end of the file.  If
    321      * the given size is greater than or equal to the file's current size then
    322      * the file is not modified. </p>
    323      *
    324      * @param  size
    325      *         The new size, a non-negative byte count
    326      *
    327      * @return  This file channel
    328      *
    329      * @throws  NonWritableChannelException
    330      *          If this channel was not opened for writing
    331      *
    332      * @throws  ClosedChannelException
    333      *          If this channel is closed
    334      *
    335      * @throws  IllegalArgumentException
    336      *          If the new size is negative
    337      *
    338      * @throws  IOException
    339      *          If some other I/O error occurs
    340      */
    341     public abstract AsynchronousFileChannel truncate(long size) throws IOException;
    342 
    343     /**
    344      * Forces any updates to this channel's file to be written to the storage
    345      * device that contains it.
    346      *
    347      * <p> If this channel's file resides on a local storage device then when
    348      * this method returns it is guaranteed that all changes made to the file
    349      * since this channel was created, or since this method was last invoked,
    350      * will have been written to that device.  This is useful for ensuring that
    351      * critical information is not lost in the event of a system crash.
    352      *
    353      * <p> If the file does not reside on a local device then no such guarantee
    354      * is made.
    355      *
    356      * <p> The {@code metaData} parameter can be used to limit the number of
    357      * I/O operations that this method is required to perform.  Passing
    358      * {@code false} for this parameter indicates that only updates to the
    359      * file's content need be written to storage; passing {@code true}
    360      * indicates that updates to both the file's content and metadata must be
    361      * written, which generally requires at least one more I/O operation.
    362      * Whether this parameter actually has any effect is dependent upon the
    363      * underlying operating system and is therefore unspecified.
    364      *
    365      * <p> Invoking this method may cause an I/O operation to occur even if the
    366      * channel was only opened for reading.  Some operating systems, for
    367      * example, maintain a last-access time as part of a file's metadata, and
    368      * this time is updated whenever the file is read.  Whether or not this is
    369      * actually done is system-dependent and is therefore unspecified.
    370      *
    371      * <p> This method is only guaranteed to force changes that were made to
    372      * this channel's file via the methods defined in this class.
    373      *
    374      * @param   metaData
    375      *          If {@code true} then this method is required to force changes
    376      *          to both the file's content and metadata to be written to
    377      *          storage; otherwise, it need only force content changes to be
    378      *          written
    379      *
    380      * @throws  ClosedChannelException
    381      *          If this channel is closed
    382      *
    383      * @throws  IOException
    384      *          If some other I/O error occurs
    385      */
    386     public abstract void force(boolean metaData) throws IOException;
    387 
    388     /**
    389      * Acquires a lock on the given region of this channel's file.
    390      *
    391      * <p> This method initiates an operation to acquire a lock on the given
    392      * region of this channel's file. The {@code handler} parameter is a
    393      * completion handler that is invoked when the lock is acquired (or the
    394      * operation fails). The result passed to the completion handler is the
    395      * resulting {@code FileLock}.
    396      *
    397      * <p> The region specified by the {@code position} and {@code size}
    398      * parameters need not be contained within, or even overlap, the actual
    399      * underlying file.  Lock regions are fixed in size; if a locked region
    400      * initially contains the end of the file and the file grows beyond the
    401      * region then the new portion of the file will not be covered by the lock.
    402      * If a file is expected to grow in size and a lock on the entire file is
    403      * required then a region starting at zero, and no smaller than the
    404      * expected maximum size of the file, should be locked.  The two-argument
    405      * {@link #lock(Object,CompletionHandler)} method simply locks a region
    406      * of size {@link Long#MAX_VALUE}. If a lock that overlaps the requested
    407      * region is already held by this Java virtual machine, or this method has
    408      * been invoked to lock an overlapping region and that operation has not
    409      * completed, then this method throws {@link OverlappingFileLockException}.
    410      *
    411      * <p> Some operating systems do not support a mechanism to acquire a file
    412      * lock in an asynchronous manner. Consequently an implementation may
    413      * acquire the file lock in a background thread or from a task executed by
    414      * a thread in the associated thread pool. If there are many lock operations
    415      * outstanding then it may consume threads in the Java virtual machine for
    416      * indefinite periods.
    417      *
    418      * <p> Some operating systems do not support shared locks, in which case a
    419      * request for a shared lock is automatically converted into a request for
    420      * an exclusive lock.  Whether the newly-acquired lock is shared or
    421      * exclusive may be tested by invoking the resulting lock object's {@link
    422      * FileLock#isShared() isShared} method.
    423      *
    424      * <p> File locks are held on behalf of the entire Java virtual machine.
    425      * They are not suitable for controlling access to a file by multiple
    426      * threads within the same virtual machine.
    427      *
    428      * @param   <A>
    429      *          The type of the attachment
    430      * @param   position
    431      *          The position at which the locked region is to start; must be
    432      *          non-negative
    433      * @param   size
    434      *          The size of the locked region; must be non-negative, and the sum
    435      *          {@code position}&nbsp;+&nbsp;{@code size} must be non-negative
    436      * @param   shared
    437      *          {@code true} to request a shared lock, in which case this
    438      *          channel must be open for reading (and possibly writing);
    439      *          {@code false} to request an exclusive lock, in which case this
    440      *          channel must be open for writing (and possibly reading)
    441      * @param   attachment
    442      *          The object to attach to the I/O operation; can be {@code null}
    443      * @param   handler
    444      *          The handler for consuming the result
    445      *
    446      * @throws  OverlappingFileLockException
    447      *          If a lock that overlaps the requested region is already held by
    448      *          this Java virtual machine, or there is already a pending attempt
    449      *          to lock an overlapping region
    450      * @throws  IllegalArgumentException
    451      *          If the preconditions on the parameters do not hold
    452      * @throws  NonReadableChannelException
    453      *          If {@code shared} is true but this channel was not opened for reading
    454      * @throws  NonWritableChannelException
    455      *          If {@code shared} is false but this channel was not opened for writing
    456      */
    457     public abstract <A> void lock(long position,
    458                                   long size,
    459                                   boolean shared,
    460                                   A attachment,
    461                                   CompletionHandler<FileLock,? super A> handler);
    462 
    463     /**
    464      * Acquires an exclusive lock on this channel's file.
    465      *
    466      * <p> This method initiates an operation to acquire a lock on the given
    467      * region of this channel's file. The {@code handler} parameter is a
    468      * completion handler that is invoked when the lock is acquired (or the
    469      * operation fails). The result passed to the completion handler is the
    470      * resulting {@code FileLock}.
    471      *
    472      * <p> An invocation of this method of the form {@code ch.lock(att,handler)}
    473      * behaves in exactly the same way as the invocation
    474      * <pre>
    475      *     ch.{@link #lock(long,long,boolean,Object,CompletionHandler) lock}(0L, Long.MAX_VALUE, false, att, handler)
    476      * </pre>
    477      *
    478      * @param   <A>
    479      *          The type of the attachment
    480      * @param   attachment
    481      *          The object to attach to the I/O operation; can be {@code null}
    482      * @param   handler
    483      *          The handler for consuming the result
    484      *
    485      * @throws  OverlappingFileLockException
    486      *          If a lock is already held by this Java virtual machine, or there
    487      *          is already a pending attempt to lock a region
    488      * @throws  NonWritableChannelException
    489      *          If this channel was not opened for writing
    490      */
    491     public final <A> void lock(A attachment,
    492                                CompletionHandler<FileLock,? super A> handler)
    493     {
    494         lock(0L, Long.MAX_VALUE, false, attachment, handler);
    495     }
    496 
    497     /**
    498      * Acquires a lock on the given region of this channel's file.
    499      *
    500      * <p> This method initiates an operation to acquire a lock on the given
    501      * region of this channel's file.  The method behaves in exactly the same
    502      * manner as the {@link #lock(long, long, boolean, Object, CompletionHandler)}
    503      * method except that instead of specifying a completion handler, this
    504      * method returns a {@code Future} representing the pending result. The
    505      * {@code Future}'s {@link Future#get() get} method returns the {@link
    506      * FileLock} on successful completion.
    507      *
    508      * @param   position
    509      *          The position at which the locked region is to start; must be
    510      *          non-negative
    511      * @param   size
    512      *          The size of the locked region; must be non-negative, and the sum
    513      *          {@code position}&nbsp;+&nbsp;{@code size} must be non-negative
    514      * @param   shared
    515      *          {@code true} to request a shared lock, in which case this
    516      *          channel must be open for reading (and possibly writing);
    517      *          {@code false} to request an exclusive lock, in which case this
    518      *          channel must be open for writing (and possibly reading)
    519      *
    520      * @return  a {@code Future} object representing the pending result
    521      *
    522      * @throws  OverlappingFileLockException
    523      *          If a lock is already held by this Java virtual machine, or there
    524      *          is already a pending attempt to lock a region
    525      * @throws  IllegalArgumentException
    526      *          If the preconditions on the parameters do not hold
    527      * @throws  NonReadableChannelException
    528      *          If {@code shared} is true but this channel was not opened for reading
    529      * @throws  NonWritableChannelException
    530      *          If {@code shared} is false but this channel was not opened for writing
    531      */
    532     public abstract Future<FileLock> lock(long position, long size, boolean shared);
    533 
    534     /**
    535      * Acquires an exclusive lock on this channel's file.
    536      *
    537      * <p> This method initiates an operation to acquire an exclusive lock on this
    538      * channel's file. The method returns a {@code Future} representing the
    539      * pending result of the operation. The {@code Future}'s {@link Future#get()
    540      * get} method returns the {@link FileLock} on successful completion.
    541      *
    542      * <p> An invocation of this method behaves in exactly the same way as the
    543      * invocation
    544      * <pre>
    545      *     ch.{@link #lock(long,long,boolean) lock}(0L, Long.MAX_VALUE, false)
    546      * </pre>
    547      *
    548      * @return  a {@code Future} object representing the pending result
    549      *
    550      * @throws  OverlappingFileLockException
    551      *          If a lock is already held by this Java virtual machine, or there
    552      *          is already a pending attempt to lock a region
    553      * @throws  NonWritableChannelException
    554      *          If this channel was not opened for writing
    555      */
    556     public final Future<FileLock> lock() {
    557         return lock(0L, Long.MAX_VALUE, false);
    558     }
    559 
    560     /**
    561      * Attempts to acquire a lock on the given region of this channel's file.
    562      *
    563      * <p> This method does not block. An invocation always returns immediately,
    564      * either having acquired a lock on the requested region or having failed to
    565      * do so.  If it fails to acquire a lock because an overlapping lock is held
    566      * by another program then it returns {@code null}.  If it fails to acquire
    567      * a lock for any other reason then an appropriate exception is thrown.
    568      *
    569      * @param  position
    570      *         The position at which the locked region is to start; must be
    571      *         non-negative
    572      *
    573      * @param  size
    574      *         The size of the locked region; must be non-negative, and the sum
    575      *         {@code position}&nbsp;+&nbsp;{@code size} must be non-negative
    576      *
    577      * @param  shared
    578      *         {@code true} to request a shared lock,
    579      *         {@code false} to request an exclusive lock
    580      *
    581      * @return  A lock object representing the newly-acquired lock,
    582      *          or {@code null} if the lock could not be acquired
    583      *          because another program holds an overlapping lock
    584      *
    585      * @throws  IllegalArgumentException
    586      *          If the preconditions on the parameters do not hold
    587      * @throws  ClosedChannelException
    588      *          If this channel is closed
    589      * @throws  OverlappingFileLockException
    590      *          If a lock that overlaps the requested region is already held by
    591      *          this Java virtual machine, or if another thread is already
    592      *          blocked in this method and is attempting to lock an overlapping
    593      *          region of the same file
    594      * @throws  NonReadableChannelException
    595      *          If {@code shared} is true but this channel was not opened for reading
    596      * @throws  NonWritableChannelException
    597      *          If {@code shared} is false but this channel was not opened for writing
    598      *
    599      * @throws  IOException
    600      *          If some other I/O error occurs
    601      *
    602      * @see     #lock(Object,CompletionHandler)
    603      * @see     #lock(long,long,boolean,Object,CompletionHandler)
    604      * @see     #tryLock()
    605      */
    606     public abstract FileLock tryLock(long position, long size, boolean shared)
    607         throws IOException;
    608 
    609     /**
    610      * Attempts to acquire an exclusive lock on this channel's file.
    611      *
    612      * <p> An invocation of this method of the form {@code ch.tryLock()}
    613      * behaves in exactly the same way as the invocation
    614      *
    615      * <pre>
    616      *     ch.{@link #tryLock(long,long,boolean) tryLock}(0L, Long.MAX_VALUE, false) </pre>
    617      *
    618      * @return  A lock object representing the newly-acquired lock,
    619      *          or {@code null} if the lock could not be acquired
    620      *          because another program holds an overlapping lock
    621      *
    622      * @throws  ClosedChannelException
    623      *          If this channel is closed
    624      * @throws  OverlappingFileLockException
    625      *          If a lock that overlaps the requested region is already held by
    626      *          this Java virtual machine, or if another thread is already
    627      *          blocked in this method and is attempting to lock an overlapping
    628      *          region
    629      * @throws  NonWritableChannelException
    630      *          If {@code shared} is false but this channel was not opened for writing
    631      *
    632      * @throws  IOException
    633      *          If some other I/O error occurs
    634      *
    635      * @see     #lock(Object,CompletionHandler)
    636      * @see     #lock(long,long,boolean,Object,CompletionHandler)
    637      * @see     #tryLock(long,long,boolean)
    638      */
    639     public final FileLock tryLock() throws IOException {
    640         return tryLock(0L, Long.MAX_VALUE, false);
    641     }
    642 
    643     /**
    644      * Reads a sequence of bytes from this channel into the given buffer,
    645      * starting at the given file position.
    646      *
    647      * <p> This method initiates the reading of a sequence of bytes from this
    648      * channel into the given buffer, starting at the given file position. The
    649      * result of the read is the number of bytes read or {@code -1} if the given
    650      * position is greater than or equal to the file's size at the time that the
    651      * read is attempted.
    652      *
    653      * <p> This method works in the same manner as the {@link
    654      * AsynchronousByteChannel#read(ByteBuffer,Object,CompletionHandler)}
    655      * method, except that bytes are read starting at the given file position.
    656      * If the given file position is greater than the file's size at the time
    657      * that the read is attempted then no bytes are read.
    658      *
    659      * @param   <A>
    660      *          The type of the attachment
    661      * @param   dst
    662      *          The buffer into which bytes are to be transferred
    663      * @param   position
    664      *          The file position at which the transfer is to begin;
    665      *          must be non-negative
    666      * @param   attachment
    667      *          The object to attach to the I/O operation; can be {@code null}
    668      * @param   handler
    669      *          The handler for consuming the result
    670      *
    671      * @throws  IllegalArgumentException
    672      *          If the position is negative or the buffer is read-only
    673      * @throws  NonReadableChannelException
    674      *          If this channel was not opened for reading
    675      */
    676     public abstract <A> void read(ByteBuffer dst,
    677                                   long position,
    678                                   A attachment,
    679                                   CompletionHandler<Integer,? super A> handler);
    680 
    681     /**
    682      * Reads a sequence of bytes from this channel into the given buffer,
    683      * starting at the given file position.
    684      *
    685      * <p> This method initiates the reading of a sequence of bytes from this
    686      * channel into the given buffer, starting at the given file position. This
    687      * method returns a {@code Future} representing the pending result of the
    688      * operation. The {@code Future}'s {@link Future#get() get} method returns
    689      * the number of bytes read or {@code -1} if the given position is greater
    690      * than or equal to the file's size at the time that the read is attempted.
    691      *
    692      * <p> This method works in the same manner as the {@link
    693      * AsynchronousByteChannel#read(ByteBuffer)} method, except that bytes are
    694      * read starting at the given file position. If the given file position is
    695      * greater than the file's size at the time that the read is attempted then
    696      * no bytes are read.
    697      *
    698      * @param   dst
    699      *          The buffer into which bytes are to be transferred
    700      * @param   position
    701      *          The file position at which the transfer is to begin;
    702      *          must be non-negative
    703      *
    704      * @return  A {@code Future} object representing the pending result
    705      *
    706      * @throws  IllegalArgumentException
    707      *          If the position is negative or the buffer is read-only
    708      * @throws  NonReadableChannelException
    709      *          If this channel was not opened for reading
    710      */
    711     public abstract Future<Integer> read(ByteBuffer dst, long position);
    712 
    713     /**
    714      * Writes a sequence of bytes to this channel from the given buffer, starting
    715      * at the given file position.
    716      *
    717      * <p> This method works in the same manner as the {@link
    718      * AsynchronousByteChannel#write(ByteBuffer,Object,CompletionHandler)}
    719      * method, except that bytes are written starting at the given file position.
    720      * If the given position is greater than the file's size, at the time that
    721      * the write is attempted, then the file will be grown to accommodate the new
    722      * bytes; the values of any bytes between the previous end-of-file and the
    723      * newly-written bytes are unspecified.
    724      *
    725      * @param   <A>
    726      *          The type of the attachment
    727      * @param   src
    728      *          The buffer from which bytes are to be transferred
    729      * @param   position
    730      *          The file position at which the transfer is to begin;
    731      *          must be non-negative
    732      * @param   attachment
    733      *          The object to attach to the I/O operation; can be {@code null}
    734      * @param   handler
    735      *          The handler for consuming the result
    736      *
    737      * @throws  IllegalArgumentException
    738      *          If the position is negative
    739      * @throws  NonWritableChannelException
    740      *          If this channel was not opened for writing
    741      */
    742     public abstract <A> void write(ByteBuffer src,
    743                                    long position,
    744                                    A attachment,
    745                                    CompletionHandler<Integer,? super A> handler);
    746 
    747     /**
    748      * Writes a sequence of bytes to this channel from the given buffer, starting
    749      * at the given file position.
    750      *
    751      * <p> This method initiates the writing of a sequence of bytes to this
    752      * channel from the given buffer, starting at the given file position. The
    753      * method returns a {@code Future} representing the pending result of the
    754      * write operation. The {@code Future}'s {@link Future#get() get} method
    755      * returns the number of bytes written.
    756      *
    757      * <p> This method works in the same manner as the {@link
    758      * AsynchronousByteChannel#write(ByteBuffer)} method, except that bytes are
    759      * written starting at the given file position. If the given position is
    760      * greater than the file's size, at the time that the write is attempted,
    761      * then the file will be grown to accommodate the new bytes; the values of
    762      * any bytes between the previous end-of-file and the newly-written bytes
    763      * are unspecified.
    764      *
    765      * @param   src
    766      *          The buffer from which bytes are to be transferred
    767      * @param   position
    768      *          The file position at which the transfer is to begin;
    769      *          must be non-negative
    770      *
    771      * @return  A {@code Future} object representing the pending result
    772      *
    773      * @throws  IllegalArgumentException
    774      *          If the position is negative
    775      * @throws  NonWritableChannelException
    776      *          If this channel was not opened for writing
    777      */
    778     public abstract Future<Integer> write(ByteBuffer src, long position);
    779 }
    780