网络编程-TCP、UDP通信:recv和recvfrom同时阻塞

问题描述

TCP、UDP通信:recv和recvfrom同时阻塞

当客户端登录时,创建一个线程接收服务器的消息(比如,密码错误时,服务器会发送消息告知客户端密码错误)。

DWORD Client_Thread()

{
....

 recv();   //接收服务器的消息,如密码是否正确,或者某一个客户端的地址和端口号等

 ....

}

服务器为每一个客户端创建一个线程(该线程可以判断密码是否正确)。

DWORD Server_Thread()

{
...

recv();  //接收客户端的消息,如账号和密码,请求朋友的地址和端口号
...
...

send(); //发送相关信息给客户端,如朋友的地址和端口号
...
}

现在的情况是,客户端如果想跟他的其中一个好友聊天,那么就向服务器发送消息,
要求服务器返回该好友的ip地址和端口号,同时客户端又新建一个线程接收好友的信息。

DWORD    Chat_Thread()

{

while(1)
{
    revcfrom(); //接收好友的信息
}

}

客户端发送消息给好友使用UDP协议。

void Send()

{
...
sendto(); //发送信息给好友

}

现在的问题是,客户端的Cient_Thread线程函数中的recv和Chat_Thread线程函数中的recvfrom同时处于阻塞状态。 当朋友发送信息时,recv收到了信息,而recvfrom没有收到。 我想要的是recvfrom收到,recv不接收。有什么办法可以实现这样的功能吗?或者怎样改?谢谢!!!!

解决方案

我看你混淆了recv和recvfrom的用法,recvfrom,recvmsg,sendto,sendmsg这几个API是给UDP用的, recv,send是给TCP用的,你得分清楚。

时间: 2024-08-02 17:50:49

网络编程-TCP、UDP通信:recv和recvfrom同时阻塞的相关文章

Java网络编程:UDP DatagramSocket

DatagramSocket类是java通过UDP通信的途径.UDP仍位于IP层的上面. 你可以用DatagramSocket类发送和接收UDP数据包. UDP 和TCP UDP工作方式和TCP有点不同.当你通过TCP发送数据时,你先要创建连接.一旦TCP连接建立了,TCP会保证你的数据传递到对端,否则它将告诉你已发生的错误. 仅仅用UDP来发送数据包(datagrams)到网络间的某个IP地址.你不能保证数据会不会到达.你也不能保证UDP数据包到达接收方的指令.这意味着UDP比TCP有更少的协

UNIX网络编程:UDP 中的外出接口的确定

已连接UDP套接字还可用来确定用于特定目的地的外出接口.这是由connect函数应用到UDP套接字时的一个副作用造成的:内核选择本地IP地址.这个本地IP地址通过为目的IP地址搜索路由表得到外出接口,然后选用该接口的主IP地址而选定. 注意:getsockname函数调用的位置. #include <unistd.h> #include <sys/types.h> #include <sys/socket.h> #include <netinet/in.h>

UNIX网络编程:UDP缺乏流量控制(改进版)

现在我们查看无任何流量控制的UDP对数据报传输的影响.首先我们把dg_cli函数修改为发送固定数目的数据报,并不再从标准输入读.如下,它写2000个1400字节大小的UDP数据报给服务器. 客户端程序cli.c: #include <unistd.h> #include <sys/types.h> #include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> #inc

PC电脑和Android模拟器访问及模拟器之间tcp/udp通信

Android系统默认只能通过IP(10.0.2.2)单向访问PC电脑,而PC电脑不能通过IP来直接访问Android模拟器系统.要想实现PC电脑和Android模拟器系统以及Android模拟器之间相互通信必须借助端口重定向(redir)来实现. 先说说端口重定向所需要的telnet客户端安装: windows: 安装telnet客户端.如果没有安装,可以在windows程序管理中的打开或关闭系统功能下找到telnet客户端菜单项来启用telnet客户端功能. linux: 自行安装telne

UNIX网络编程:UDP 的connect函数(改进版)

上一篇我们提到,除非套接字已连接,否则异步错误是不会返回到UDP套接字的.我们确实可以给UDP套接字调用connect,然而这样做的结果却与TCP连接大相径庭:没有三次握手.内核只是检查是否存在立即可知的错误(例如一个显然不可达的目的地),记录对端的IP地址和端口号(取自传递给connect的套接字地址结构),然后立即返回到调用进程. 有了这个能力后,我们必须区分: (1)未连接UDP套接字,新创建UDP套接字默认如此: (2)已连接UDP套接字,对UDP套接字调用connect的结果. 对于已

UNIX网络编程:UDP编程模型简介

使用UDP编写的一些常见得应用程序有:DNS(域名系统),NFS(网络文件系统)和SNMP(简单网络管理协议). 客户不与服务器建立连接,而是只管使用sendto函数给服务器发送数据报,其中必须指定目的地(即服务器)的地址作为参数.类似的,服务器不接受来自客户的连接,而是只管调用recvfrom函数,等待来自某个客户的数据到达.recvfrom将与所接收的数据报一道返回客户的协议地址,因此服务器可以把响应发送给正确的客户. 对于UDP,写一个长度为0的数据报时可行的.在UDP情况下,这会形成一个

C#开发之Socket网络编程TCP/IP层次模型、端口及报文等探讨_C#教程

1.TCP/IP层次模型 当然这里我们只讨论重要的四层 01,应用层(Application):应用层是个很广泛的概念,有一些基本相同的系统级TCP/IP应用以及应用协议,也有许多的企业应用和互联网应用.http协议在应用层运行. 02,传输层(Tanspot):传输层包括UDP和TCP,UDP几乎不对报文进行检查,而TCP提供传输保证. 03,网络层(Netwok):网络层协议由一系列协议组成,包括ICMP.IGMP.RIP.OSPF.IP(v4,v6)等. 04,链路层(Link):又称为物

python网络编程之UDP通信实例(含服务器端、客户端、UDP广播例子)_python

UDP广泛应用于需要相互传输数据的网络应用中,如QQ使用的就是UDP协议.在网络质量不好的情况下,使用UDP协议时丢包现象十分严重,但UDP占用资源少,处理速度快,UDP依然是传输数据时常用的协议. 下面是用python实现UDP服务器的代码: 复制代码 代码如下: #!/usr/bin/env pythonimport socketaddress=('127.0.0.1',10000)s=socket.socket(socket.AF_INET,socket.SOCK_DGRAM)s.bind

UNIX网络编程:UDP回射服务器程序(初级版本)及漏洞分析

该函数提供的是一个迭代服务器,而不是像TCP服务器那样可以提供一个并发服务器.其中没有对fork的调用,因此单个服务器进程就得处理所有客户.一般来说,大多数TCP服务器是并发的,而大多数UDP服务器是迭代的. 对于本套接字,UDP层中隐含有排队发生.事实上每个UDP套接字都有一个接收缓冲区,到达该套接字的每个数据报都进入这个套接字接收缓冲区.当进程调用recvfrom时,缓冲区中的下一个数据报以FIFO(先入先出)顺序返回给进程. 服务器程序: #include<stdio.h> #inclu