跳至主要內容
Linux I/O Models

Unix 下的 5 种 I/O 模型

《Unix 网络编程》中介绍了这 5 种 I/O 模型,由于该书中的示例图比较模糊,我照着画了一遍,原书中使用的是 UDP datagram 作为请求的数据,我这里统写为 data.

1. 阻塞 I/O - Blocking I/O

在阻塞的 I/O 模型中,发起读取调用时,应用程序阻塞在 recvfrom方法上,recvfrom 方法会进行系统调用读取内核空间中的数据,当数据未就绪时,则会等待数据就绪;当数据就绪时,数据会从内核空间拷贝到用户空间,当拷贝完成后,recvfrom方法返回,应用程序继续处理数据。在这整个过程中,recvfrom 方法和支持该方法的系统调用一直处于阻塞状态(无法返回),直到请求的数据到达内核,并从内核拷贝到了应用内存中。


Kaybee大约 3 分钟编程技术Linux基础内功总结REVIEW
Java 多线程知识点总结

进程与线程、协程的区别?

  • 进程是操作系统进行资源分配的最小单位;线程是进程的一个执行单元,是 CPU 调度的基本单位

  • 进程之间的资源是互相独立的,一个进程内可以有多个线程运行,线程之间共享同一进程内的资源。

  • 进程间的切换开销大,线程由于轻量开销相对少

Java 线程的状态有哪几种?

  1. 初始(NEW):新创建了一个线程对象,但还没有调用start()方法。
  2. 运行(RUNNABLE):Java线程中将就绪(ready)和运行中(running)两种状态笼统的称为“运行”。
    线程对象创建后,其他线程(比如main线程)调用了该对象的start()方法。该状态的线程位于可运行线程池中,等待被线程调度选中,获取CPU的使用权,此时处于就绪状态(ready)。就绪状态的线程在获得CPU时间片后变为运行中状态(running)。
  3. 阻塞(BLOCKED):表示线程阻塞于锁。
  4. 等待(WAITING):进入该状态的线程需要等待其他线程做出一些特定动作(通知或中断)。
  5. 超时等待(TIMED_WAITING):该状态不同于WAITING,它可以在指定的时间后自行返回。
  6. 终止(TERMINATED):表示该线程已经执行完毕。

Kaybee大约 10 分钟编程技术总结多线程