NS3 Socket类API说明

源文件位置:

src/netwrok/model/socket.h
socket.cc

描述:

一个基于BSD Socket API的低级Socket API。
内省没有找到任何典型的配置路径。
有几件事要记住这种类型的套接字:

 它使用ns-3 API构造,如ns3 :: Address类,而不是C风格的结构
 与原始的BSD套接字API相反,这个API是异步的:它不包含阻塞调用。 发送和接收操作必须使用提供的回调。
 它还使用类ns3 :: Packet作为奇特字节缓冲区,允许使用ns-3数据包而不是原始数据指针通过API传递数据。
 不是所有的POSIX套接字API都支持

除此之外,它试图坚持BSD API,使那些知道BSD API的人更容易使用这个API。
更多详细信息,请参见ns-3教程。

公共方法:

Socket (void)
virtual     ~Socket (void)
virtual int     Bind (const Address &address)=0
    为此套接字分配本地端点。
virtual int     Bind ()=0
    为此套接字分配本地IPv4端点。
virtual int     Bind6 ()=0
    为此套接字分配本地IPv6端点。
virtual void    BindToNetDevice (Ptr< NetDevice > netdevice)
    将套接字绑定到特定设备。
    此方法对应于使用真实网络或BSD套接字的setsockopt()SO_BINDTODEVICE。 
        如果在套接字上设置,此选项将强制数据包离开绑定设备,而不管IP路由自然选择的设备。 
        在接收方向,只有从绑定接口接收的数据包将被传递。

    此选项与通过Socket :: Bind()将地址绑定到地址没有特殊的关系。 
        可以通过调用Socket :: Bind(address)和Socket :: BindToNetDevice(device)
        将套接字绑定到绑定接口上的特定IP地址,但是也可以绑定到不匹配的设备和地址,
        即使 套接字不能接收任何数据包结果。
virtual int     Close (void)=0
    关闭套接字。
virtual int     Connect (const Address &address)=0
    启动与远程主机的连接。
virtual bool    GetAllowBroadcast () const =0
    查询是否允许广播数据报传输。
    此方法对应于使用真实网络或BSD套接字的getsockopt()SO_BROADCAST。
Ptr< NetDevice >    GetBoundNetDevice ()
    返回套接字的绑定netdevice(如果有)。
    此方法对应于使用真实网络或BSD套接字的getsockopt()SO_BINDTODEVICE。
virtual enum Socket::SocketErrno    GetErrno (void) const =0
    获取上一个错误号。
uint8_t     GetIpTos (void) const
    查询此套接字的IP服务类型的值。
    此方法对应于使用真实网络或BSD套接字的getsockopt()IP_TOS。
virtual uint8_t     GetIpTtl (void) const
    查询此套接字的IP生存时间字段的值。
    此方法对应于使用真实网络或BSD套接字的getsockopt()IP_TTL。
virtual uint8_t     GetIpv6HopLimit (void) const
    查询此套接字的IP Hop Limit字段的值。
    此方法对应于使用真实网络或BSD套接字的getsockopt()IPV6_HOPLIMIT。
uint8_t     GetIpv6Tclass (void) const
    查询此套接字的“IPv6流量类”字段的值。
    此方法对应于使用真实网络或BSD套接字的getsockopt()IPV6_TCLASS。
virtual Ptr< Node >     GetNode (void) const =0
    返回此套接字与之关联的节点。
virtual int     GetPeerName (Address &address) const =0
    获取连接的套接字的对等体地址。
uint8_t     GetPriority (void) const
    查询此套接字的优先级值。
    此方法对应于使用真实网络或BSD套接字的getsockopt()SO_PRIORITY。
virtual uint32_t    GetRxAvailable (void) const =0
    返回可以从一个或多个调用返回到Recv的字节数。
    必须可以从Recv回调中调用此方法。
virtual enum Socket::SocketType     GetSocketType (void) const =0
    套接字类型,类似于getsockopt(SO_TYPE)
virtual int     GetSockName (Address &address) const =0
    获取套接字地址。
virtual uint32_t    GetTxAvailable (void) const =0
    返回在单个调用Send中可以发送的字节数。
    对于数据报套接字,这返回可以通过底层协议原子传递的字节数。
    对于流套接字,这返回发送缓冲区中剩余的字节的可用空间。
