Class DatagramSocketImpl
- All Implemented Interfaces:
SocketOptions
public abstract class DatagramSocketImpl extends Object implements SocketOptions
- Implementation Note:
- Sockets created with the
DatagramSocket
andMulticastSocket
public constructors historically delegated all socket operations to aDatagramSocketImpl
implementation named "PlainDatagramSocketImpl".DatagramSocket
andMulticastSocket
have since been changed to a new implementation based onDatagramChannel
. The JDK continues to ship with the older implementation to allow code to run that depends on unspecified behavior that differs between the old and new implementations. The old implementation will be used if the Java virtual machine is started with the system propertyjdk.net.usePlainDatagramSocketImpl
set to use the old implementation. It may also be set in the JDK's network configuration file, located in${java.home}/conf/net.properties
. The value of the property is the string representation of a boolean. If set without a value then it defaults totrue
, hence running with-Djdk.net.usePlainDatagramSocketImpl
or-Djdk.net.usePlainDatagramSocketImpl=true
will configure the Java virtual machine to use the old implementation. The property and old implementation will be removed in a future version. - Since:
- 1.1
Field Summary
Modifier and Type | Field | Description |
---|---|---|
protected FileDescriptor |
fd |
The file descriptor object. |
protected int |
localPort |
The local port number. |
Fields declared in interface java.net.SocketOptions
IP_MULTICAST_IF, IP_MULTICAST_IF2, IP_MULTICAST_LOOP, IP_TOS, SO_BINDADDR, SO_BROADCAST, SO_KEEPALIVE, SO_LINGER, SO_OOBINLINE, SO_RCVBUF, SO_REUSEADDR, SO_REUSEPORT, SO_SNDBUF, SO_TIMEOUT, TCP_NODELAY
Constructor Summary
Constructor | Description |
---|---|
DatagramSocketImpl() |
Constructor for subclasses to call. |
Method Summary
Modifier and Type | Method | Description |
---|---|---|
protected abstract void |
bind |
Binds a datagram socket to a local port and address. |
protected abstract void |
close() |
Close the socket. |
protected void |
connect |
Connects a datagram socket to a remote destination. |
protected abstract void |
create() |
Creates a datagram socket. |
protected void |
disconnect() |
Disconnects a datagram socket from its remote destination. |
protected FileDescriptor |
getFileDescriptor() |
Gets the datagram socket file descriptor. |
protected int |
getLocalPort() |
Gets the local port. |
protected <T> T |
getOption |
Called to get a socket option. |
protected abstract int |
getTimeToLive() |
Retrieve the TTL (time-to-live) option. |
protected abstract byte |
getTTL() |
Deprecated. use getTimeToLive instead. |
protected abstract void |
join |
Join the multicast group. |
protected abstract void |
joinGroup |
Join the multicast group. |
protected abstract void |
leave |
Leave the multicast group. |
protected abstract void |
leaveGroup |
Leave the multicast group. |
protected abstract int |
peek |
Peek at the packet to see who it is from. |
protected abstract int |
peekData |
Peek at the packet to see who it is from. |
protected abstract void |
receive |
Receive the datagram packet. |
protected abstract void |
send |
Sends a datagram packet. |
protected <T> void |
setOption |
Called to set a socket option. |
protected abstract void |
setTimeToLive |
Set the TTL (time-to-live) option. |
protected abstract void |
setTTL |
Deprecated. use setTimeToLive instead. |
protected Set<SocketOption<?>> |
supportedOptions() |
Returns a set of SocketOptions supported by this impl and by this impl's socket (DatagramSocket or MulticastSocket) |
Methods declared in class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods declared in interface java.net.SocketOptions
getOption, setOption
Field Details
localPort
protected int localPort
fd
protected FileDescriptor fd
Constructor Details
DatagramSocketImpl
public DatagramSocketImpl()
Method Details
create
protected abstract void create() throws SocketException
- Throws:
-
SocketException
- if there is an error in the underlying protocol, such as a TCP error.
bind
protected abstract void bind(int lport, InetAddress laddr) throws SocketException
- Parameters:
-
lport
- the local port -
laddr
- the local address - Throws:
-
SocketException
- if there is an error in the underlying protocol, such as a TCP error.
send
protected abstract void send(DatagramPacket p) throws IOException
- Parameters:
-
p
- the packet to be sent. - Throws:
-
IOException
- if an I/O exception occurs while sending the datagram packet. -
PortUnreachableException
- may be thrown if the socket is connected to a currently unreachable destination. Note, there is no guarantee that the exception will be thrown.
connect
protected void connect(InetAddress address, int port) throws SocketException
If the remote destination to which the socket is connected does not exist, or is otherwise unreachable, and if an ICMP destination unreachable packet has been received for that address, then a subsequent call to send or receive may throw a PortUnreachableException. Note, there is no guarantee that the exception will be thrown.
- Parameters:
-
address
- the remote InetAddress to connect to -
port
- the remote port number - Throws:
-
SocketException
- may be thrown if the socket cannot be connected to the remote destination - Since:
- 1.4
disconnect
protected void disconnect()
- Since:
- 1.4
peek
protected abstract int peek(InetAddress i) throws IOException
InetAddress
to the address which the packet came from.- Parameters:
-
i
- an InetAddress object - Returns:
- the port number which the packet came from.
- Throws:
-
IOException
- if an I/O exception occurs -
PortUnreachableException
- may be thrown if the socket is connected to a currently unreachable destination. Note, there is no guarantee that the exception will be thrown.
peekData
protected abstract int peekData(DatagramPacket p) throws IOException
DatagramPacket
. The data is returned, but not consumed, so that a subsequent peekData/receive operation will see the same data.- Parameters:
-
p
- the Packet Received. - Returns:
- the port number which the packet came from.
- Throws:
-
IOException
- if an I/O exception occurs -
PortUnreachableException
- may be thrown if the socket is connected to a currently unreachable destination. Note, there is no guarantee that the exception will be thrown. - Since:
- 1.4
receive
protected abstract void receive(DatagramPacket p) throws IOException
- Parameters:
-
p
- the Packet Received. - Throws:
-
IOException
- if an I/O exception occurs while receiving the datagram packet. -
PortUnreachableException
- may be thrown if the socket is connected to a currently unreachable destination. Note, there is no guarantee that the exception will be thrown.
setTTL
@Deprecated protected abstract void setTTL(byte ttl) throws IOException
- Parameters:
-
ttl
- a byte specifying the TTL value - Throws:
-
IOException
- if an I/O exception occurs while setting the time-to-live option. - See Also:
getTTL
@Deprecated protected abstract byte getTTL() throws IOException
- Returns:
- a byte representing the TTL value
- Throws:
-
IOException
- if an I/O exception occurs while retrieving the time-to-live option - See Also:
setTimeToLive
protected abstract void setTimeToLive(int ttl) throws IOException
- Parameters:
-
ttl
- anint
specifying the time-to-live value - Throws:
-
IOException
- if an I/O exception occurs while setting the time-to-live option. - See Also:
getTimeToLive
protected abstract int getTimeToLive() throws IOException
- Returns:
- an
int
representing the time-to-live value - Throws:
-
IOException
- if an I/O exception occurs while retrieving the time-to-live option - See Also:
join
protected abstract void join(InetAddress inetaddr) throws IOException
- Parameters:
-
inetaddr
- multicast address to join. - Throws:
-
IOException
- if an I/O exception occurs while joining the multicast group.
leave
protected abstract void leave(InetAddress inetaddr) throws IOException
- Parameters:
-
inetaddr
- multicast address to leave. - Throws:
-
IOException
- if an I/O exception occurs while leaving the multicast group.
joinGroup
protected abstract void joinGroup(SocketAddress mcastaddr, NetworkInterface netIf) throws IOException
- Parameters:
-
mcastaddr
- address to join. -
netIf
- specifies the local interface to receive multicast datagram packets - Throws:
-
IOException
- if an I/O exception occurs while joining the multicast group - Since:
- 1.4
leaveGroup
protected abstract void leaveGroup(SocketAddress mcastaddr, NetworkInterface netIf) throws IOException
- Parameters:
-
mcastaddr
- address to leave. -
netIf
- specified the local interface to leave the group at - Throws:
-
IOException
- if an I/O exception occurs while leaving the multicast group - Since:
- 1.4
close
protected abstract void close()
getLocalPort
protected int getLocalPort()
- Returns:
- an
int
representing the local port value
getFileDescriptor
protected FileDescriptor getFileDescriptor()
- Returns:
- a
FileDescriptor
object representing the datagram socket file descriptor
setOption
protected <T> void setOption(SocketOption<T> name, T value) throws IOException
- Implementation Requirements:
- The default implementation of this method first checks that the given socket option
name
is not null, then throwsUnsupportedOperationException
. Subclasses should override this method with an appropriate implementation. - Type Parameters:
-
T
- The type of the socket option value - Parameters:
-
name
- The socket option -
value
- The value of the socket option. A value ofnull
may be valid for some options. - Throws:
-
UnsupportedOperationException
- if the DatagramSocketImpl does not support the option -
IllegalArgumentException
- if the value is not valid for the option -
IOException
- if an I/O error occurs, or if the socket is closed -
NullPointerException
- if name isnull
- Since:
- 9
getOption
protected <T> T getOption(SocketOption<T> name) throws IOException
- Implementation Requirements:
- The default implementation of this method first checks that the given socket option
name
is not null, then throwsUnsupportedOperationException
. Subclasses should override this method with an appropriate implementation. - Type Parameters:
-
T
- The type of the socket option value - Parameters:
-
name
- The socket option - Returns:
- the socket option
- Throws:
-
UnsupportedOperationException
- if the DatagramSocketImpl does not support the option -
IOException
- if an I/O error occurs, or if the socket is closed -
NullPointerException
- if name isnull
- Since:
- 9
supportedOptions
protected Set<SocketOption<?>> supportedOptions()
- Implementation Requirements:
- The default implementation of this method returns an empty set. Subclasses should override this method with an appropriate implementation.
- Returns:
- a Set of SocketOptions
- Since:
- 9
© 1993, 2021, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/net/DatagramSocketImpl.html