跳至主要內容
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 分钟编程技术总结多线程
JVM 知识点总结

本篇是学习 JVM 的一些知识点总结,翻阅了大量参考资料,不求多深入到细节,只求把一些重点的内容整理出来,所有参考资料均在文章末尾列出,这些参考资料才是最大的宝藏,文章所引用图片均来自于互联网。

一般来讲,JVM 的架构分为3个部分:类加载子系统、运行时数据区域、执行引擎。如下图。

类加载子系统将二进制的字节码读入和转换成虚拟机能够处理的数据结构,Java 虚拟机在执行Java程序的过程中将它所管理的内存区域划分为若干不同的数据区域,这些区域有不同作用,统称为运行时数据区域。执行引擎是虚拟机的执行字节码的概念模型,在虚拟机的实现中有解释执行(通过解释器执行)和编译执行(通过即时编译器生成本地代码执行)2种类型。


Kaybee大约 37 分钟编程技术总结JVM
什么是 Fat/Shade/Shadow Jar

问题

  • java -jar xxx.jar 执行时找不到主类 或 ClassNotFoundException

  • 引入的 jar 包中依赖冲突了怎么办,有多个版本的依赖类

正文

有没有想过 Spring Boot 项目可以直接打包成一个 jar 包还能直接通过java -jar运行,而当我们自己去写一个小项目去打成 jar 包的时候,要么就是打成的 jar 包运行的时候报 “找不到主类”, 要么就是报一个依赖的Class找不到,这是为什么呢?


Kaybee大约 7 分钟编程技术问题JavaTIPS
JVM 字节码介绍

来源: https://dzone.com/articles/introduction-to-java-bytecode

这是一遍相对来说比较简单的Java 字节码入门文章,一开始作者讲到了阅读Java 字节码比较枯燥无味,但是通过自己的故事说明了字节码的作用,事情是这样的,这哥们在很早之前做了一次功能变更,目的是为了测试修复一个潜在的性能问题, 并且打好了 JAR 包部署到服务器上。不幸的是,他并没有将源码提交到版本控制系统上,后来不知什么原因这段代码找不到了,一点痕迹都没有了(做了什么新的功能,记得一定要提交代码到Git 上),几个月后当他想用到那段代码的时候,悲剧就发生了。还好这哥们在远程机器上部署的 JAR 包还在,于是他用反编译的工具来找到源码,更不幸的是,反编译工具在关键的Class上崩溃了,也就是他正好要找的关键代码!


Kaybee大约 5 分钟编程技术JVMTIPS
UML类图

参考:https://en.wikipedia.org/wiki/Class_diagram

Instance-level relationships 实例间的关系

  • Dependency

依赖关系是2个关联元素之间的语义连接,这种连接关系导致一个元素的变化可能会引起依赖它的其他元素的变化。依赖关系是单向的。


Kaybee大约 2 分钟编程技术知识点TIPS