网络编程面试笔试题

一、OSI 7层模型,TCP/IP 4层模型 5层模型。 以及每一层的功能(重点:第三层 第四层)

答:

7层模型(①物理层:二进制比特流传输,②数据链路层:相邻结点的可靠传输,③网络层:寻址和路由选择,④传输层:端到端的可靠传输,⑤会话层:主机之间会话管理,⑥表示层:数据表示,加密与压缩,⑦应用层:提供各种网络应用接口)

5层模型(①物理层,②数据链路层,③网络层,④传输层,⑦应用层)

4层模型(①网络接口和物理层或网络访问层:ip地址与物理地址的映射(MAC),以及将上一次的ip报文封装成帧,转换成二进制比特流传输,③网络层,④传输层,⑦应用层)

网络接口和物理层:网络访问层

二、MAC地址:48bit全球唯一。 改变网络环境后MAC地址变不变,IP地址变不变

答:MAC不变,IP改变

2.1 ARP:通过ip地址获取对应的mac地址

2.2 RARP:通过mac地址获取对应的ip地址

2.3 MTU MSS,分别多大,有什么作用

答:MTU(最大传输单元):物理接口提供给上层最大一次传输数据的大小,规定了数据链路层所能传送最大数据长度,最大为1500bytes。MSS(最大报文长度):TCP提交给IP层最大分段大小,指TCP报文所允许传送数据部分最大长度,不包含TCP头,MSS是TCP来限制应用层最大发送字节数,若MTU=1500,则MSS最大为1460bytes

三、网络层:

  1. IP协议 : 路由器工作在哪一层:网络层
  2. ICMP :英特网控制管理协议,用于在IP主机、路由器之间传递控制消息
  3. IGMP:英特网分组管理协议,组播,广播

四、传输层:

4.1 TCP UDP

答:TCP(传输控制协议):提供面向连接的,一对一的,可靠数据传输协议。UDP(用户数据报协议):提供无连接的,不可靠的,尽力的传输协议(效率高)

4.2 TCP和UDP有什么异同点

答:相同点:是同属于传输层的协议。不同点:

TCP:

  1. TCP是面向连接的,可靠的数据传输协议
  2. TCP提供数据无误,数据无失序,数据无丢失,数据无重复到达的通信
  3. 传输效率低,耗费资源多
  4. 数据的收发是不同步的,或出现粘包的情况

UDP:

  1. UDP是面向无连接的,不可靠的,尽力的数据传输协议
  2. 数据有可能在传输过程中丢失、失序、重复
  3. 传输效率高
  4. 数据的收发是同步的,不存在粘包现象
  5. 限制每次传输的数据大小,超出部分直接删除

五、IP地址:

5.1 IP地址分类:2类

答:IPv4:采用4个字节的无符号整数,共32bit来存储IP地址。IPv6:采用16字节的无符号整数,共128bit来存储IP地址

5.2 二级IP地址划分:二级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类不表示网络,保留或者实验室使用。

5.3 网络地址和广播地址:

答:网络地址 = 有效网络号 + 全是0的主机号,例如192.168.122.92 网络地址为192.168.122.0

广播地址 = 有效网络号 + 全是1的主机号,例如192.168.122.92 广播地址为192.168.122.255

5.4 子网掩码:默认子网掩码,子网网段个数,主机号,可以用主机号,所有可用主机号。 题型详情看笔记。

答:三级IP地址划分:利用子网掩码可以将主机号再次划分,可以划分部分为2^n,IP = 网络号 + 子网号 + 主机号

子网掩码格式:子网掩码的长度与IP地址长度一样是32位无符号整数,由一串连续的1后面跟着连续的0组成

IP地址 & 子网掩码 = 子网网段

子网网段个数 = 2^(子网掩码中多加的1的个数)

每个子网网段中主机号的个数 = 2^(子网掩码剩余0的个数)

六、字节序:请简述字节序的概念,并用共用体(联合体)的方式判断本机字节数

答:字节序是指不同类型CPU主机内存存储多字节整数序列的方式,例如:short,int,long。字节序分为大端字节序与小端字节序,小端字节序:低地址存储低字节,高地址存储高字节。大端字节序:低地址存储高字节,高地址存储低字节。用共用体的方式判断本机字节序:

#include <stdio.h>
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");
}

七、TCP

7.1 TCP流程图

7.2 send函数能否替换成其他函数

