一,网络
1,TCP窗口机制
TCP(传输控制协议)是一种可靠的、面向连接的传输层协议。其中的窗口机制是TCP协议中的一项重要功能,用于控制数据在发送和接收之间的流程。
TCP窗口机制是利用滑动窗口的方式来进行拥塞控制和流量控制的一种算法。它通过维护一个动态的发送窗口大小来适应网络吞吐量和延迟变化,有效地利用带宽资源。TCP发送方根据接收方给出的窗口大小来确定能够向对方发送多少个字节的数据,而接收方则根据自身处理能力和缓存空间来确定窗口大小。
TCP窗口机制的基本原理是,在建立TCP连接时,发送方和接收方都会设置自己的初始窗口大小。发送方每发送一个报文段后,会等待接收方的确认,如果接收方成功接收到报文段并发出确认,发送方就可以将发送窗口右移,并发送更多的数据;如果接收方的窗口满了或者网络拥塞导致报文丢失,发送窗口会被重新设定为较小的值,以降低发送速率。
通过 TCP窗口机制,TCP协议可以实现拥塞控制和流量控制,避免网络拥塞和数据丢失。同时,窗口机制还能根据真实的网络条件动态调整发送窗口大小,从而保证网络通信的效率与可靠性。
2,字节
字节是计算机中存储和传输数据的基本单位。它通常由8个二进制位组成,表示为一个8位的二进制数。在计算机中,所有的数据都以字节的形式存储和处理。字节可以用来表示数字、字符、图像、音频和视频等各种不同类型的数据。
3,select、poll、epoll的区别
select:
1. 一个进程最多只能监听1024个文件描述符 (千级别)
2. select被唤醒之后需要重新轮询一遍驱动的poll函数,效率比较低(消耗CPU资源);
3. select每次会清空表,每次都需要拷贝用户空间的表到内核空间,效率低(一个进行0~4G,0~3G是用户态,3G~4G是内核态,拷贝是非常耗时的);
poll
1. 优化文件描述符个数的限制;(根据poll函数第一个函数的参数来定,如果监听的事件为1个,则结构体数组的大小为1,如果想监听100个,那么这个结构体数组的大小就为100,由程序员自己来决定)
2. poll被唤醒之后需要重新轮询一遍驱动的poll函数,效率比较低
3. poll不需要重新构造文件描述符表,只需要从用户空间向内核空间拷贝一次数据即可
epoll:(本世纪最好用的io多路复用机制)
1. 监听的最大的文件描述符没有个数限制(理论上,取决与你自己的系统)
2. epoll当有事件产生被唤醒之后,文件描述符主动调用callback函数直接拿到唤醒的文件描述符,将文件描述符拷贝到用户空间即可不需要轮询,效率高。
3. epoll不需要重新构造文件描述符表,只需要从用户空间向内核空间拷贝一次数据即可
4,广播和组播的区别
主体不同
1、组播:为了减少在广播中涉及的不必要的开销,可以只向特定的一部分接收方(可以是域内也可以是域间)发送流量。
2、广播:指将报文发送到网络中的所有可能的接收者。
原理不同
1、组播:在通信中参与或感兴趣的主机需要处理相关的分组,流量只会被承载于它将被使用的链路上,并且只有任意组播数据报的一个副本被承载于这样的链路上。
2、广播:路由器简单地将它接收到的任何广播报文副本转发到除该报文到达的接口以外的每个接口。
特点不同
1、组播:通过发送方指明接收方,或是通过接收方独立地指明就可以完成这项工作。然后网络只负责向预期的或感兴趣的收件方发送流量。
2、广播:通过将地址中的主机部分全部置1形成的,特殊地质255.255.255.255对应于本地网络广播。
二,C
下面关于线性表的叙述中,错误的是哪一个()
正确答案: B 你的答案: 空 (错误)
线性表采用顺序存储,必须占用一片连续的存储单元
线性表采用顺序存储,便于进行插入和删除操作
线性表采用链接存储,不必占用一片连续的存储单元
线性表采用链接存储,便于插入和删除操作
下面所述步骤中,不是创建进程所必须的步骤是?
正确答案: A 你的答案: 空 (错误)
由调度程序为进程分配CPU
建立一个进程控制块
为进程分配内存
将进程控制块链入就绪队列
下面的排序算法中,初始数据集的排列顺序对算法的性能无影响的是
正确答案: B 你的答案: 空 (错误)
插入排序
堆 排 序
冒泡排序
快速排序
以下关于 Cache 的叙述中,正确的是()
正确答案: B 你的答案: 空 (错误)
CPU 中的 Cache 容量应大于 CPU 之外的 Cache 容量
Cache 的设计思想是在合理成本下提高命中率
Cache 的设计目标是容量尽可能与主存容量相等
在容量确定的情况下,替换算法的时间复杂度是影响 Cache 命中率的关键因素
运行在多核处理器上的Linux 环境中,若临界区非常短,且不允许线程上下文切换的
情况下,使用下列哪种机制满足上述需求并且性能最好?
正确答案: A 你的答案: 空 (错误)
SpinLock
Mutex
Semaphore
Condition variable
int listen(SOCKET s, int backlog);该函数中第二个参数的含义是?
正确答案: C 你的答案: 空 (错误)
是否打开 log 信息
是否打开后台 log 信息
后台等待连接队列的最大限制值
后台等待连接队列的最小限制值
无意义
以下数据结构属于非线性数据结构的是
正确答案: C 你的答案: 空 (错误)
队列
线性表
二叉树
栈
Unix 系统中,哪些可以用于进程间的通信?()
正确答案: A B C D 你的答案: 空 (错误)
Socket
共享内存
消息队列
信号量
关于多线程和多进程编程,下面描述正确的是():
正确答案: A C D 你的答案: 空 (错误)
多进程里,子进程可获得父进程的所有堆和栈的数据;而线程会与同进程的其他线
程共享数据,拥有自己的栈空间
线程因为有自己的独立栈空间且共享数据,所有执行的开销相对较大,同时不利于
资源管理和保护
线程的通信速度更快,切换更快,因为他们在同一地址空间内
线程使用公共变量/内存时需要使用同步机制,因为他们在同一地址空间内
因多线程里,每个子进程有自己的地址空间,因此相互之间通信时,线程不如进程
灵活和方便
流量劫持是网络安全中常见的安全威胁,下列哪些情况可能会造成流量劫持?()
正确答案: A B C 你的答案: 空 (错误)
MAC 地址欺骗
DNS 劫持
伪造的 DHCP 服务器
使用 https 协议