void YUVRotate90(BYTE *des,BYTE *src,int width,int height)
{
int i=0,j=0,n=0;
int hw=width/2,hh=height/2;
#if 0
for(j=width;j>0;j--)
{
for(i=0;i<height;i++)
{
des[n++] = src[width*i+j];
}
}
#else
for(j=width;j>0;j--)
{
for(i=height;i>0;i--)
{
des[n++] = src[width*i-j];
}
}
#endif
#if 0
unsigned char *ptmp = src+width*height;
for(j=hw;j>0;j--)
{
for(i=0;i<hh;i++)
{
des[n++] = ptmp[hw*i+j];
}
}
ptmp = src+width*height*5/4;
for(j=hw;j>0;j--)
{
for(i=0;i<hh;i++)
{
des[n++] = ptmp[hw*i+j];
}
}
#else
unsigned char *ptmp = src+width*height;
unsigned char *ptmp2 = src+width*height*5/4;
for(j=hw;j>0;j--)
{
for(i=hh;i>0;i--)
{
des[n] = ptmp[hw*i-j];
des[n+hw*hh] = ptmp2[hw*i-j];
n++;
}
}
#endif
}
--------------------------------------------------------------------------------
基于消息的SOCKET最大的发送包大小为SO_MAX_MSG_SIZE(默认为65535, 即64K), 超过此值,SendTo函数将发送失败,失败信息为 WSAEMSGSIZE.但报文段尺寸大于MTU,需要进行IP分片传输,同样这样在接收方,IP层需要组合包操作,并耗内存,一般来说要控制报文大小在小于或等于MTU的范围内,避开拆包和组包过程.
在TCP协议中,大的数据实际上可能经过两次分割:第一次是TCP协议会把数据分段已装入一个TCP报文中,由于TCP报文将要被放入IP包中,所以每个分段<SO_MAX_MSG_SIZE; 第二次是IP包经过某物理时,如果IP包>该网络的MTU,那么IP协议会将该IP包切片;
由于UDP是无连接协议,且运行在IP之上,UDP每次送的数据<SO_MAX_MSG_SIZE
各种网络环境对MTU的设置:
Internet, 路由器可能会将MTU设为不同的值路由器可能会将MTU设为不同的值;
PPPoE/ADSL:1492
Dial Up/Modem:576
以太网(Ethernet)数据帧的长度必须在46-1500字节之间,这是由以太网的物理特性决定的.
这个1500字节被称为链路层的MTU(最大传输单元). 根据四层网络拓扑结构, 扣除IP层中的包装字段(IP数据报的首部为20字节),所以IP数据报的数据区长度最大为1480字节, 而这个1480字节就是用来放TCP传来的TCP报文段或UDP传来的UDP数据报的;另外考虑传输层UDP的首部占用8个字节,所以UDP数据报的数据 区最大长度为1472字节.