答:
7层模型(①物理层:二进制比特流传输,②数据链路层:相邻结点的可靠传输,③网络层:寻址和路由选择,④传输层:端到端的可靠传输,⑤会话层:主机之间会话管理,⑥表示层:数据表示,加密与压缩,⑦应用层:提供各种网络应用接口)
5层模型(①物理层,②数据链路层,③网络层,④传输层,⑦应用层)
4层模型(①网络接口和物理层或网络访问层:ip地址与物理地址的映射(MAC),以及将上一次的ip报文封装成帧,转换成二进制比特流传输,③网络层,④传输层,⑦应用层)
网络接口和物理层:网络访问层
答:MAC不变,IP改变
答:MTU(最大传输单元):物理接口提供给上层最大一次传输数据的大小,规定了数据链路层所能传送最大数据长度,最大为1500bytes。MSS(最大报文长度):TCP提交给IP层最大分段大小,指TCP报文所允许传送数据部分最大长度,不包含TCP头,MSS是TCP来限制应用层最大发送字节数,若MTU=1500,则MSS最大为1460bytes
答:TCP(传输控制协议):提供面向连接的,一对一的,可靠数据传输协议。UDP(用户数据报协议):提供无连接的,不可靠的,尽力的传输协议(效率高)
答:相同点:是同属于传输层的协议。不同点:
TCP:
UDP:
答:IPv4:采用4个字节的无符号整数,共32bit来存储IP地址。IPv6:采用16字节的无符号整数,共128bit来存储IP地址
答:A类:0.0.0.0~127.255.255.255
B类:128.0.0.0~191.255.255.255
C类:192.0.0.0~223.255.255.255
D类:224.0.0.0~239.255.255.255
E类:240.0.0.0~255.255.255.255
ABC类为基本类,IP地址分配给主机使用,D类不表示网络,用于特殊用途,例如:组播。E类不表示网络,保留或者实验室使用。
答:网络地址 = 有效网络号 + 全是0的主机号,例如192.168.122.92 网络地址为192.168.122.0
广播地址 = 有效网络号 + 全是1的主机号,例如192.168.122.92 广播地址为192.168.122.255
答:三级IP地址划分:利用子网掩码可以将主机号再次划分,可以划分部分为2^n,IP = 网络号 + 子网号 + 主机号
子网掩码格式:子网掩码的长度与IP地址长度一样是32位无符号整数,由一串连续的1后面跟着连续的0组成
IP地址 & 子网掩码 = 子网网段
子网网段个数 = 2^(子网掩码中多加的1的个数)
每个子网网段中主机号的个数 = 2^(子网掩码剩余0的个数)
答:字节序是指不同类型CPU主机内存存储多字节整数序列的方式,例如:short,int,long。字节序分为大端字节序与小端字节序,小端字节序:低地址存储低字节,高地址存储高字节。大端字节序:低地址存储高字节,高地址存储低字节。用共用体的方式判断本机字节序:
#include
union t
{
int a;
char b;
};
int main(int argc,const char argv[])
{
union t test;
test.a = 1;
if(1 == test.b)
printf("这是小端存储\n");
else if(0 == test.b)
printf("这是大端存储\n");
}
答:可以,当send中的flag == 0时,send函数可以替换成write,也可以替换成sendto,此时sendto最后两个参数分别为NULL和0
答:可以,当recv中的flag == 0时,recv函数可以替换成read,也可以替换成recvfrom,此时recvfrom最后两个参数为NULL
答:可以,当flag == 0且最后两个参数都为NULL时,可以替换成recv,read函数
答:可以,当flag == 0时,可以替换成send,write函数,但前提是得先调用connect函数
答:UDP中,可以调用connect函数。
void handler(int sig){
while(waitpid(-1, NULL, WNOHANG) > 0);
}
signal(17, handler);
sfd = socket();
bind();
listen();
while(1){
newfd = accept();
if(fork() == 0){
close(sfd);
while(1){
recv();
send();
}
close(newfd);
exit(0);
}
close(newfd);
}
close(sfd);
sfd = socket();
bind();
listen();
while(1){
newfd = accept();
pthread_create(&tid, NULL, deal_cli_msg, &info);
pthread_detach(tid);
}
close(sfd);
void* deal_cli_msg(void* arg){
newfd = arg->newfd;
cin = arg->cin;
while(1){
recv();
send();
}
close(newfd);
pthread_exit();
}
答:IO多路复用分为select、poll、epoll,select的TCP服务器模型
sfd = socket();
bind();
listen();
while(1)
{
tempfds = readfds
select(maxfd+1,&tempfds,NULL,NULL,NULL);
for(int i=0;i newfd ? maxfd : newfd;
}
else
{
res = recv();
if(0 == res)
{
close(i);
FD_CLR(i,&readfds);
while(FD_ISSET(maxfd,&readfds) == 0 && maxfd-- > 0)
continue;
}
send();
}
}
}
close(sfd);