答:可以,当send中的flag == 0时,send函数可以替换成write,也可以替换成sendto,此时sendto最后两个参数分别为NULL和0

7.3 recv函数能否替换成其他函数

答:可以,当recv中的flag == 0时,recv函数可以替换成read,也可以替换成recvfrom,此时recvfrom最后两个参数为NULL

八、UDP

8.1 UDP的流程图

8.1 recvfrom函数能否替换成其他函数

答:可以,当flag == 0且最后两个参数都为NULL时,可以替换成recv,read函数

8.2 sendto函数能否替换成其他函数 ----> connect

答:可以,当flag == 0时,可以替换成send,write函数,但前提是得先调用connect函数

8.3 udp中能否调用connect函数。(与TCP的对比,优点)

答:UDP中,可以调用connect函数。

  1. TCP中的connect函数会产生三次握手,将客户端与服务器相连,UDP中的connect函数不会产生连接,它仅仅将对端的IP和端口号记录到内核套接字中,此时UDP只能与记录的对端进行通信
  2. TCP中的connect函数只能调用一次,UDP中的connect函数可以调用多次,但会刷新内核中对端的IP和端口号,如果想要清空内核中对端的地址信息,则需要将地址信息结构体中sin_family设置成AF_UNSPEC,再调用connect
  3. 当UDP采用connect函数后,sendto函数可以用send,write替换
  4. UDP调用connect函数能够提升传输效率
  5. UDP调用connect函数能够增加传输稳定性

九、广播IP和组播IP(流程)

9.1.1 广播发送方

  1. socket 创建报式套接字
  2. setsockopt 设置允许广播 level:SOL_SOCKET optname:SO_BROADCAST
  3. bind 非必须绑定
  4. 填充接收方的地址信息结构体,给sendto函数使用,IP:广播IP 与接收方绑定的一致(ps:不能填0.0.0.0)PORT:1024~49151,与接收方绑定的一致
  5. sendto 发送

9.1.2 广播接收方

  1. socket 创建报式套接字
  2. 填充接收方自身的地址信息结构体,给bind函数使用
    1. IP:绑定广播IP(192.168.123.255 或者 255.255.255.255 或者0.0.0.0)
      1. 0.0.0.0:一旦绑定到套接字上,会将本机所有可用IP地址都绑定到套接字上。例如:
        1. ifconfig出来的本机IP 192.168.122.120
        2. 本地环回IP: 127.0.0.1
        3. 广播IP
        4. 组播IP
    2. PORT:1024~49151。
  3. bind 必须绑定
  4. recvfrom 接收数据

9.2.1 组播发送方

  1. socket 创建报式套接字
  2. bind 非必须绑定
  3. 填充接收方的地址信息结构体,给sendto函数使用,IP:组播 与接收方绑定的一致(ps:不能填0.0.0.0),PORT:1024~49151,与接收方绑定的一致
  4. sendto 发送

9.2.2 组播接收方

  1. socket 创建报式套接字
  2. setsockopt 加入多播组 level:IPPROTO_IP optname:IP_ADD_MEMBERSHIP
  3. 填充接收方自身的地址信息结构体,给bind函数使用
    1. IP:绑定组播IP,与加入的组播一致(224.0.0.0 - 239.255.255.255 或者 0.0.0.0)
      1. 0.0.0.0:一旦绑定到套接字上,会将本机所有可用IP地址都绑定到套接字上。例如:
        1. ifconfig出来的本机IP 192.168.122.120
        2. 本地环回IP: 127.0.0.1
        3. 广播IP
        4. 组播IP
    2. PORT:1024~49151。
  4. bind 必须绑定
  5. recvfrom 接收数据

十、多进程并发服务器 和 多线程并发服务器模型

10.1 多进程并发服务器

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);

10.2 多线程并发服务器

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多路复用的分类?请简述其中一种的流程(原理)?

答:IO多路复用分为select、poll、epoll,select的TCP服务器模型

