对应linux中的实现
struct tcphdr {
__be16 source; //16位源端口号
__be16 dest; //16位目的端口号
__be32 seq; //此次发送的数据在整个报文段中的起始字节数。为了安全起见,它的初始值是一个随机生成的数,它到达2的32次方-1后又从零开始。
__be32 ack_seq; //是下一个期望接收的字节,确认序号应当是上次已成功接收的序号+1,只有ack标志为1时确认序号字段才有效。一旦一个连接已经建立了,ack总是=1
#if defined(__LITTLE_ENDIAN_BITFIELD) //小端
__u16 res1:, // 保留位
doff:, //tcp头部长度,指明了在tcp头部中包含了多少个32位的字。由于options域的长度是可变的,所以整个tcp头部的长度也是变化的.
fin:, //发端完成发送任务
syn:, //同步序号用来发起一个连接
rst:, //重建连接
psh:, //接收方应该尽快将这个报文段交给应用层
ack:, //一旦一个连接已经建立了,ack总是=1
urg:, //紧急指针有效
ece:,
cwr:;
#elif defined(__BIG_ENDIAN_BITFIELD)
__u16 doff:,
res1:,
cwr:,
ece:,
urg:,
ack:,
psh:,
rst:,
syn:,
fin:;
#else
#error "Adjust your <asm/byteorder.h> defines"
#endif
__be16 window; //窗口大小,单位字节数,指接收端正期望接受的字节,16bit,故窗口大小最大为16bit=1111 1111 1111 1111(二进制)=65535(十进制)字节
__sum16 check; //校验和校验的是整个tcp报文段,包括tcp首部和tcp数据,这是一个强制性的字段,一定是由发端计算和存储,并由收端进行验证。
__be16 urg_ptr;
};