✅并发编程中的原子性和数据库ACID的原子性一样吗?

典型回答

不一样。原子性在并发编程中,和在数据库中两种不同的概念。

在数据库中,事务的ACID中原子性指的是"要么都执行要么都回滚"。

在并发编程中,原子性指的是"操作不可拆分、不被中断"。所以在并发编程中,我们要保证原子性指的就是一段代码需要不可拆分,不被中断。

比如经典的i++问题,就是原子性的一个很好地体现。

如Redis,它既是一个数据库系统,也是一个有并发的系统,那么看一下他对原子性的支持,就理解了:

✅为什么Lua脚本可以保证原子性?

原文: https://www.yuque.com/hollis666/xkm7k3/wsfbu382gg5l9ytx