Class AbstractOioChannel
- java.lang.Object
-
- org.jboss.netty.channel.AbstractChannel
-
- org.jboss.netty.channel.socket.oio.AbstractOioChannel
-
- Direct Known Subclasses:
OioDatagramChannel,OioSocketChannel
abstract class AbstractOioChannel extends AbstractChannel
-
-
Field Summary
Fields Modifier and Type Field Description (package private) java.lang.ObjectinterestOpsLockprivate java.net.InetSocketAddresslocalAddress(package private) java.net.InetSocketAddressremoteAddress(package private) Workerworker(package private) java.lang.ThreadworkerThread-
Fields inherited from interface org.jboss.netty.channel.Channel
OP_NONE, OP_READ, OP_READ_WRITE, OP_WRITE
-
-
Constructor Summary
Constructors Constructor Description AbstractOioChannel(Channel parent, ChannelFactory factory, ChannelPipeline pipeline, ChannelSink sink)
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description (package private) abstract voidcloseSocket()protected intgetInternalInterestOps()java.net.InetSocketAddressgetLocalAddress()Returns the local address where this channel is bound to.(package private) abstract java.net.InetSocketAddressgetLocalSocketAddress()java.net.InetSocketAddressgetRemoteAddress()Returns the remote address where this channel is connected to.(package private) abstract java.net.InetSocketAddressgetRemoteSocketAddress()booleanisBound()Returnstrueif and only if this channel is bound to a local address.booleanisConnected()Returnstrueif and only if this channel is connected to a remote address.(package private) abstract booleanisSocketBound()(package private) abstract booleanisSocketClosed()(package private) abstract booleanisSocketConnected()protected booleansetClosed()Marks this channel as closed.protected voidsetInternalInterestOps(int interestOps)Sets theinterestOpsproperty of this channel immediately.ChannelFuturewrite(java.lang.Object message, java.net.SocketAddress remoteAddress)Sends a message to this channel asynchronously.-
Methods inherited from class org.jboss.netty.channel.AbstractChannel
bind, close, compareTo, connect, disconnect, equals, getAttachment, getCloseFuture, getFactory, getId, getInterestOps, getParent, getPipeline, getSucceededFuture, getUnsupportedOperationFuture, getUserDefinedWritability, hashCode, isOpen, isReadable, isWritable, setAttachment, setInterestOps, setReadable, setUnwritable, setUserDefinedWritability, setWritable, toString, unbind, write
-
-
-
-
Field Detail
-
localAddress
private volatile java.net.InetSocketAddress localAddress
-
remoteAddress
volatile java.net.InetSocketAddress remoteAddress
-
workerThread
volatile java.lang.Thread workerThread
-
worker
volatile Worker worker
-
interestOpsLock
final java.lang.Object interestOpsLock
-
-
Constructor Detail
-
AbstractOioChannel
AbstractOioChannel(Channel parent, ChannelFactory factory, ChannelPipeline pipeline, ChannelSink sink)
-
-
Method Detail
-
setClosed
protected boolean setClosed()
Description copied from class:AbstractChannelMarks this channel as closed. This method is intended to be called by an internal component - please do not call it unless you know what you are doing.- Overrides:
setClosedin classAbstractChannel- Returns:
trueif and only if this channel was not marked as closed yet
-
getInternalInterestOps
protected int getInternalInterestOps()
- Overrides:
getInternalInterestOpsin classAbstractChannel
-
setInternalInterestOps
protected void setInternalInterestOps(int interestOps)
Description copied from class:AbstractChannelSets theinterestOpsproperty of this channel immediately. This method is intended to be called by an internal component - please do not call it unless you know what you are doing.- Overrides:
setInternalInterestOpsin classAbstractChannel
-
write
public ChannelFuture write(java.lang.Object message, java.net.SocketAddress remoteAddress)
Description copied from interface:ChannelSends a message to this channel asynchronously. It has an additional parameter that allows a user to specify where to send the specified message instead of this channel's current remote address. If this channel was created by a connectionless transport (e.g.DatagramChannel) and is not connected yet, you must specify non-null address. Otherwise, the write request will fail withNotYetConnectedExceptionand an'exceptionCaught'event will be triggered.- Specified by:
writein interfaceChannel- Overrides:
writein classAbstractChannel- Parameters:
message- the message to writeremoteAddress- where to send the specified message. This method is identical toChannel.write(Object)ifnullis specified here.- Returns:
- the
ChannelFuturewhich will be notified when the write request succeeds or fails
-
isBound
public boolean isBound()
Description copied from interface:ChannelReturnstrueif and only if this channel is bound to a local address.
-
isConnected
public boolean isConnected()
Description copied from interface:ChannelReturnstrueif and only if this channel is connected to a remote address.
-
getLocalAddress
public java.net.InetSocketAddress getLocalAddress()
Description copied from interface:ChannelReturns the local address where this channel is bound to. The returnedSocketAddressis supposed to be down-cast into more concrete type such asInetSocketAddressto retrieve the detailed information.- Returns:
- the local address of this channel.
nullif this channel is not bound.
-
getRemoteAddress
public java.net.InetSocketAddress getRemoteAddress()
Description copied from interface:ChannelReturns the remote address where this channel is connected to. The returnedSocketAddressis supposed to be down-cast into more concrete type such asInetSocketAddressto retrieve the detailed information.- Returns:
- the remote address of this channel.
nullif this channel is not connected. If this channel is not connected but it can receive messages from arbitrary remote addresses (e.g.DatagramChannel, useMessageEvent.getRemoteAddress()to determine the origination of the received message as this method will returnnull.
-
isSocketBound
abstract boolean isSocketBound()
-
isSocketConnected
abstract boolean isSocketConnected()
-
isSocketClosed
abstract boolean isSocketClosed()
-
getLocalSocketAddress
abstract java.net.InetSocketAddress getLocalSocketAddress() throws java.lang.Exception- Throws:
java.lang.Exception
-
getRemoteSocketAddress
abstract java.net.InetSocketAddress getRemoteSocketAddress() throws java.lang.Exception- Throws:
java.lang.Exception
-
closeSocket
abstract void closeSocket() throws java.io.IOException- Throws:
java.io.IOException
-
-