php的原子操作,原子操作 · 国外PHP框架Nette官网教程 · 看云

# 原子操作

用于文件操作的Nette \ Utils \ SafeStram协议保证每个文件操作的原子性和隔离。

为什么它实际上好? 让我们从一个简单的例子开始,我们重复写入相同的字符串到文件,然后读取它:`

~~~

$s = str_repeat('Long String', 10000);

$counter = 1000;

while ($counter--) {

file_put_contents('soubor', $s); // write it

$readed = file_get_contents('soubor'); // read it

if ($s !== $readed) { // check it

echo 'Strings are different!';

}

}

~~~

看起来回声的字符串是不同的! 命令不能被执行。 相反是真的。 尝试在两个浏览器中同时运行此脚本。 错误几乎立即发生。

这是因为当在同一时间(即,在多个线程)重复执行时,代码是不安全的。 这是互联网上没有什么不寻常的,在那里几个人经常连接到一个网站在同一时间。 因此,确保您的应用程序可以一次处理多个线程,这是非常重要的 - 它是线程安全的,因为本机PHP函数不是。 否则,您可以预期数据丢失和奇怪的错误发生。

如何确保,像file_get_contets或fwrite的函数原子性地行为? SafeStream协议提供了一个安全的解决方案,所以我们可以通过标准的PHP函数原子操作文件。 加载Nette Framework时,协议自动可用。 之后,你只需要前缀的文件名nette.safe://:

~~~

$handle = fopen('nette.safe://test.txt', 'x'); // prefix the filename with nette.safe://

fwrite($handle, 'Nette Framework'); // for now, the data is written into a temporary file

fclose($handle); // and only now the file is renamed to test.txt

~~~

你当然可以使用所有熟悉的功能,如:

~~~

file_put_contents('nette.safe://test.txt', $content);

$ini = parse_ini_file('nette.safe://autoload.ini');

~~~

SafeStream保证:

原子性:文件作为一个整体写或根本不写。

隔离:没有人可以开始读取尚未完全写入的文件。

如果您以“a”模式(附加)写入现有文件,SafeStream将创建它的副本,只有在成功写入后,它才会将其重命名为原始名称。 因此,在此模式下写入比在其他模式下更耗资源。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值