zoukankan      html  css  js  c++  java
  • php -- 判断文件是否存在

    file_exists

    is_file

    is_dir

    基本上,PHP的 file_exists = is_dir + is_file

    写程序验证一下:

    分别执行1000次,记录所需时间。

    ------------------------------------------------------------------------------------------------------

    is_file 和 file_exists

    文件存在(当前目录)
    is_file:0.4570ms
    file_exists:2.0640ms

    文件存在(绝对路径3层/www/hx/a/)
    is_file:0.4909ms
    file_exists:3.3500ms

    文件存在(绝对路径5层/www/hx/a/b/c/)
    is_file:0.4961ms
    file_exists:4.2100ms

    文件不存在(当前目录)
    is_file:2.0170ms
    file_exists:1.9848ms

    文件不存在(绝对路径5层/www/hx/a/b/c/)
    is_file:4.1909ms
    file_exists:4.1502ms

    ----------------------------------------------------------------------------------------

    is_dir 和 file_exists

    目录存在
    file_exists:2.9271ms
    is_dir:0.4601ms
    目录不存在
    file_exists:2.9719ms
    is_dir:2.9359ms

    -------------------------------------------------------------------------------------------

    is_file($file)
    file_exists($file)
    当$file是目录时,is_file返回false,file_exists返回true


    文件存在的情况下,is_file比file_exists要快得多;
    要检测文件所在的目录越深,速度差越多,但至少快4倍。

    文件不存在的情况下,is_file比file_exists要慢一点点,但可以忽略不计。

    目录存在的情况下,is_dir比file_exists要快得多;
    目录不存在的情况下,is_dir比file_exists要慢一点点,但可以忽略不计。

    结论:
    如果要判断文件是否存在,用函数 is_file(),

    如果要判断目录是否存在,用函数 is_dir(),

    不确定传入的参数是文件还是目录的时候用,用file_exists了

  • 相关阅读:
    HDU 1317 XYZZY(floyd+bellman_ford判环)
    UVa 10791 最小公倍数的最小和(唯一分解定理)
    UVa 12169 不爽的裁判
    UVa 11582 巨大的斐波那契数!(幂取模)
    POJ 1142 Smith Numbers(分治法+质因数分解)
    HDU 1595 find the longest of the shortest
    UVa 11090 在环中
    UVa 10917 林中漫步
    UVa 11374 机场快线
    POJ 1503 Integer Inquiry
  • 原文地址:https://www.cnblogs.com/hf8051/p/4602521.html
Copyright © 2011-2022 走看看