社区
网络通信/分布式开发
帖子详情
serversocket向ClientSocket发数据为何会丢包?
刘大黑
2002-11-01 12:49:57
服务器socketserver端向客户端clientserver发送数据,如果服务器端每个数据包为2k连续发送,客户端采用阻塞方式监听,就会产生有的数据包监听不到,在服务器端加入一个小的延时就可以了,服务器端用的是阻塞方式的(经测试所有的包都已经发送成功了),客户端监听到只有不到一半
请问为何要加入延时?有没有好办法?
谢谢了
...全文
163
12
打赏
收藏
serversocket向ClientSocket发数据为何会丢包?
服务器socketserver端向客户端clientserver发送数据,如果服务器端每个数据包为2k连续发送,客户端采用阻塞方式监听,就会产生有的数据包监听不到,在服务器端加入一个小的延时就可以了,服务器端用的是阻塞方式的(经测试所有的包都已经发送成功了),客户端监听到只有不到一半 请问为何要加入延时?有没有好办法? 谢谢了
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
12 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
刘大黑
2002-11-05
打赏
举报
回复
问题已经解决了,主要在发送的时候判断一下sendbuf的返回值与程序发送的字节数是否相等就可以了,如果不相等就重复发送,谢谢大家!
findya
2002-11-05
打赏
举报
回复
一次传送的字节数太大?改成1k的应该可以减小延迟
agang007
2002-11-05
打赏
举报
回复
请问下贴主,怎么实现了sendbuf来收发数据的?最好提供些源码!谢谢了!
agangemail@btamail.net.cn
猛禽
2002-11-05
打赏
举报
回复
这种方法在实际应用中不够可靠,在多连接并发的大量数据传输中有可能出错.
halfdream
2002-11-04
打赏
举报
回复
>>那你认为问题出现在哪里?
>> 我的服务端和客户端都采用阻塞方式
>>用服务器端用sendbuf方法发送到缓冲区内返回实际写入的字节数,这些数据
>>发送到客户端接收事件中确实是丢失了
客户端接收事件??在阻塞方式中有这东东吗?
猛禽
2002-11-04
打赏
举报
回复
呵,如果在阻塞方式下用SendBuf之类的确会出问题,看看帮助吧,在阻塞方式下要用TWinSocketStream,不过直接用它不太方便,我对它作了一点增强,有兴趣试试:
http://raptorz.myetang.com/mentals/share/dev/msocket.htm
agang007
2002-11-04
打赏
举报
回复
请问下贴主,怎么实现了sendbuf来收发数据的?最好提供些源码!谢谢了!
ZhuJunfeng
2002-11-04
打赏
举报
回复
应该是你自己的问题,没有发出去,或者接受到了但被忽略了
flinming
2002-11-02
打赏
举报
回复
首先,我觉得你应该确定是否是你服务器有没有发送出去,是不是发太快了!你应该判断一下,每次发送的结果是不是2k,如果发送出去的话,在发送下面的
Sendbuf返回值可以判断!
dulcet
2002-11-01
打赏
举报
回复
用TWinSocketStream
刘大黑
2002-11-01
打赏
举报
回复
那你认为问题出现在哪里?
我的服务端和客户端都采用阻塞方式
用服务器端用sendbuf方法发送到缓冲区内返回实际写入的字节数,这些数据
发送到客户端接收事件中确实是丢失了
猛禽
2002-11-01
打赏
举报
回复
SERVERSOCKET/CLIENTSOCKET是用TCP的,用阻塞方式不可能出现这种情况,当客户端来不及收时会出现缓冲区溢出的异常,非阻塞方式也会出现错误消息。
一般只有UDP才会丢包。
Java 内核原理入门到实战(大神必经之路)
主要特性Java 语言是简单的:Java 语言的语法与 C 语言和 C++ 语言很接近,使得大多数程序员很容易学习和使用。另一方面,Java 丢弃了 C++ 中很少使用的、很难理解的、令人迷惑的那些特性,如操作符重载、多继承、自动的强制类型转换。特别地,Java 语言不使用指针,而是引用。并提供了自动分配和回收内存空间,使得程序员不必为内存管理而担忧。Java 语言是面向对象的:Java 语言提供类、接口和继承等面向对象的特性,为了简单起见,只支持类之间的单继承,但支持接口之间的多继承,并支持类与接口之间的实现机制(关键字为 implements)。Java 语言全面支持动态绑定,而 C++语言只对虚函数使用动态绑定。总之,Java语言是一个纯的面向对象程序设计语言。Java语言是分布式的:Java 语言支持 Internet 应用的开
发
,在基本的 Java 应用编程接口中有一个网络应用编程接口(java net),它提供了用于网络应用编程的类库,包括 URL、URLConnection、
Socket
、
Server
Socket
等。Java 的 RMI(远程方法激活)机制也是开
发
分布式应用的重要手段。Java 语言是健壮的:Java 的强类型机制、异常处理、垃圾的自动收集等是 Java 程序健壮性的重要保证。对指针的丢弃是 Java 的明智选择。Java 的安全检查机制使得 Java 更具健壮性。Java语言是安全的:Java通常被用在网络环境中,为此,Java 提供了一个安全机制以防恶意代码的攻击。除了Java 语言具有的许多安全特性以外,Java 对通过网络下载的类具有一个安全防范机制(类 ClassLoader),如分配不同的名字空间以防替代本地的同名类、字节代码检查,并提供安全管理机制(类 SecurityManager)让 Java 应用设置安全哨兵。Java 语言是体系结构中立的:Java 程序(后缀为 java 的文件)在 Java 平台上被编译为体系结构中立的字节码格式(后缀为 class 的文件),然后可以在实现这个 Java 平台的任何系统中运行。这种途径适合于异构的网络环境和软件的分
发
。Java 语言是可移植的:这种可移植性来源于体系结构中立性,另外,Java 还严格规定了各个基本
数据
类型的长度。Java 系统本身也具有很强的可移植性,Java 编译器是用 Java 实现的,Java 的运行环境是用 ANSI C 实现的。Java 语言是解释型的:如前所述,Java 程序在 Java 平台上被编译为字节码格式,然后可以在实现这个 Java 平台的任何系统中运行。在运行时,Java 平台中的 Java 解释器对这些字节码进行解释执行,执行过程中需要的类在联接阶段被载入到运行环境中。Java 是高性能的:与那些解释型的高级脚本语言相比,Java 的确是高性能的。事实上,Java 的运行速度随着 JIT(Just-In-Time)编译器技术的
发
展越来越接近于 C++。Java 语言是多线程的:在 Java 语言中,线程是一种特殊的对象,它必须由 Thread 类或其子(孙)类来创建。通常有两种方法来创建线程:其一,使用型构为 Thread(Runnable) 的构造子类将一个实现了 Runnable 接口的对象包装成一个线程,其二,从 Thread 类派生出子类并重写 run 方法,使用该子类创建的对象即为线程。值得注意的是 Thread 类已经实现了 Runnable 接口,因此,任何一个线程均有它的 run 方法,而 run 方法中包含了线程所要运行的代码。线程的活动由一组方法来控制。Java 语言支持多个线程的同时执行,并提供多线程之间的同步机制(关键字为 synchronized)。Java 语言是动态的:Java 语言的设计目标之一是适应于动态变化的环境。Java 程序需要的类能够动态地被载入到运行环境,也可以通过网络来载入所需要的类。这也有利于软件的升级。另外,Java 中的类有一个运行时刻的表示,能进行运行时刻的类型检查。
Doubango RTP包传输使用UDT可靠传输协议,解决RTP
丢包
问题
使用SIP做过VOIP通话的同学,肯定被RTP
丢包
弄的焦头烂额,必定尝试过不少的办法,比方: 1、
丢包
重传(NACK) 2、前向纠错(FEC) 3、丢帧处理 但效果往往不尽如人意,那有没有一劳永逸的方法?确实,网络
发
展到现在,家庭带宽随随便便都是百兆的今天,为什么还有让人困扰不已的
丢包
问题?为何不换成TCP传输,假如延时容许的情况下,UDT就是为了解决这个问题的。 UDT建立于UDP
Socket
基础六:基于
数据
报套接字的网络程序(udp
丢包
测试)
Socket
基础五:基于
数据
报套接字的网络程序(udp
丢包
测试) 作者:刘磊 2020.4.27 参考书目:《Windows网络编程》刘琰等著 一、功能函数 1、int udp_server_fun_packetloss(
SOCKET
s){ int iResult = 0; int count = 0; struct sockaddr_in cliaddr; int addrlen = sizeof(sockaddr_in); char recvline[MAXLINE]; do
Windows下
丢包
率测试源码
PacketLossTest
Client
: PacketLossTest
Client
.cpp: // PacketLossTest
Client
.cpp : 定义控制台应用程序的入口点。 // #include "stdafx.h" #include "
Socket
Frame.h" int udp_
client
_fun_packetloss(int times,
SOCKET
s);
Socket
Receive
数据
一次性接收不全的问题
Socket
Receive
数据
一次性接收不全的问题
网络通信/分布式开发
1,593
社区成员
32,964
社区内容
发帖
与我相关
我的任务
网络通信/分布式开发
Delphi 网络通信/分布式开发
复制链接
扫一扫
分享
社区描述
Delphi 网络通信/分布式开发
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章