架构师面试(二):计算机编程基础

问题

(该题目考察计算机编程基础,看看大家在学生期间有没有认真上课)

下面说法正确的有哪几项?

A、协程在创建、切换和销毁时,操作系统都是无法感知的;

B、理论上讲,用户应用程序是可以脱离操作系统运行起来的;

C、Linux 下的 epoll 是同步 IO 模型,Windows下的 IOCP 是异步 IO 模型;

D、在 TCP 网络编程中,相对于单线程来说,多个线程同时写 socket 效率是更高的。

解析

A选项:协程是轻量级的用户级线程,它工作在用户态;协程的创建、切换和销毁,都不会进行系统调用,操作系统都是无感知的。

B选项:操作系统存在的意义有两个,一是对运行中的进程进行综合治理,二是为用户应用程序提供访问底层硬件的 API 接口;但是,用户应用程序并不是完全依赖操作系统的;没有操作系统的环境中,用户应用程序仍然可以正常运行起来。那怎么运行没有操作系统的应用程序呢?开机后,硬件加载 BIOS 程序(这是硬件厂商规定的),BIOS 程序的最后一条指令往往是 操作系统程序在硬盘中的地址,把这个地址修改成用户应用程序在硬盘中的地址即可。

C选项:Linux 下的 epoll 是 同步非阻塞的 IO 模型,即 IO 多路复用模型中的一种;Windows 下的 IOCP (俗称 完成端口)是 纯异步的 IO 模型。

D选项:socket 在 Linux 中的本质 是一个 文件描述符,即 fd,我们把它看做一个文件即可;TCP 是流式传输协议,在基于 TCP 的网络编程中,特别需要注意 "粘包" 和 "分包" 问题,也就是说线程在写 socket 时,必须要确保写的数据包是完整的;如果有多个线程同时写 socket 时,必须要加锁保证线程的串行化写入;而这个时候,往往单线程写 socket,效率是最好的。

答案

ABC

相关推荐
范特西林1 天前
AI OS 已来:OpenClaw与第三次操作系统革命
操作系统·agent
Trouvaille ~2 天前
【项目篇】从零手写高并发服务器(六):EventLoop事件循环——Reactor的心脏
linux·运维·服务器·c++·高并发·epoll·reactor模式
Trouvaille ~3 天前
【项目篇】从零手写高并发服务器(五):Channel事件管理与Poller模块
运维·服务器·c++·reactor·高并发·多路转接·epoll
Bruce_kaizy4 天前
c++ linux环境编程——linux信号(signal)
linux·c++·操作系统·环境编程
橙子也要努力变强4 天前
Linux I/O 缓冲区、inode、软硬链接与磁盘结构全解析
linux·c++·操作系统
Byte不洛4 天前
手写一个C++ TCP服务器实现自定义协议(顺便解决粘包问题)
linux·c++·操作系统·网络编程·tcp
AMoon丶5 天前
Golang--协程调度
linux·开发语言·后端·golang·go·协程·goroutine
带娃的IT创业者6 天前
Python 异步编程完全指南(二):深入 asyncio 核心概念
开发语言·python·协程·事件循环·asyncio·异步编程
棉花糖超人6 天前
【操作系统】三、线程
java·开发语言·操作系统
橙子也要努力变强7 天前
进程间通信基础
c++·操作系统