组播又称为多播,相对于广播更受程序员们的欢迎,但是介于很多平台对组播的支持不是很好的缘故,很多程序员像我一样不得不放弃组播,选择广播。大家都知道广播是无法跨路由的,只有在同一广播域内的机器才能收到该广播域内来自其他其他机器的广播包。广播还有一个很大的缺点就是不做过滤,同一广播域内的所有机器都会收到广播包,不管机器是否愿意。这对不关心该广播包的机器而言就是垃圾数据,无形中造成了网络拥塞。这也是很多程序员实在不想采用广播的原因。然而多播就可爱多了,它不仅可以跨路由,而且只对加入了相同组播域的机器发数据。也就是说,如果哪台机器关心来自某一组播域的数据,它必须主动加入该组播域,执行加入指令以后,系统会向路由发送一条加入请求,路由会在该组播域上维护新加入机器的套接字(文件描述符),当路由收到其他机器发到该组播域的数据以后,会依次转发到已经加入改组播域的所有套接字(文件描述符)中去。 阅读全文
默认情况下,系统为我们分配的套接字(文件描述符)是阻塞的,我们使用阻塞的套接字(文件描述符)执行connect、read、write、accept等函数的话,会阻塞一段系统默认的超时时间,当然这个超时时间可以通过setsockopt函数的相关参数进行设置,但不论如何都会阻塞一段这个指定的时间。如果您的程序是单线程,或者该线程需要执行多任务,一旦阻塞这就不能执行其他任务了,这并不是我们希望看到的,那么有没有办法让基于该套接字(文件描述符)的动作(如connect)立刻返回呢?答案是肯定的。
阅读全文
使用select函数也才一年多时间,也许对select的理解还不是很深刻,所以不敢称详解,我只能简单的描述一下自己对select函数功能的理解和调用方式,我想这些对于初次使用select函数的人来说够用了,如有说得不恰当的地方,还请大家批评指正。
首先我们需要解答一些疑惑。为什么要使用select函数?
比如你有一个服务器程序,维护着N多个TCP连接,你如何去判断这些TCP连接上有数据传送过来了呢?最傻瓜的办法就是隔一定时间去循环读一次所有TCP连接对应的文件描述符,如果read返回正值则说明有数据过来。这样做未免也太傻瓜太浪费CPU了一点,无法做到及时的检测到结果,还好,select函数可以帮我们自动检测指定的文件描述符是否有数据可读,即已经建立好的连接那端有新的数据过来或者有新的尚未建立好的连接请求过来。 阅读全文