php flock()介绍
flock — 轻便的咨询文件锁定
语法:
bool flock ( resource $handle , int $operation [, int &$wouldblock ] )
flock() 允许执行一个简单的可以在任何平台中使用的读取/写入模型(包括大部分的 Unix 派生版和甚至是 Windows)。
在 PHP 5.3.2版本之前,锁也会被 fclose() 释放(在脚本结束后会自动调用)。
PHP 支持以咨询方式(也就是说所有访问程序必须使用同一方式锁定, 否则它不会工作)锁定全部文件的一种轻便方法。 默认情况下,这个函数会阻塞到获取锁;这可以通过下面文档中 LOCK_NB 选项来控制(在非 Windows 平台上)。
参数:
- handle 文件系统指针,是典型地由 fopen() 创建的 resource (资源)。
- operation operation 可以是以下值之一: 1. LOCK_SH 取得共享锁定(读取的程序)。 2. LOCK_EX 取得独占锁定(写入的程序。 3. LOCK_UN 释放锁定(无论共享或独占)。 如果不希望 flock() 在锁定时堵塞,则是 LOCK_NB (Windows 上还不支持)。
- wouldblock 如果锁定会堵塞的话(EWOULDBLOCK 错误码情况下),可选的第三个参数会被设置为 TRUE 。(Windows 上不支持)
返回值:
成功时返回 TRUE , 或者在失败时返回 FALSE 。
php flock()实例
下面有两个php脚本文件:
a.php代码如下:
<?php
$file = \'temp.txt\';
$fp = fopen($file , \'w\');
if(flock($fp , LOCK_EX)){
fwrite($fp , “abc”);
/* http://www.manongjc.com/article/1357.html */
sleep(10);
fwrite($fp , “123”);
flock($fp , LOCK_UN);
}
fclose($fp);
?>
b.php代码如下:
<?php
$file = “temp.txt”;
$fp = fopen($file , \'r\');
echo fread($fp , 100);
fclose($fp);
?>
运行 a.php 后,马上运行 b.php ,可以看到输出:
abc
等 a.php 运行完后运行 b.php ,可以看到输出:
abc
123
显然,当 a.php 写文件时数据太大,导致时间比较长时,这时 b.php 读取数据不完整,在对b.php做修改
修改 b.php 为:
<?php
$file = “temp.txt”;
$fp = fopen($file , \'r\');
if(flock($fp , LOCK_EX)){
echo fread($fp , 100);
flock($fp , LOCK_UN);
} else{
echo “Lock file failed…”;
}
fclose($fp);
?>
运行 a.php 后,马上运行 b.php ,可以发现 b.php 会等到 a.php 运行完成后(即 10 秒后)才显示:
abc
123
读取数据完整,但时间过长,他要等待写锁释放,再对b.php做修改。
修改 b.php 为:
<?php
$file = “temp.txt”;
$fp = fopen($file , \'r\');
if(flock($fp , LOCK_SH | LOCK_NB)){
echo fread($fp , 100);
flock($fp , LOCK_UN);
} else{
echo “Lock file failed…”;
}
fclose($fp);
?>
运行 a.php 后,马上运行 b.php ,可以看到输出:
Lock file failed…
证明可以返回锁文件失败状态,而不是向上面一样要等很久。
结论:
建议作文件缓存时,选好相关的锁,不然可能导致读取数据不完整,或重复写入数据。
file_get_contents 好像选择不了锁,不知道他默认用的什么锁,反正和不锁得到的输出一样,是不完整的数据。
继续阅读与本文标签相同的文章
上一篇 :
php分享一个非常简单的文件读取demo
-
这款游戏曾被称为国产之光,现沦为“骗玩家充值”游戏,网友:再见
2026-05-14栏目: 教程
-
金属3D打印专家铂力特2019用户大会尽显大国实力
2026-05-14栏目: 教程
-
Google Books迎15岁生日 重新调整后更加方便
2026-05-14栏目: 教程
-
Windows 7即将停止支援 今年被攻击次数大幅提升71%
2026-05-14栏目: 教程
-
你绝对用得到的Excel数据保护方法
2026-05-14栏目: 教程
