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 */ AsynchronousFileChannel()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 */ open(Path file, Set<? extends OpenOption> options, ExecutorService executor, FileAttribute<?>... attrs)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<?>[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 */ open(Path file, OpenOption... options)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 */ size()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 */ truncate(long size)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 */ force(boolean metaData)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} + {@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 */ lock(long position, long size, boolean shared, A attachment, CompletionHandler<FileLock,? super A> handler)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 */ lock(A attachment, CompletionHandler<FileLock,? super A> handler)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} + {@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 */ lock(long position, long size, boolean shared)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 */ lock()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} + {@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 */ tryLock(long position, long size, boolean shared)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 */ tryLock()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 */ read(ByteBuffer dst, long position, A attachment, CompletionHandler<Integer,? super A> handler)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 */ read(ByteBuffer dst, long position)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 */ write(ByteBuffer src, long position, A attachment, CompletionHandler<Integer,? super A> handler)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 */ write(ByteBuffer src, long position)778 public abstract Future<Integer> write(ByteBuffer src, long position); 779 } 780