virtual void    Ipv6JoinGroup (Ipv6Address address, Ipv6MulticastFilterMode filterMode,
                                                 std::vector< Ipv6Address > sourceAddresses)
    加入IPv6组播组。
    基于过滤器模式和源地址,这可以被解释为对多播组上的源过滤的加入,
        离开或修改。
    注意套接字只能加入一个多播组。 任何加入其他群组的尝试都会移除旧群组。
virtual void    Ipv6JoinGroup (Ipv6Address address)
    加入没有过滤器的IPv6组播组。
    套接字只能加入一个组播组。 任何加入其他群组的尝试都会移除旧群组。
virtual void    Ipv6LeaveGroup (void)
    离开此套接字加入的IPv6组播组。
bool    IsIpRecvTos (void) const
    询问套接字当前是否在堆栈上传递关于IP类型的服务的信息。
    此方法对应于使用真实网络或BSD套接字的getsockopt()IP_RECVTOS。
bool    IsIpRecvTtl (void) const
    询问套接字当前是否将关于IP_TTL的信息传递到堆栈。
    此方法对应于使用真实网络或BSD套接字的getsockopt()IP_RECVTTL。
bool    IsIpv6RecvHopLimit (void) const
    询问套接字当前是否将关于IPv6 Hop Limit的信息传递到堆栈。
    此方法对应于使用真实网络或BSD套接字的getsockopt()IPV6_RECVHOPLIMIT。
bool    IsIpv6RecvTclass (void) const
    询问套接字当前是否在栈上传递关于IPv6流量类的信息。
    此方法对应于使用真实网络或BSD套接字的getsockopt()IPV6_RECVTCLASS。
bool    IsRecvPktInfo () const
    获取状态指示是否启用/禁用数据包信息到套接字。
virtual int     Listen (void)=0
    监听传入连接。
virtual Ptr< Packet >   Recv (uint32_t maxSize, uint32_t flags)=0
    从套接字读取数据。
Ptr< Packet >   Recv (void)
    从套接字读取单个数据包。
    Recv的重载版本(maxSize,flags),maxSize隐式设置为最大大小的整数,
        并且标志设置为零。
int     Recv (uint8_t *buf, uint32_t size, uint32_t flags)
    从远程主机回收数据(或虚拟数据)。
    提供该方法以便具有在外观上更接近真实网络或BSD套接字的API。
    如果底层数据包携带空(假)数据,则此缓冲区将被归零,直到由返回值指定的长度。
virtual Ptr< Packet >   RecvFrom (uint32_t maxSize, uint32_t flags, Address &fromAddress)=0
    从套接字读取单个数据包并检索发送方地址。
    调用Recv(maxSize,flags),maxSize隐式设置为最大大小整数,标志设置为零。
    此方法具有与Recv()类似的语义,但子类可能希望提供对套接字状态的检查
        因此实现推送到子类。
Ptr< Packet >   RecvFrom (Address &fromAddress)
    从套接字读取单个数据包并检索发送方地址。
    调用RecvFrom(maxSize,flags,fromAddress),maxSize隐式设置为
        最大大小的整数,标志设置为零。
int     RecvFrom (uint8_t *buf, uint32_t size, uint32_t flags, Address &fromAddress)
    从套接字读取单个数据包并检索发送方地址。
    提供该方法以便具有在外观上更接近真实网络或BSD套接字的API。
virtual int     Send (Ptr< Packet > p, uint32_t flags)=0
    将数据(或虚拟数据)发送到远程主机。
int     Send (Ptr< Packet > p)
    将数据(或虚拟数据)发送到远程主机。
    具有设置为零的标志的Send(...,flags)的重载版本。
int     Send (const uint8_t *buf, uint32_t size, uint32_t flags)
    将数据(或虚拟数据)发送到远程主机。
    提供该方法以便具有在外观上更接近真实网络或BSD套接字的API。
virtual int     SendTo (Ptr< Packet > p, uint32_t flags, const Address &toAddress)=0
    发送数据到指定的对等体。
    此方法具有与Send()类似的语义,但子类可能希望提供对套接字状态的检查
        因此实现被推送到子类。
