UDP网络传输丢包分析

  UDP是面向无连接传输,这个大家都清楚,但有时候在网络条件良好,线程效率良好的情况下,任然会出现丢包,这时候就需要多注意一个很重要的地方:Socket接受缓冲区大小。

 

  Socket接受缓冲区大多数默认是4K,有的也会默认为8K,当数据流量较大的时候,这个缓冲区就需要设置的大一些,最好为64K,可以根据具体情况修改。

 

/* 获取发送缓冲区大小 */

int sendbufsize;

int size;

if ( getsockopt( sockfd, SOL_SOCKET, SO_SNDBUF, (char *)&sendbufsize, &size) == 0 )

       printf( “senbufsize = %d/n”, sendbufsize );

/* 设置发送缓冲区大小 */

recvbufsize = 65536;

if ( setsockopt( sockfd, SOL_SOCKET, SO_SNDBUF, (char *)&sendbufsize, size) == 0 )

       printf( “sendbufsize = %d/n”, sendbufsize );

 

/* 获取接受缓冲区大小 */

int recvbufsize;

int size;

if ( getsockopt( sockfd, SOL_SOCKET, SO_RCVBUF, (char *)& recvbufsize, &size) == 0 )

       printf( “recvbufsize = %d/n”, recvbufsize);

/* 设置接受缓冲区大小 */

recvbufsize = 65536;

if ( setsockopt( sockfd, SOL_SOCKET, SO_RCVBUF, (char *)& recvbufsize, size) == 0 )

       printf( “recvbufsize = %d/n”, recvbufsize);

 

  除此之外,环形队列也需要注意,控制环形队列的头指针位置和尾指针位置,可以使两个线程同时操作环形队列而不用互斥体控制,这样可以提高线程运行效率。控制好headtail的值,就能很好的发挥环形队列的作用。

SBuf       buffer[1024];

int           head;

int           tail;

  需要在边界处多加注意(tail + 1 == head)是否成立的问题,还有在分别修改headtail时,最好在操作完buffer后再进行修改,这样就可以一定限度的避免使用互斥体进行保护。

  最后需要优化的就是线程的效率了,这个根据具体情况而定。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值