不一样。原子性在并发编程中,和在数据库中两种不同的概念。
在数据库中,事务的ACID中原子性指的是"要么都执行要么都回滚"。
在并发编程中,原子性指的是"操作不可拆分、不被中断"。所以在并发编程中,我们要保证原子性指的就是一段代码需要不可拆分,不被中断。
比如经典的i++问题,就是原子性的一个很好地体现。
如Redis,它既是一个数据库系统,也是一个有并发的系统,那么看一下他对原子性的支持,就理解了:
✅为什么Lua脚本可以保证原子性?
原文: https://www.yuque.com/hollis666/xkm7k3/wsfbu382gg5l9ytx