int     SendTo (const uint8_t *buf, uint32_t size, uint32_t flags, const Address &address)
    发送数据到指定的对等体。
    提供该方法以便具有在外观上更接近真实网络或BSD套接字的API。
void    SetAcceptCallback (Callback< bool, Ptr< Socket >, const Address & > connectionRequest, 
                            Callback< void, Ptr< Socket >, const Address & > newConnectionCreated)
    接受来自远程主机的连接请求。
virtual bool    SetAllowBroadcast (bool allowBroadcast)=0
    配置是否允许广播数据报传输。
    此方法对应于使用实际网络或BSD套接字的setsockopt()SO_BROADCAST。 
        如果在套接字上设置,此选项将启用或禁用要传输到广播目标地址的数据包。
void    SetCloseCallbacks (Callback< void, Ptr< Socket > > normalClose, 
                            Callback< void, Ptr< Socket > > errorClose)
    检测套接字recv()事件,如正常关闭或错误。
    对于面向连接的套接字,第一个回调用于表示远程端正常关闭连接,
        第二个回调表示与传统recv()套接字调用可能返回-1(错误)的情况相对应的错误。 
        如连接复位。 对于数据报套接字,这些回调可能永远不会被调用。
void    SetConnectCallback (Callback< void, Ptr< Socket > > connectionSucceeded, 
                             Callback< void, Ptr< Socket > > connectionFailed)
    指定回调以允许调用者确定连接是否成功失败。
void    SetDataSentCallback (Callback< void, Ptr< Socket >, uint32_t > dataSent)
    当数据包已从传输协议(非标准套接字调用)发送时通知应用程序
void    SetIpRecvTos (bool ipv4RecvTos)
    告诉套接字传递关于IP类型的服务的信息在堆栈。
    此方法对应于使用真实网络或BSD套接字的setsockopt()IP_RECVTOS。 
        在我们的实现中,套接字简单地在将包传递到栈之前向该包添加SocketIpTosTag标签。
void    SetIpRecvTtl (bool ipv4RecvTtl)
    告诉套接字向栈上传递关于IP_TTL的信息。
    此方法对应于使用实际网络或BSD套接字的setsockopt()IP_RECVTTL。 
        在我们的实现中,套接字简单地在将包传递到栈之前向该包添加SocketIpTtlTag标签。
void    SetIpTos (uint8_t ipTos)
    手动设置IP服务类型字段。
    此方法对应于使用实际网络或BSD套接字的setsockopt()IP_TOS。 
        此选项仅适用于IPv4。 设置IP TOS还会根据手册页中所述更改套接字优先级。
virtual void    SetIpTtl (uint8_t ipTtl)
    手动设置IP时间到实时字段。
    此方法对应于使用实际网络或BSD套接字的setsockopt()IP_TTL。
virtual void    SetIpv6HopLimit (uint8_t ipHopLimit)
    手动设置IPv6跳数限制。
    此方法对应于使用实际网络或BSD套接字的setsockopt()IPV6_HOPLIMIT。
void    SetIpv6RecvHopLimit (bool ipv6RecvHopLimit)
    告诉套接字传递关于IPv6 Hop Limit的信息。
    此方法对应于使用实际网络或BSD套接字的setsockopt()IPV6_RECVHOPLIMIT。 
        在我们的实现中,套接字简单地在将包传递到栈之前向包添加SocketIpv6HopLimitTag标签。
void    SetIpv6RecvTclass (bool ipv6RecvTclass)
    告诉套接字传递有关IPv6流量类的信息。
    此方法对应于使用实际网络或BSD套接字的setsockopt()IPV6_RECVTCLASS。 
        在我们的实现中,套接字简单地在将包传递到栈之前向该包添加SocketIpv6TclasssTag标签。
void    SetIpv6Tclass (int ipTclass)
    手动设置IPv6流量类字段。
    此方法对应于使用实际网络或BSD套接字的setsockopt()IPV6_TCLASS。
        此选项仅适用于IPv6。 将IPV6_TCLASSS设置为-1会清除该选项,并让套接字使用默认值。
void    SetPriority (uint8_t priority)
    手动设置套接字优先级。
    此方法对应于使用真实网络或BSD套接字的setsockopt()SO_PRIORITY。
