Unix系统编程中的原子操作类似于数据库中事务的概念,一个操作可以由许多个步骤组成,这些步骤要么全部完成,要么不执行。
在Unix中,所有的(内核级别的???)系统调用都是原子操作,非原子的操作在多进程/多线程环境中一个典型的问题如多个进程同时向一个打开的文件写数据,早期的Unix系统open函数不支持O_APPEND,一个进程想向文件中添加数据时,典型的写法是
if(lseek(fd, 0L, 2) < 0)
err_sys("lseek error");
if(write(fd,buf,100) != 100)
err_sys("write error");
这样的写法在单进程环境下没有问题,但是在多进程的时候就有可能出现问题。因为内核有可能在进程A执行了lseek还没执行write的时候调度进程B(详细解释在APUE3.11)
所以在open文件的时候加入O_APPEND,每次write调用时,在写入数据之前内核会首先将该进程指向的文件表中的file status flags指向EOF,即写入文件末尾这个操作是一个原子操作。
问题:
如果一个文件用open("file",O_RDWR | O_APPEND)打开,可以使用lseek来进行任意的read和write么?
read可以,write不行,因为使用lseek将当前的file status flags定位到任意地方之后,在write操作执行之前,由于O_APPEND,内核会重新将标志置为EOF.所以lseek此时对write失效。
分享到:
相关推荐
详细地介绍了C++11中的原子操作,值得好好研读。
今天小编就为大家分享一篇关于C++11并发编程关于原子操作atomic的代码示例,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
atomic_ops原子操作1
3、并发编程之CAS&Atomic原子操作详解
来自BOOST库的原子操作atomic的源代码,跨平台
测试了windows下原子操作api的使用,很简单的测试,还是比较有趣的
很好用的原子钟同步软件,服务器出现时钟同步异常可以使用该软件
原子操作 四种原子更新方式文档,分别是原子更新基本类型,原子更 新数组,原子更新引用和原子更新字段。Atomic包里的类基本都是使用Unsafe实现的包装 类
描述了linux系统原子操作的实现以及使用原子操作时的注意事项。
主要介绍了Java多线程Atomic包操作原子变量与原子类详解,简单介绍了Atomic,同时涉及java.util.concurrent中的原子变量,Atomic类的作用等相关内容,具有一定参考价值,需要的朋友可以了解下。
angular-atomic-notify, angular.js 应用程序的原子咆哮通知 angular-atomic-notify一个用于显示通知的AngularJS模块 依赖项我们使用这个库作为示例,注意jQuery用于 angular.element 和 Font Awesome 图标,但是你...
原子范数约束谱估计文章,是稀疏恢复领域比较好的文章
Chronograph Atomic Time Clock 6.40(校时原子钟的时间工具)英文绿色特别版
Atom-atomic-bohr-model.zip,D3驱动的可定制动画原子玻尔模型原子玻尔模型,atom是一个用web技术构建的开源文本编辑器。
atomic
java.util.concurrent.atomic包:原子类的小工具包,支持在单个变量上解除锁的线程安全编程 原子变量类相当于一种泛化的 volatile 变量,能够支持原子的和有条件的读-改-写操作。AtomicInteger 表示一个int类型的值...
fs-write-stream-atomic - 类似`fs.createWriteStream(...)`, 但是是原子的
Atomic
前端开源库-atomic-batcher原子批处理程序,一个简单的批处理函数,允许您自动批处理一系列操作。