zoukankan      html  css  js  c++  java
  • 文件操作 ---针对多线程

    <?php
    /*要取得共享锁定(读取的程序),将 lock 设为 LOCK_SH(PHP 4.0.1 以前的版本设置为 1)。
    要取得独占锁定(写入的程序),将 lock 设为 LOCK_EX(PHP 4.0.1 以前的版本中设置为 2)。
    要释放锁定(无论共享或独占),将 lock 设为 LOCK_UN(PHP 4.0.1 以前的版本中设置为 3)。
    如果不希望 flock() 在锁定时堵塞,则给 lock 加上 LOCK_NB(PHP 4.0.1 以前的版本中设置为 4)。**/

    function WriteFile($fp,$data){
     
                  if(fopen($fp,'a')){

            if(!flock($fp,LOCK_EX|LOCK_NB)){
        exit('由于其他用户在用,文件暂时无法操作!');
      }
       flock($fp,LOCK_EX); //加锁
       fwrite($fp, $data);    //写入数据
                     flock($fp, LOCK_UN);   //解锁
                     fclose($fp);           //关闭文件流
           }
    }
     
    function ReadFile($fp,$length){

                 if(fopen($fp,'a')){
           if(!flock($fp,LOCK_EX|LOCK_NB)){
        exit('由于其他用户在用,文件暂时无法操作!');
      }
       flock($fp,LOCK_SH); //加锁
       fgets($fp, $length);    //写入数据
                     flock($fp, LOCK_UN);   //解锁
                     fclose($fp);           //关闭文件流
           }
    }

  • 相关阅读:
    azkaben任务调度器
    HQL练习
    Hive基本操作
    Spark cache、checkpoint机制笔记
    2021年元旦云南之旅
    2020年总
    Windows Server 2016 如何恢复.NET Framework 4.6
    numpy和tensorflow中的广播机制
    查看spark RDD 各分区内容
    Spark RDD的默认分区数:(spark 2.1.0)
  • 原文地址:https://www.cnblogs.com/legend-song/p/3622572.html
Copyright © 2011-2022 走看看