Added in API level 1

SocketImpl

abstract class SocketImpl : SocketOptions

The abstract class SocketImpl is a common superclass of all classes that actually implement sockets. It is used to create both client and server sockets.

A "plain" socket implements these methods exactly as described, without attempting to go through a firewall or proxy.

Summary

Inherited constants
Int IP_MULTICAST_IF

Set which outgoing interface on which to send multicast packets. Useful on hosts with multiple network interfaces, where applications want to use other than the system default. Takes/returns an InetAddress.

Valid for Multicast: DatagramSocketImpl

Int IP_MULTICAST_IF2

Same as above. This option is introduced so that the behaviour with IP_MULTICAST_IF will be kept the same as before, while this new option can support setting outgoing interfaces with either IPv4 and IPv6 addresses. NOTE: make sure there is no conflict with this

Int IP_MULTICAST_LOOP

This option enables or disables local loopback of multicast datagrams. This option is enabled by default for Multicast Sockets.

Int IP_TOS

This option sets the type-of-service or traffic class field in the IP header for a TCP or UDP socket.

Int SO_BINDADDR

Fetch the local address binding of a socket (this option cannot be "set" only "gotten", since sockets are bound at creation time, and so the locally bound address cannot be changed). The default local address of a socket is INADDR_ANY, meaning any local address on a multi-homed host. A multi-homed host can use this option to accept connections to only one of its addresses (in the case of a ServerSocket or DatagramSocket), or to specify its return address to the peer (for a Socket or DatagramSocket). The parameter of this option is an InetAddress.

This option must be specified in the constructor.

Valid for: SocketImpl, DatagramSocketImpl

Int SO_BROADCAST

Sets SO_BROADCAST for a socket. This option enables and disables the ability of the process to send broadcast messages. It is supported for only datagram sockets and only on networks that support the concept of a broadcast message (e.g. Ethernet, token ring, etc.), and it is set by default for DatagramSockets.

Int SO_KEEPALIVE

When the keepalive option is set for a TCP socket and no data has been exchanged across the socket in either direction for 2 hours (NOTE: the actual value is implementation dependent), TCP automatically sends a keepalive probe to the peer. This probe is a TCP segment to which the peer must respond. One of three responses is expected: 1. The peer responds with the expected ACK. The application is not notified (since everything is OK). TCP will send another probe following another 2 hours of inactivity. 2. The peer responds with an RST, which tells the local TCP that the peer host has crashed and rebooted. The socket is closed. 3. There is no response from the peer. The socket is closed. The purpose of this option is to detect if the peer host crashes. Valid only for TCP socket: SocketImpl

Int SO_LINGER

Specify a linger-on-close timeout. This option disables/enables immediate return from a close() of a TCP Socket. Enabling this option with a non-zero Integer timeout means that a close() will block pending the transmission and acknowledgement of all data written to the peer, at which point the socket is closed gracefully. Upon reaching the linger timeout, the socket is closed forcefully, with a TCP RST. Enabling the option with a timeout of zero does a forceful close immediately. If the specified timeout value exceeds 65,535 it will be reduced to 65,535.

Valid only for TCP: SocketImpl

Int SO_OOBINLINE

When the OOBINLINE option is set, any TCP urgent data received on the socket will be received through the socket input stream. When the option is disabled (which is the default) urgent data is silently discarded.

Int SO_RCVBUF

Set a hint the size of the underlying buffers used by the platform for incoming network I/O. When used in set, this is a suggestion to the kernel from the application about the size of buffers to use for the data to be received over the socket. When used in get, this must return the size of the buffer actually used by the platform when receiving in data on this socket. Valid for all sockets: SocketImpl, DatagramSocketImpl

Int SO_REUSEADDR

Sets SO_REUSEADDR for a socket. This is used only for MulticastSockets in java, and it is set by default for MulticastSockets.

Valid for: DatagramSocketImpl

Int SO_REUSEPORT

Sets SO_REUSEPORT for a socket. This option enables and disables the ability to have multiple sockets listen to the same address and port.

Valid for: SocketImpl, DatagramSocketImpl

Int SO_SNDBUF

Set a hint the size of the underlying buffers used by the platform for outgoing network I/O. When used in set, this is a suggestion to the kernel from the application about the size of buffers to use for the data to be sent over the socket. When used in get, this must return the size of the buffer actually used by the platform when sending out data on this socket. Valid for all sockets: SocketImpl, DatagramSocketImpl