sfd = socket();
bind();
listen();
while(1)
{tempfds = readfdsselect(maxfd+1,&tempfds,NULL,NULL,NULL);for(int i=0;i<maxfd;i++){if(FD_ISSET(i,&tempfds) == 0) continue;if(0 == i){fgets();        }    else if(sfd == i){newfd = accept();FD_SET(new,&readfds);maxfd = maxfd > 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);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/76507.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Django的模型

定义模型 from django.db import models class User(models.Model):# 类属性是表示表的字段username models.CharField(max_length50,uniqueTrue)password models.CharField(max_length200)create_time models.DateTimeField(auto_now_addTrue) # auto_now_add新增数据时间…

如何提升城市空气质量?一招教会你

空气质量监控&#xff0c;作为保障人类健康和维护环境可持续的关键手段&#xff0c;在现代社会发挥着重要作用。通过实时监测、数据采集和分析&#xff0c;我们能够深入了解空气中各种污染物的浓度以及气象参数的变化&#xff0c;从而评估空气质量的状况。 空气质量监控通过科学…

大数据及软件教学与实验专业实训室建设方案

一 、系统概述 大数据及软件教学与实验大数据及软件教学与实验在现代教育中扮演重要角色&#xff0c;这方面的教学内容涵盖了大数据处理、数据分析、数据可视化和大数据应用等多个方面。以下是大数据及软件教学与实验的一般内容&#xff1a;1. 数据基础知识&#xff1a;教授学生…

无涯教程-PHP - 静态变量函数

静态变量 静态变量在函数退出时值不会丢失,您只需将关键字STATIC放在变量名称的前面,即可将变量声明为静态变量。 <?phpfunction keep_track() {STATIC $count0;$count;print $count;print "<br />";}keep_track();keep_track();keep_track(); ?> 这…

基于docker搭建owncloud Harbor 构建镜像

环境介绍&#xff1a;ContenOS7.9 docker17.12.1-ce 使用mysql:5.6和 owncloud 镜像&#xff0c;构建一个个人网盘。 docker pull owncloud #拉取镜像 docker pull mysql5.6 创建容器 docker run --name owncloud-mysql -p 3306:3306 -e MYSQL\_ROOT\_PASSWORDroot …

linux部署clickhouse(单机)

一、下载安装 1.1、下载地址 阿里巴巴开源镜像站-OPSX镜像站-阿里云开发者社区阿里巴巴开源镜像站&#xff0c;免费提供Linux镜像下载服务&#xff0c;拥有Ubuntu、CentOS、Deepin、MongoDB、Apache、Maven、Composer等多种开源软件镜像源&#xff0c;此外还提供域名解析DNS、…

开放网关架构演进

作者&#xff1a;庄文弘&#xff08;弘智&#xff09; 淘宝开放平台是阿里与外部生态互联互通的重要开放途径&#xff0c;通过开放的产品技术把阿里经济体一系列基础服务&#xff0c;像水、电、煤一样输送给我们的商家、开发者、社区媒体以及其他合作伙伴&#xff0c;推动行业的…

Microsoft 图像BERT,基于大规模图文数据的跨模态预训练

视觉语言任务是当今自然语言处理&#xff08;NLP&#xff09;和计算机视觉领域的热门话题。大多数现有方法都基于预训练模型&#xff0c;这些模型使用后期融合方法融合下游任务的多模态输入。然而&#xff0c;这种方法通常需要在训练期间进行特定的数据注释&#xff0c;并且对于…

设计模式笔记

工厂模式&#xff1a; 1.Simple Factory Pattern : 是指由一个工厂对象决定创建出哪一种产品类的实例&#xff0c;简单工厂是产品的工厂&#xff0c;工厂类负责创建的对象较少&#xff0c;客户端需要传入工厂类的参数&#xff0c;对于如何创建对象的逻辑不关心。 缺点&#xf…

电脑上安装,多版本node

手上有一个vue3的项目&#xff0c;sass配置如下图所示&#xff1a; 安装了Python3.10和node 16.14.0&#xff0c;项目能正常install 跟run。 因工作需要&#xff0c;收上有一个vue2的项目&#xff0c;sass配置如下图所示&#xff1a; 执行npm intsall 的时候一直报Python2找不…

软件设计风格(干货)-架构师之路(九)

一、软件架构风格概念 Architecture架构&#xff0c;体系结构 软件体系结构风格是 描述某一特定应用领域中 系统组织方式 的惯用模式。架构风格定义一个系统家族&#xff0c;即 一个架构的定义、一个词汇表和一组约束。词汇表包含 一些构建和连接类型&#xff0c;而一组约束 …

Unity 找不到 Navigation 组件的解决

当我们想利用unity 里面的Navigation 组件来实现我们的物体的自动导航时&#xff0c;有时竟然会发现我们的菜单栏里面找不到 该组件 这时我们应该怎么办&#xff1f; 请确保你的项目中已经导入了Unity的AI模块。要导入该模块&#xff0c;请打开"Project Settings"&am…