`
ruby_java
  • 浏览: 23469 次
  • 性别: Icon_minigender_1
  • 来自: ZZ
社区版块
存档分类
最新评论

为什么有些有些类的方法无法在API手册中找到?

    博客分类:
  • Ruby
阅读更多
在看ruby api文档的时候总是觉得它的API文档怪怪的,不太适应。

就说API的组织形式吧,都不太明白每个窗口的含义。比如在标准库API文档里边,右边的窗口都不同步,比如点某个类,右上角的method中并不是该类的所有方法,这点就不太使用。


最近在查一个socket编程的问题,

server = TCPServer.new(PORT)
while ( session = server.accept )

    mystr=session.recv(20)


发现使用recv方法接收指定大小的内容时会发生错误。然后在API手册中找不到这个recv方法究竟是哪个类定义的。

最后在源码socket.c中发现有这么一段:
    rb_define_method(rb_cBasicSocket, "recv", bsock_recv, -1);
    rb_define_method(rb_cBasicSocket, "recv_nonblock", bsock_recv_nonblock, -1);



我对源码不太了解,但是推测应该是basicsocket中定义的recv方法,可是遍历整个socket编程类,也没有在API文档中发现这个方法的说明。



请问究竟是我查找API手册的方法不对,没有找到位置呢,还是API手册本身就没有完全覆盖所有方法?
分享到:
评论
6 楼 kaven 2008-03-11  
rdoc生成的帮助文件已经很好了,如果不够,就去
看test case,ruby就是这点好,源码和test是放在一起的。
ruby的设计是以开发人员导向的,我还没有见过比这个更加友好的工具了
5 楼 ruby_java 2008-03-10  
如果API的功能都要自己悟
哪学习曲线该多么高
4 楼 foxgst 2008-03-06  
同感,API文档似乎很简洁,便于查找,但层次不太清晰,而且用法也说得不是太明白,需要悟的地方太多...这难道是初学者才遇到的问题吗?
3 楼 ruby_java 2008-03-02  
你看到的还是
basicsocket.recv_nonblock(maxlen) => mesg
basicsocket.recv_nonblock(maxlen, flags) => mesg

这2个函数的解释
2 楼 neodoxy 2008-03-01  
ri BasicSocket#recv

---------------------------------------------- BasicSocket#recv_nonblock
     basicsocket.recv_nonblock(maxlen) => mesg
     basicsocket.recv_nonblock(maxlen, flags) => mesg
------------------------------------------------------------------------
     Receives up to _maxlen_ bytes from +socket+ using recvfrom(2) after
     O_NONBLOCK is set for the underlying file descriptor. _flags_ is
     zero or more of the +MSG_+ options. The result, _mesg_, is the data
     received.

     When recvfrom(2) returns 0, Socket#recv_nonblock returns an empty
     string as data. The meaning depends on the socket: EOF on TCP,
     empty packet on UDP, etc.

     Parameters
     *   +maxlen+ - the number of bytes to receive from the socket

     *   +flags+ - zero or more of the +MSG_+ options

     Example
          serv = TCPServer.new("127.0.0.1", 0)
          af, port, host, addr = serv.addr
          c = TCPSocket.new(addr, port)
          s = serv.accept
          c.send "aaa", 0
          IO.select([s])
          p s.recv_nonblock(10) #=> "aaa"

     Refer to Socket#recvfrom for the exceptions that may be thrown if
     the call to _recv_nonblock_ fails.

     BasicSocket#recv_nonblock may raise any error corresponding to
     recvfrom(2) failure, including Errno::EAGAIN.

     See
     *   Socket#recvfrom

------------------------------------------------------------------------------------

1 楼 ruby_java 2008-03-01  
引用
BasicSocket
表示套接字的抽象类。具体的套接字操作需要在子类加以定义。比如说internet domain stream socket的话,就要使用TCPSocket。

超类:
IO
类方法:
BasicSocket.do_not_reverse_lookup
BasicSocket.do_not_reverse_lookup = bool
若该值为真,则不会进行从地址到主机名的逆向解析。默认值是false。该设定的影响面非常大。

它会影响下列方法的运作。

BasicSocket#recv, IPSocket#recvfrom, UNIXSocket#recvfrom, Socket#recvfrom, IPSocket#addr, IPSocket#peeraddr, Socket.getaddrinfo

例:

require 'socket'

p TCPSocket.new('localhost', 'telnet').addr
TCPSocket.do_not_reverse_lookup = true
p TCPSocket.new('localhost', 'telnet').addr

=> ["AF_INET", 2253, "localhost", "127.0.0.1"]
   ["AF_INET", 2254, "127.0.0.1", "127.0.0.1"]

BasicSocket.for_fd(fd) ((<ruby 1.7 feature>))
为文件描述符fd生成一个新套接字。

ruby 1.7 特性: 该方法从 Socket类移动到该类中。这样就可以在任意套接字fd中生成相对应的套接字类了。

方法:
getpeername
获取对方的套接字信息。返回打包sockaddr结构体后得到的字符串。请参考getpeername(2)。

getsockname
获取套接字信息。返回打包sockaddr结构体后得到的字符串。请参考getsockname(2)。

getsockopt(level, optname)
获取套接字选项。请参考getsockopt(2)。将获取的选项数据打包成字符串后,返回该字符串。

recv(len[, flags])
从套接字获取数据,并以字符串形式将其返回。len规定了获取信息的最大长度。关于flags的具体细节,请参考recv(2)。flags的默认值是0。指定flags时使用的常数都被定义在Socket类中。(例: Socket::SO_LINGER)

send(mesg, flags[, to])
通过套接字发送数据。关于flags的具体细节,请参考send(2)。若套接字尚未进行连接时,则必须指定发送目的地to。返回实际发送数据的大小。

to中必须是将套接字地址结构体打包后得到的字符串。

若发送数据失败,则引发Errno::EXXX异常。

setsockopt(level, optname, optval)
设定套接字选项。请参考setsockopt(2)。

shutdown([how])
结束套接字的连接。若how为0,则只停止信息的接收;若为1则只停止信息的发送;若how为2,则停止信息的发送和接受全过程。how的缺省值就是2。请参考shutdown(2)。



这是我在网上找到的一个说明,为什么ruby本身的文档反而找不到这么详细的呢

相关推荐

    《Windows CE API手册》by Blitz Force团队

    《Windows CE API手册》是Blitz Force团队继 Xarm和ROS开发系统之后之后又一重要作品。本手册收录并翻译了 MSDN Library for Visual Studio 2008 中超过2000 个API函数和宏的资料信息。分为:系统函数、COM函数、...

    jquery中文api手册下载

    为方便自己也为方便所有爱好jQuery的朋友,本人将CHM重新整理,并和jQuery中文API的整理者 Shawphy 同步更新本CHM手册,以便大家能及时了解其最新资讯!由于本人精力有限,难免出现差错,请谅解并告知 Email ! 本...

    Windows CE API 手册 v2.0

    《Windows CE API手册》v2.0 说明 Blitz Force-加百力的个人标志:带大卫星的黑鹰 《Windows CE API手册》是Blitz Force团队继 Xarm和ROS开发系统之后之后又一重要作品。本手册收录并翻译了 MSDN Library for ...

    Windows CE API 手册 v2.0,非常不错的wince手册

    《Windows CE API手册》是Blitz Force团队继 Xarm和ROS开发系统之后之后又一重要作品。本手册收录并翻译了 MSDN Library for Visual Studio 2008 中超过2000 个API函数和宏的资料信息。分为:系统函数、COM函数、...

    JavaApi中文参考手册.zip

    JavaApi中文参考手册,找了好久终于找到了一个可以用的中文离线文档

    opencv3.0 api手册

    还有java版的,找到发。

    D3.js API 中文手册

    非常实用的D3 的api手册,找了好长时间才找到。比一直在线查看强很多。

    U8API开发手册(C#版).doc

    在“开始”-&gt;“程序”-&gt;“用友ERP-U8”-&gt;“UAP”目录下找到“U8API资源管理器”,单击,登录,进入“U8API资源管理器”。在左侧 “U8API” 树形节点下,找到某某模块,如“库存管理”模块(可以看到下面列有很多个...

    Linux内核API查询手册(html格式)

    找了好久都没找到一个像样的查询Linux内核的方法 网站上下的好多都是假的 不能用的 本来放弃了 不经意间发现 内核原来可以自己生成查询文档 在源码目录下 执行:make htmldocs就可以生成查询文档了 虽然简陋点 凑合...

    JQuery1.5 API 中文速查手册

    JQuery1.5 API 中文速查手册,找了很久才找到的。是中文的,有需要的朋友就下载吧

    Elasticsearch5.x Java API手册

    该资源为Elasticsearch5.x版本的java操作API手册,基本方法都可以从里面找到,有需要的程序猿可自行下载;

    javascript api参考手册英文版

    在网上想找个javascript api参考手册,结果找到的都是jscript版本。 偶然找到了一个html格式的英文版本javascript api参考手册,希望对大家有用。 注意:此手册是英文版

    JDK6API中文参考手册

    JDK6API中文参考手册 中文版 找了很久才找到的

    WinCE_API_中文版

    《Windows CE API手册》是Blitz Force团队继 Xarm和ROS开发系统之后之后又一重要作品。本手册收录并翻译了 MSDN Library for Visual Studio 2008 中超过2000 个API函数和宏的资料信息。分为:系统函数、COM函数、...

    JPA使用手册+API+JAR

    这是我第一次上传资料,因为我的积分不多了!呵呵..... 这些资料都是我在做项目的时候用到过的,找了很久才找到!

    Java + JDK6开发手册 + JavaAPI中文文档,帮助学习java

    可以说是很全面的学习包了,虽然是JDK6的,但是跟最新的也几乎没什么区别,放心去学。 学会使用JDK手册,就是你真正学习java的第一步,相当于你有了一本java宝典,冲吧,一边查字典,一边学习,这样学习效果会更好。...

    自己制作的最全的介绍API分类的手册

    文件介绍了11000个API或常量宏类别(实际API函数有大几千), 通过这个手册可以很方便在VC Include下或者VC帮助系统找到所需类别的API函数。 希望对大家有用,

    J2EE1.5 api 英文版手册

    J2EE1.5 api 英文版手册 这个是英文版的JAVA EE 手册,格式为CHM的,目前中文版的没找到

Global site tag (gtag.js) - Google Analytics