Int SO_TIMEOUT

Set a timeout on blocking Socket operations:

ServerSocket.accept();
  SocketInputStream.read();
  DatagramSocket.receive();
  

The option must be set prior to entering a blocking operation to take effect. If the timeout expires and the operation would continue to block, java.io.InterruptedIOException is raised. The Socket is not closed in this case.

Valid for all sockets: SocketImpl, DatagramSocketImpl

Int TCP_NODELAY

Disable Nagle's algorithm for this connection. Written data to the network is not buffered pending acknowledgement of previously written data.

Valid for TCP only: SocketImpl.

Public constructors

Public methods
open String

Returns the address and port of this socket as a String.

Protected methods
abstract Unit

Accepts a connection.

abstract Int

Returns the number of bytes that can be read from this socket without blocking.

abstract Unit
bind(host: InetAddress!, port: Int)

Binds this socket to the specified local IP address and port number.

abstract Unit

Closes this socket.

abstract Unit
connect(host: String!, port: Int)

Connects this socket to the specified port on the named host.

abstract Unit
connect(address: InetAddress!, port: Int)

Connects this socket to the specified port number on the specified host.

abstract Unit
connect(address: SocketAddress!, timeout: Int)

Connects this socket to the specified port number on the specified host.

abstract Unit
create(stream: Boolean)

Creates either a stream or a datagram socket.

open FileDescriptor!

Returns the value of this socket's fd field.

open InetAddress!

Returns the value of this socket's address field.

abstract InputStream!

Returns an input stream for this socket.

open Int

Returns the value of this socket's localport field.

open T

Called to get a socket option.

abstract OutputStream!

Returns an output stream for this socket.

open Int

Returns the value of this socket's port field.

abstract Unit
listen(backlog: Int)

Sets the maximum queue length for incoming connection indications (a request to connect) to the count argument.

abstract Unit

Send one byte of urgent data on the socket.

open Unit
setOption(name: SocketOption<T>!, value: T)

Called to set a socket option.

open Unit
setPerformancePreferences(connectionTime: Int, latency: Int, bandwidth: Int)

Sets performance preferences for this socket.

open Unit

Places the input stream for this socket at "end of stream".

open Unit

Disables the output stream for this socket.

open MutableSet<SocketOption<*>!>!

Returns a set of SocketOptions supported by this impl and by this impl's socket (Socket or ServerSocket)

open Boolean

Returns whether or not this SocketImpl supports sending urgent data.

Inherited functions
Any! getOption(optID: Int)

Fetch the value of an option. Binary options will return java.lang.Boolean.TRUE if enabled, java.lang.Boolean.FALSE if disabled, e.g.:

SocketImpl s;
  ...
  Boolean noDelay = (Boolean)(s.getOption(TCP_NODELAY));
  if (noDelay.booleanValue()) {
      // true if TCP_NODELAY is enabled...
  ...
  }
  

For options that take a particular type as a parameter, getOption(int) will return the parameter's value, else it will return java.lang.Boolean.FALSE:

Object o = s.getOption(SO_LINGER);
  if (o instanceof Integer) {
      System.out.print("Linger time is " + ((Integer)o).intValue());
  } else {
    // the true type of o is java.lang.Boolean.FALSE;
  }
  

Unit setOption(optID: Int, value: Any!)

Enable/disable the option specified by optID. If the option is to be enabled, and it takes an option-specific "value", this is passed in value. The actual type of value is option-specific, and it is an error to pass something that isn't of the expected type:

SocketImpl s;
  ...
  s.setOption(SO_LINGER, new Integer(10));
     // OK - set SO_LINGER w/ timeout of 10 sec.
  s.setOption(SO_LINGER, new Double(10));
     // ERROR - expects java.lang.Integer
 
If the requested option is binary, it can be set using this method by a java.lang.Boolean:
s.setOption(TCP_NODELAY, Boolean.TRUE);
     // OK - enables TCP_NODELAY, a binary option
  

Any option can be disabled using this method with a Boolean.FALSE:
s.setOption(TCP_NODELAY, Boolean.FALSE);
     // OK - disables TCP_NODELAY
  s.setOption(SO_LINGER, Boolean.FALSE);
     // OK - disables SO_LINGER
  

