从OS / VM角度谈一谈栈的应用

系统中一个栈代表一个执行流,那么到底有多少种栈

首先用户空间,也就是进程至少有一个用户栈(每个线程有一个独立的用户栈)

中断、异常处理程序有独立的调用栈

系统调用有独立的调用栈 – 进程(线程)的内核栈

信号处理程序的执行肯定是在用户[……]

阅读全文

背景介绍:在硬件产线检测中,需要自动化的读取硬件状态,并逐一判断硬件状态是否健康,如:

最近对于这个需求设计了一个DSL,如:

每次工厂产品下线检测只需要设置好对应的DSL脚本,便有产线上位机自动加载并解释执行,以及与硬件串口进行交互检测

[……]

阅读全文

Linux 内核同步原语

每 CPU 变量

每 CPU 变量是一种内核用来避免竞争(而不是解决竞争)的手段,意思就是每个 CPU 访问各自的每 CPU变量而不要越界,这样就直接不需要同步了

原子操作

原子操作需要硬件支持,这类芯片级的原子操作对操作系统来说是不可或缺的,他们不[……]

阅读全文

本文涉及到中断/异常、系统调用、信号、进程切换,因为有这之间涉及到很多依赖,而很多概念容易混淆,所以专门梳理一下概念

中断/异常:

中断是由间隔定时器和I/O设备产生的,即CPU的外围设备产生,以通知CPU一个事件的发生,硬件上存在可编程中断控制器(PIC, APIC),负责向 CPU[……]

阅读全文

一直对 Java 异常的实现机制搞得不是很懂,也一直没找到比较权威的解释,国内各大论坛一通搜索也没找到合理的解释以消除我的疑问。

貌似只有我抱着这个疑问,可能是国内大牛比较多,这个问题又如此简单,大家已经心照不宣了。

最后终于还是看了一通官方文档才真正搞明白,以下是一些摘要。

3.[……]

阅读全文

ISO的隔离级别的划分并不完美,比如典型的丢失更新问题就不在其考虑范围内(以下内容以MySQL InnoDB为例)

InnoDB默认是repeatable read级别,但是默认的select仍然会导致丢失更新(lost update)

如果需要避免这个问题,需要使用select …[……]

阅读全文

虚拟内存与进程地址空间

为了方便描述模型,以32位Linux 为例,每个进程有3G的独立的地址空间,高位1G 的地址空间 – 内核空间是所有进程共享的,每个进程本身的描述符就是放在内核空间中,并且内核空间又为每个进程都分配了一个独立的内核栈,当然每个进程在自己独立的用户空间中还有另一个栈 -[……]

阅读全文