Class NioSocketChannel
- java.lang.Object
-
- org.jboss.netty.channel.AbstractChannel
-
- org.jboss.netty.channel.socket.nio.NioSocketChannel
-
- All Implemented Interfaces:
Comparable<Channel>,Channel,SocketChannel
public class NioSocketChannel extends AbstractChannel implements SocketChannel
-
-
Field Summary
-
Fields inherited from interface org.jboss.netty.channel.Channel
OP_NONE, OP_READ, OP_READ_WRITE, OP_WRITE
-
-
Constructor Summary
Constructors Constructor Description NioSocketChannel(Channel parent, ChannelFactory factory, ChannelPipeline pipeline, ChannelSink sink, SocketChannel socket, NioWorker worker)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description NioSocketChannelConfiggetConfig()Returns the configuration of this channel.protected intgetInternalInterestOps()InetSocketAddressgetLocalAddress()Returns the local address where this channel is bound to.InetSocketAddressgetRemoteAddress()Returns the remote address where this channel is connected to.NioWorkergetWorker()Return theAbstractNioWorkerthat handle the IO of theAbstractNioChannelbooleanisBound()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.booleanisOpen()Returnstrueif and only if this channel is open.protected booleansetClosed()Marks this channel as closed.protected voidsetInternalInterestOps(int interestOps)Sets theinterestOpsproperty of this channel immediately.ChannelFuturewrite(Object message, 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, isReadable, isWritable, setAttachment, setInterestOps, setReadable, setUnwritable, setUserDefinedWritability, setWritable, toString, unbind, write
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.jboss.netty.channel.Channel
bind, close, connect, disconnect, getAttachment, getCloseFuture, getFactory, getId, getInterestOps, getParent, getPipeline, getUserDefinedWritability, isReadable, isWritable, setAttachment, setInterestOps, setReadable, setUserDefinedWritability, unbind, write
-
Methods inherited from interface java.lang.Comparable
compareTo
-
Methods inherited from interface org.jboss.netty.channel.socket.SocketChannel
getLocalAddress, getRemoteAddress
-
-
-
-
Constructor Detail
-
NioSocketChannel
public NioSocketChannel(Channel parent, ChannelFactory factory, ChannelPipeline pipeline, ChannelSink sink, SocketChannel socket, NioWorker worker)
-
-
Method Detail
-
getWorker
public NioWorker getWorker()
Return theAbstractNioWorkerthat handle the IO of theAbstractNioChannel- Returns:
- worker
-
getConfig
public NioSocketChannelConfig getConfig()
Description copied from interface:ChannelReturns the configuration of this channel.- Specified by:
getConfigin interfaceChannel- Specified by:
getConfigin interfaceSocketChannel
-
isOpen
public boolean isOpen()
Description copied from interface:ChannelReturnstrueif and only if this channel is open.- Specified by:
isOpenin interfaceChannel- Overrides:
isOpenin classAbstractChannel
-
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.- Specified by:
isConnectedin interfaceChannel
-
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.- Returns:
trueif and only if this channel was not marked as closed yet
-
write
public ChannelFuture write(Object message, 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
-
getLocalAddress
public 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 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.
-
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
-
-