For an option that has a notion of on and off, and requires a non-boolean parameter, setting its value to anything other than Boolean.FALSE implicitly enables it.
Throws SocketException if the option is unrecognized, the socket is closed, or some low-level error occurred

Properties
InetAddress!

The IP address of the remote end of this socket.

FileDescriptor!

The file descriptor object for this socket.

Int

The local port number to which this socket is connected.

Int

The port number on the remote host to which this socket is connected.

Public constructors

SocketImpl

Added in API level 1
SocketImpl()

Public methods

toString

Added in API level 1
open fun toString(): String

Returns the address and port of this socket as a String.

Return
String a string representation of this socket.

Protected methods

accept

Added in API level 1
protected abstract fun accept(s: SocketImpl!): Unit

Accepts a connection.

Parameters
s SocketImpl!: the accepted connection.
Exceptions
java.io.IOException if an I/O error occurs when accepting the connection.

available

Added in API level 1
protected abstract fun available(): Int

Returns the number of bytes that can be read from this socket without blocking.

Return
Int the number of bytes that can be read from this socket without blocking.
Exceptions
java.io.IOException if an I/O error occurs when determining the number of bytes available.

bind

Added in API level 1
protected abstract fun bind(
    host: InetAddress!,
    port: Int
): Unit

Binds this socket to the specified local IP address and port number.

Parameters
host InetAddress!: an IP address that belongs to a local interface.
port Int: the port number.
Exceptions
java.io.IOException if an I/O error occurs when binding this socket.

close

Added in API level 1
protected abstract fun close(): Unit

Closes this socket.

Exceptions
java.io.IOException if an I/O error occurs when closing this socket.

connect

Added in API level 1
protected abstract fun connect(
    host: String!,
    port: Int
): Unit

Connects this socket to the specified port on the named host.

Parameters
host String!: the name of the remote host.
port Int: the port number.
Exceptions
java.io.IOException if an I/O error occurs when connecting to the remote host.

connect

Added in API level 1
protected abstract fun connect(
    address: InetAddress!,
    port: Int
): Unit

Connects this socket to the specified port number on the specified host.

Parameters
address InetAddress!: the IP address of the remote host.
port Int: the port number.
Exceptions
java.io.IOException if an I/O error occurs when attempting a connection.

connect

Added in API level 1
protected abstract fun connect(
    address: SocketAddress!,
    timeout: Int
): Unit

Connects this socket to the specified port number on the specified host. A timeout of zero is interpreted as an infinite timeout. The connection will then block until established or an error occurs.

Parameters
address SocketAddress!: the Socket address of the remote host.
timeout Int: the timeout value, in milliseconds, or zero for no timeout.
Exceptions
java.io.IOException if an I/O error occurs when attempting a connection.

create

Added in API level 1
protected abstract fun create(stream: Boolean): Unit

Creates either a stream or a datagram socket.

Parameters
stream Boolean: if true, create a stream socket; otherwise, create a datagram socket.
Exceptions
java.io.IOException if an I/O error occurs while creating the socket.

getFileDescriptor

Added in API level 1
protected open fun getFileDescriptor(): FileDescriptor!

Returns the value of this socket's fd field.

Return
FileDescriptor! the value of this socket's fd field.

getInetAddress

Added in API level 1
protected open fun getInetAddress(): InetAddress!

Returns the value of this socket's address field.

Return
InetAddress! the value of this socket's address field.

getInputStream

Added in API level 1
protected abstract fun getInputStream(): InputStream!

Returns an input stream for this socket.

Return
InputStream! a stream for reading from this socket.
Exceptions
java.io.IOException if an I/O error occurs when creating the input stream.

getLocalPort

Added in API level 1
protected open fun getLocalPort(): Int

Returns the value of this socket's localport field.

Return
Int the value of this socket's localport field.

getOption

Added in API level 33
protected open fun <T : Any!> getOption(name: SocketOption<T>!): T

Called to get a socket option.

Parameters
<T> The type of the socket option value
name SocketOption<T>!: The socket option
Return
T the value of the named option
Exceptions
java.lang.UnsupportedOperationException if the SocketImpl does not support the option.
java.io.IOException if an I/O error occurs, or if the socket is closed.

getOutputStream

