Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/openjdk-multiarch-jdk8u
Path: blob/aarch64-shenandoah-jdk8u272-b10/jdk/src/share/classes/java/nio/channels/FileChannel.java
38918 views
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
26
package java.nio.channels;
27
28
import java.io.*;
29
import java.nio.ByteBuffer;
30
import java.nio.MappedByteBuffer;
31
import java.nio.channels.spi.AbstractInterruptibleChannel;
32
import java.nio.file.*;
33
import java.nio.file.attribute.FileAttribute;
34
import java.nio.file.spi.*;
35
import java.util.Set;
36
import java.util.HashSet;
37
import 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
155
public 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
1160