void    SetRecvCallback (Callback< void, Ptr< Socket > >)
    在新数据可用时读取应用程序。
    此回调旨在通知在阻塞套接字模型中已阻止数据可用于读取的套接字。
void    SetRecvPktInfo (bool flag)
    启用/禁用接收数据包信息到套接字。
    对于IP_PKTINFO / IP6_PKTINFO。 此方法只能用于Raw套接字和Datagram套接字。 
        不支持Stream套接字。
    方法不区分IPv4和IPv6。 如果启用,则对支持包信息的所有类型的套接字启用
void    SetSendCallback (Callback< void, Ptr< Socket >, uint32_t > sendCb)
    当添加了发送缓冲区中的空间时通知应用程序。
    此回调旨在通知在阻塞套接字模型中已阻塞的套接字,
        该套接字在发送缓冲区中有可用空间,并且可以再次调用Send()。
virtual int     ShutdownRecv (void)=0
    不允许任何进一步的Recv回调。 此方法通常实现为Tcp套接字半关闭。
virtual int     ShutdownSend (void)=0
    不允许任何进一步的发送回调。 此方法通常实现为Tcp套接字半关闭。
static Ptr< Socket >    CreateSocket (Ptr< Node > node, TypeId tid)
    此方法包装由TypeId指定的SocketFactory在给定节点上执行的套接字的创建。
static TypeId   GetTypeId (void)
static uint8_t  IpTos2Priority (uint8_t ipTos)
    返回对应于给定TOS值的优先级。
    此函数在Linux rt_tos2priority函数之后实现。 
        TOS字节的使用最初是由RFC 1349(http://www.ietf.org/rfc/rfc1349.txt)定义的

保护方法:

virtual void    DoDispose (void)
bool    IsManualIpTtl (void) const
    检查套接字是否具有特定的IPv4 TTL集。
bool    IsManualIpv6HopLimit (void) const
    检查套接字是否设置了特定的IPv6跳跃限制。
bool    IsManualIpv6Tclass (void) const
    检查套接字是否具有特定的IPv6 Tclass集。
void    NotifyConnectionFailed (void)
    通过回调(如果设置)通知由于错误连接尚未建立。
bool    NotifyConnectionRequest (const Address &from)
    通过回调(如果设置)通知远程主机正在请求传入连接。
    此函数默认返回true(即,接受所有传入连接)。
         回调(如果设置)可能通过为应拒绝的连接返回零来限制此行为。
void    NotifyConnectionSucceeded (void)
    通过回调(如果设置)通知连接已建立。
void    NotifyDataRecv (void)
    通过回调(如果设置)通知已接收到一些数据。
void    NotifyDataSent (uint32_t size)
    通过回调(如果设置)通知某些数据已发送。
void    NotifyErrorClose (void)
    通过回调(如果设置)通知由于错误连接已关闭。
void    NotifyNewConnectionCreated (Ptr< Socket > socket, const Address &from)
    通过回调(如果设置)通知已创建新连接。
void    NotifyNormalClose (void)
    通过回调(如果设置)通知连接已关闭。
void    NotifySend (uint32_t spaceAvailable)
    通过回调(如果设置)通知某些数据已发送。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容

  • 1. Object-c的类可以多重继承么?可以实现多个接口么?Category是什么?重写一个类的方式用继承好还是...
    Charls丶阅读 746评论 0 0
  • 转:http://www.cocoachina.com/programmer/20151019/13746.htm...
    Style_伟阅读 1,301评论 0 3
  • 之前看了很多面试题,感觉要不是不够就是过于冗余,于是我将网上的一些面试题进行了删减和重排,现在分享给大家。(题...
    Job_Yang阅读 12,103评论 12 143
  • 自己都结婚很多年了,婚前财产是不是已经变成了夫妻共同财产了?很多人都会有这种疑问,因为对于结婚很久的人来说,夫妻两...
    538a902176e9阅读 674评论 0 0
  • 坚持原创分享第54天 今天看到女儿国学馆的书,上面的《小儿语 》特别有意思,以前只知道《三字经》、《第子规...
    我是一只没有脚的鸟阅读 1,308评论 0 1