Added in API level 1
protected abstract fun getOutputStream(): OutputStream!

Returns an output stream for this socket.

Return
OutputStream! an output stream for writing to this socket.
Exceptions
java.io.IOException if an I/O error occurs when creating the output stream.

getPort

Added in API level 1
protected open fun getPort(): Int

Returns the value of this socket's port field.

Return
Int the value of this socket's port field.

listen

Added in API level 1
protected abstract fun listen(backlog: Int): Unit

Sets the maximum queue length for incoming connection indications (a request to connect) to the count argument. If a connection indication arrives when the queue is full, the connection is refused.

Parameters
backlog Int: the maximum length of the queue.
Exceptions
java.io.IOException if an I/O error occurs when creating the queue.

sendUrgentData

Added in API level 1
protected abstract fun sendUrgentData(data: Int): Unit

Send one byte of urgent data on the socket. The byte to be sent is the low eight bits of the parameter

Parameters
data Int: The byte of data to send
Exceptions
java.io.IOException if there is an error sending the data.

setOption

Added in API level 33
protected open fun <T : Any!> setOption(
    name: SocketOption<T>!,
    value: T
): Unit

Called to set a socket option.

Parameters
<T> The type of the socket option value
name SocketOption<T>!: The socket option
value T: The value of the socket option. A value of null may be valid for some options.
Exceptions
java.lang.UnsupportedOperationException if the SocketImpl does not support the option
java.io.IOException if an I/O error occurs, or if the socket is closed.

setPerformancePreferences

Added in API level 1
protected open fun setPerformancePreferences(
    connectionTime: Int,
    latency: Int,
    bandwidth: Int
): Unit

Sets performance preferences for this socket.

Sockets use the TCP/IP protocol by default. Some implementations may offer alternative protocols which have different performance characteristics than TCP/IP. This method allows the application to express its own preferences as to how these tradeoffs should be made when the implementation chooses from the available protocols.

Performance preferences are described by three integers whose values indicate the relative importance of short connection time, low latency, and high bandwidth. The absolute values of the integers are irrelevant; in order to choose a protocol the values are simply compared, with larger values indicating stronger preferences. Negative values represent a lower priority than positive values. If the application prefers short connection time over both low latency and high bandwidth, for example, then it could invoke this method with the values (1, 0, 0). If the application prefers high bandwidth above low latency, and low latency above short connection time, then it could invoke this method with the values (0, 1, 2). By default, this method does nothing, unless it is overridden in a sub-class.

Parameters
connectionTime Int: An int expressing the relative importance of a short connection time
latency Int: An int expressing the relative importance of low latency
bandwidth Int: An int expressing the relative importance of high bandwidth

shutdownInput

Added in API level 1
protected open fun shutdownInput(): Unit

Places the input stream for this socket at "end of stream". Any data sent to this socket is acknowledged and then silently discarded. If you read from a socket input stream after invoking this method on the socket, the stream's available method will return 0, and its read methods will return -1 (end of stream).

Exceptions
java.io.IOException if an I/O error occurs when shutting down this socket.

shutdownOutput

Added in API level 1
protected open fun shutdownOutput(): Unit

Disables the output stream for this socket. For a TCP socket, any previously written data will be sent followed by TCP's normal connection termination sequence. If you write to a socket output stream after invoking shutdownOutput() on the socket, the stream will throw an IOException.

Exceptions
java.io.IOException if an I/O error occurs when shutting down this socket.

supportedOptions

Added in API level 33
protected open fun supportedOptions(): MutableSet<SocketOption<*>!>!

Returns a set of SocketOptions supported by this impl and by this impl's socket (Socket or ServerSocket)

Return
MutableSet<SocketOption<*>!>! a Set of SocketOptions

supportsUrgentData

Added in API level 1
protected open fun supportsUrgentData(): Boolean

Returns whether or not this SocketImpl supports sending urgent data. By default, false is returned unless the method is overridden in a sub-class

Return
Boolean true if urgent data supported

Properties

address

Added in API level 1
protected var address: InetAddress!

The IP address of the remote end of this socket.

fd

Added in API level 1
protected var fd: FileDescriptor!

The file descriptor object for this socket.

localport

Added in API level 1
protected var localport: Int

The local port number to which this socket is connected.

port

Added in API level 1
protected var port: Int

The port number on the remote host to which this socket is connected.