Categories:
Audio (13)
Biotech (29)
Bytecode (36)
Database (77)
Framework (7)
Game (7)
General (507)
Graphics (53)
I/O (35)
IDE (2)
JAR Tools (101)
JavaBeans (21)
JDBC (121)
JDK (426)
JSP (20)
Logging (108)
Mail (58)
Messaging (8)
Network (84)
PDF (97)
Report (7)
Scripting (84)
Security (32)
Server (121)
Servlet (26)
SOAP (24)
Testing (54)
Web (15)
XML (309)
Collections:
Other Resources:
JDK 11 java.base.jmod - Base Module
JDK 11 java.base.jmod is the JMOD file for JDK 11 Base module.
JDK 11 Base module compiled class files are stored in \fyicenter\jdk-11.0.1\jmods\java.base.jmod.
JDK 11 Base module compiled class files are also linked and stored in the \fyicenter\jdk-11.0.1\lib\modules JImage file.
JDK 11 Base module source code files are stored in \fyicenter\jdk-11.0.1\lib\src.zip\java.base.
You can click and view the content of each source code file in the list below.
✍: FYIcenter
⏎ java/nio/channels/package-info.java
/* * Copyright (c) 2001, 2017, Oracle and/or its affiliates. All rights reserved. * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. * * * * * * * * * * * * * * * * * * * * */ /** * Defines channels, which represent connections to entities that are capable of * performing I/O operations, such as files and sockets; defines selectors, for * multiplexed, non-blocking I/O operations. * * <a id="channels"></a> * * <table class="striped" style="text-align:left; margin-left:2em"> * <caption style="display:none">Lists channels and their descriptions</caption> * <thead> * <tr><th scope="col">Channels</th> * <th scope="col">Description</th></tr> * </thead> * <tbody> * <tr><th scope="row"><i>{@link java.nio.channels.Channel}</i></th> * <td>A nexus for I/O operations</td></tr> * <tr><th scope="row"> * <span style="padding-left:1em"><i>{@link java.nio.channels.ReadableByteChannel}</i></span></th> * <td>Can read into a buffer</td></tr> * <tr><th scope="row"> * <span style="padding-left:2em"><i>{@link java.nio.channels.ScatteringByteChannel}</i></span></th> * <td>Can read into a sequence of buffers</td></tr> * <tr><th scope="row"> * <span style="padding-left:1em"><i>{@link java.nio.channels.WritableByteChannel}</i></span></th> * <td>Can write from a buffer</td></tr> * <tr><th scope="row"> * <span style="padding-left:2em"><i>{@link java.nio.channels.GatheringByteChannel}</i></span></th> * <td>Can write from a sequence of buffers</td></tr> * <tr><th scope="row"> * <span style="padding-left:1em"><i>{@link java.nio.channels.ByteChannel}</i></span></th> * <td>Can read/write to/from a buffer</td></tr> * <tr><th scope="row"> * <span style="padding-left:2em"><i>{@link java.nio.channels.SeekableByteChannel}</i></span></th> * <td>A {@code ByteChannel} connected to an entity that contains a variable-length * sequence of bytes</td></tr> * <tr><th scope="row"> * <span style="padding-left:1em"><i>{@link java.nio.channels.AsynchronousChannel}</i></span></th> * <td>Supports asynchronous I/O operations.</td></tr> * <tr><th scope="row"> * <span style="padding-left:2em"><i>{@link java.nio.channels.AsynchronousByteChannel}</i></span></th> * <td>Can read and write bytes asynchronously</td></tr> * <tr><th scope="row"> * <span style="padding-left:1em"><i>{@link java.nio.channels.NetworkChannel}</i></span></th> * <td>A channel to a network socket</td></tr> * <tr><th scope="row"> * <span style="padding-left:2em"><i>{@link java.nio.channels.MulticastChannel}</i></span></th> * <td>Can join Internet Protocol (IP) multicast groups</td></tr> * <tr><th scope="row">{@link java.nio.channels.Channels}</th> * <td>Utility methods for channel/stream interoperation</td></tr> * </tbody> * </table> * * <p> A <i>channel</i> represents an open connection to an entity such as a * hardware device, a file, a network socket, or a program component that is * capable of performing one or more distinct I/O operations, for example reading * or writing. As specified in the {@link java.nio.channels.Channel} interface, * channels are either open or closed, and they are both <i>asynchronously * closeable</i> and <i>interruptible</i>. * * <p> The {@link java.nio.channels.Channel} interface is extended by several * other interfaces. * * <p> The {@link java.nio.channels.ReadableByteChannel} interface specifies a * {@link java.nio.channels.ReadableByteChannel#read read} method that reads bytes * from the channel into a buffer; similarly, the {@link * java.nio.channels.WritableByteChannel} interface specifies a {@link * java.nio.channels.WritableByteChannel#write write} method that writes bytes * from a buffer to the channel. The {@link java.nio.channels.ByteChannel} * interface unifies these two interfaces for the common case of channels that can * both read and write bytes. The {@link java.nio.channels.SeekableByteChannel} * interface extends the {@code ByteChannel} interface with methods to {@link * java.nio.channels.SeekableByteChannel#position() query} and {@link * java.nio.channels.SeekableByteChannel#position(long) modify} the channel's * current position, and its {@link java.nio.channels.SeekableByteChannel#size * size}. * * <p> The {@link java.nio.channels.ScatteringByteChannel} and {@link * java.nio.channels.GatheringByteChannel} interfaces extend the {@link * java.nio.channels.ReadableByteChannel} and {@link * java.nio.channels.WritableByteChannel} interfaces, respectively, adding {@link * java.nio.channels.ScatteringByteChannel#read read} and {@link * java.nio.channels.GatheringByteChannel#write write} methods that take a * sequence of buffers rather than a single buffer. * * <p> The {@link java.nio.channels.NetworkChannel} interface specifies methods * to {@link java.nio.channels.NetworkChannel#bind bind} the channel's socket, * obtain the address to which the socket is bound, and methods to {@link * java.nio.channels.NetworkChannel#getOption get} and {@link * java.nio.channels.NetworkChannel#setOption set} socket options. The {@link * java.nio.channels.MulticastChannel} interface specifies methods to join * Internet Protocol (IP) multicast groups. * * <p> The {@link java.nio.channels.Channels} utility class defines static methods * that support the interoperation of the stream classes of the {@link * java.io} package with the channel classes of this package. An appropriate * channel can be constructed from an {@link java.io.InputStream} or an {@link * java.io.OutputStream}, and conversely an {@link java.io.InputStream} or an * {@link java.io.OutputStream} can be constructed from a channel. A {@link * java.io.Reader} can be constructed that uses a given charset to decode bytes * from a given readable byte channel, and conversely a {@link java.io.Writer} can * be constructed that uses a given charset to encode characters into bytes and * write them to a given writable byte channel. * * <table class="striped" style="margin-left:2em; text-align:left"> * <caption style="display:none"> * Lists file channels and their descriptions</caption> * <thead> * <tr><th scope="col">File channels</th> * <th scope="col">Description</th></tr> * </thead> * <tbody> * <tr><th scope="row"> * {@link java.nio.channels.FileChannel}</th> * <td>Reads, writes, maps, and manipulates files</td></tr> * <tr><th scope="row"> * {@link java.nio.channels.FileLock}</th> * <td>A lock on a (region of a) file</td></tr> * <tr><th scope="row"> * {@link java.nio.MappedByteBuffer}</th> * <td>A direct byte buffer mapped to a region of a file</td></tr> * </tbody> * </table> * * <p> The {@link java.nio.channels.FileChannel} class supports the usual * operations of reading bytes from, and writing bytes to, a channel connected to * a file, as well as those of querying and modifying the current file position * and truncating the file to a specific size. It defines methods for acquiring * locks on the whole file or on a specific region of a file; these methods return * instances of the {@link java.nio.channels.FileLock} class. Finally, it defines * methods for forcing updates to the file to be written to the storage device that * contains it, for efficiently transferring bytes between the file and other * channels, and for mapping a region of the file directly into memory. * * <p> A {@code FileChannel} is created by invoking one of its static {@link * java.nio.channels.FileChannel#open open} methods, or by invoking the {@code * getChannel} method of a {@link java.io.FileInputStream}, {@link * java.io.FileOutputStream}, or {@link java.io.RandomAccessFile} to return a * file channel connected to the same underlying file as the {@link java.io} * class. * * <a id="multiplex"></a> * <table class="striped" style="margin-left:2em; text-align:left"> * <caption style="display:none"> * Lists multiplexed, non-blocking channels and their descriptions</caption> * <thead> * <tr><th scope="col">Multiplexed, non-blocking I/O</th> * <th scope="col">Description</th></tr> * </thead> * <tbody> * <tr><th scope="row">{@link java.nio.channels.SelectableChannel}</th> * <td>A channel that can be multiplexed</td></tr> * <tr><th scope="row"> * <span style="padding-left:2em">{@link java.nio.channels.DatagramChannel}</span></th> * <td>A channel to a datagram-oriented socket</td></tr> * <tr><th scope="row"> * <span style="padding-left:2em">{@link java.nio.channels.Pipe.SinkChannel}</span></th> * <td>The write end of a pipe</td></tr> * <tr><th scope="row"> * <span style="padding-left:2em">{@link java.nio.channels.Pipe.SourceChannel}</span></th> * <td>The read end of a pipe</td></tr> * <tr><th scope="row"> * <span style="padding-left:2em">{@link java.nio.channels.ServerSocketChannel}</span></th> * <td>A channel to a stream-oriented listening socket</td></tr> * <tr><th scope="row"> * <span style="padding-left:2em">{@link java.nio.channels.SocketChannel}</span></th> * <td>A channel for a stream-oriented connecting socket</td></tr> * <tr><th scope="row">{@link java.nio.channels.Selector}</th> * <td>A multiplexor of selectable channels</td></tr> * <tr><th scope="row">{@link java.nio.channels.SelectionKey}</th> * <td>A token representing the registration of a channel * with a selector</td></tr> * <tr><th scope="row">{@link java.nio.channels.Pipe}</th> * <td>Two channels that form a unidirectional pipe</td></tr> * </tbody> * </table> * * <p> Multiplexed, non-blocking I/O, which is much more scalable than * thread-oriented, blocking I/O, is provided by <i>selectors</i>, <i>selectable * channels</i>, and <i>selection keys</i>. * * <p> A <a href="Selector.html"><i>selector</i></a> is a multiplexor of <a * href="SelectableChannel.html"><i>selectable channels</i></a>, which in turn are * a special type of channel that can be put into <a * href="SelectableChannel.html#bm"><i>non-blocking mode</i></a>. To perform * multiplexed I/O operations, one or more selectable channels are first created, * put into non-blocking mode, and {@link * java.nio.channels.SelectableChannel#register <i>registered</i>} * with a selector. Registering a channel specifies the set of I/O operations * that will be tested for readiness by the selector, and returns a <a * href="SelectionKey.html"><i>selection key</i></a> that represents the * registration. * * <p> Once some channels have been registered with a selector, a <a * href="Selector.html#selop"><i>selection operation</i></a> can be performed in * order to discover which channels, if any, have become ready to perform one or * more of the operations in which interest was previously declared. If a channel * is ready then the key returned when it was registered will be added to the * selector's <i>selected-key set</i>. The key set, and the keys within it, can * be examined in order to determine the operations for which each channel is * ready. From each key one can retrieve the corresponding channel in order to * perform whatever I/O operations are required. * * <p> That a selection key indicates that its channel is ready for some operation * is a hint, but not a guarantee, that such an operation can be performed by a * thread without causing the thread to block. It is imperative that code that * performs multiplexed I/O be written so as to ignore these hints when they prove * to be incorrect. * * <p> This package defines selectable-channel classes corresponding to the {@link * java.net.DatagramSocket}, {@link java.net.ServerSocket}, and {@link * java.net.Socket} classes defined in the {@link java.net} package. * Minor changes to these classes have been made in order to support sockets that * are associated with channels. This package also defines a simple class that * implements unidirectional pipes. In all cases, a new selectable channel is * created by invoking the static {@code open} method of the corresponding class. * If a channel needs an associated socket then a socket will be created as a side * effect of this operation. * * <p> The implementation of selectors, selectable channels, and selection keys * can be replaced by "plugging in" an alternative definition or instance of the * {@link java.nio.channels.spi.SelectorProvider} class defined in the {@link * java.nio.channels.spi} package. It is not expected that many developers * will actually make use of this facility; it is provided primarily so that * sophisticated users can take advantage of operating-system-specific * I/O-multiplexing mechanisms when very high performance is required. * * <p> Much of the bookkeeping and synchronization required to implement the * multiplexed-I/O abstractions is performed by the {@link * java.nio.channels.spi.AbstractInterruptibleChannel}, {@link * java.nio.channels.spi.AbstractSelectableChannel}, {@link * java.nio.channels.spi.AbstractSelectionKey}, and {@link * java.nio.channels.spi.AbstractSelector} classes in the {@link * java.nio.channels.spi} package. When defining a custom selector provider, * only the {@link java.nio.channels.spi.AbstractSelector} and {@link * java.nio.channels.spi.AbstractSelectionKey} classes should be subclassed * directly; custom channel classes should extend the appropriate {@link * java.nio.channels.SelectableChannel} subclasses defined in this package. * * <a id="async"></a> * * <table class="striped" style="padding-left:2em; text-align:left"> * <caption style="display:none"> * Lists asynchronous channels and their descriptions</caption> * <thead> * <tr><th scope="col">Asynchronous I/O</th> * <th scope="col">Description</th></tr> * </thead> * <tbody> * <tr><th scope="row"> * {@link java.nio.channels.AsynchronousFileChannel}</th> * <td>An asynchronous channel for reading, writing, and manipulating a file</td></tr> * <tr><th scope="row"> * {@link java.nio.channels.AsynchronousSocketChannel}</th> * <td>An asynchronous channel to a stream-oriented connecting socket</td></tr> * <tr><th scope="row"> * {@link java.nio.channels.AsynchronousServerSocketChannel}</th> * <td>An asynchronous channel to a stream-oriented listening socket</td></tr> * <tr><th scope="row"> * {@link java.nio.channels.CompletionHandler}</th> * <td>A handler for consuming the result of an asynchronous operation</td></tr> * <tr><th scope="row"> * {@link java.nio.channels.AsynchronousChannelGroup}</th> * <td>A grouping of asynchronous channels for the purpose of resource sharing</td></tr> * </tbody> * </table> * * <p> {@link java.nio.channels.AsynchronousChannel Asynchronous channels} are a * special type of channel capable of asynchronous I/O operations. Asynchronous * channels are non-blocking and define methods to initiate asynchronous * operations, returning a {@link java.util.concurrent.Future} representing the * pending result of each operation. The {@code Future} can be used to poll or * wait for the result of the operation. Asynchronous I/O operations can also * specify a {@link java.nio.channels.CompletionHandler} to invoke when the * operation completes. A completion handler is user provided code that is executed * to consume the result of I/O operation. * * <p> This package defines asynchronous-channel classes that are connected to * a stream-oriented connecting or listening socket, or a datagram-oriented socket. * It also defines the {@link java.nio.channels.AsynchronousFileChannel} class * for asynchronous reading, writing, and manipulating a file. As with the {@link * java.nio.channels.FileChannel} it supports operations to truncate the file * to a specific size, force updates to the file to be written to the storage * device, or acquire locks on the whole file or on a specific region of the file. * Unlike the {@code FileChannel} it does not define methods for mapping a * region of the file directly into memory. Where memory mapped I/O is required, * then a {@code FileChannel} can be used. * * <p> Asynchronous channels are bound to an asynchronous channel group for the * purpose of resource sharing. A group has an associated {@link * java.util.concurrent.ExecutorService} to which tasks are submitted to handle * I/O events and dispatch to completion handlers that consume the result of * asynchronous operations performed on channels in the group. The group can * optionally be specified when creating the channel or the channel can be bound * to a <em>default group</em>. Sophisticated users may wish to create their * own asynchronous channel groups or configure the {@code ExecutorService} * that will be used for the default group. * * <p> As with selectors, the implementation of asynchronous channels can be * replaced by "plugging in" an alternative definition or instance of the {@link * java.nio.channels.spi.AsynchronousChannelProvider} class defined in the * {@link java.nio.channels.spi} package. It is not expected that many * developers will actually make use of this facility; it is provided primarily * so that sophisticated users can take advantage of operating-system-specific * asynchronous I/O mechanisms when very high performance is required. * * <p> Unless otherwise noted, passing a {@code null} argument to a constructor * or method in any class or interface in this package will cause a {@link * java.lang.NullPointerException NullPointerException} to be thrown. * * @since 1.4 * @author Mark Reinhold * @author JSR-51 Expert Group */ package java.nio.channels;
⏎ java/nio/channels/package-info.java
Or download all of them as a single archive file:
File name: java.base-11.0.1-src.zip File size: 8740354 bytes Release date: 2018-11-04 Download
2020-05-29, 242835👍, 0💬
Popular Posts:
maven-settings-builder-3 .8.6.jaris the JAR file for Apache Maven 3.8.6 Settings Builder module. Apa...
The Web Services Description Language for Java Toolkit (WSDL4J), Release 1.6.2, allows the creation,...
Apache BCEL Source Code Files are inside the Apache BCEL source package file like bcel-6.6.1-src.zip...
MXP1 is a stable XmlPull parsing engine that is based on ideas from XPP and in particular XPP2 but c...
If you are a Java developer, it is very often that you need to use some 3rd party libraries to perfo...