首頁 後端開發 php教程 為什麼is_file()函數不能取代file_exists()函數的理由

為什麼is_file()函數不能取代file_exists()函數的理由

Jul 11, 2017 am 10:52 AM
file 為什麼 替代

is_file真的可以取代file_exists使用嗎?答案是否定的。為什麼?原因很簡單,is_file有快取

我們可以用下面的程式碼測試一下:

程式碼如下:

<?php  
      $filename = &#39;test.txt&#39;;
      if (is_file($filename)) {
          echo "$filename exists!\n";
      } else {
          echo "$filename no exists!\n";
      }
      sleep(10);
     if (is_file($filename)) {
          echo "$filename exists!\n";
      } else {
          echo "$filename no exists!\n";
      }
?>
登入後複製

在執行測試程式碼時,我們確保test.txt檔案存在。在上面的程式碼中,第一次使用is_file函數判斷檔案是否存在,然後呼叫sleep函數睡眠10秒。在這10秒內,我們要把test.txt檔案刪除。最後看看第二次呼叫is_file函數的結果。輸出結果如下:
test.txt exists!
test.txt exists!
嗯,你沒有看錯,兩次都是輸出“test.txt exists!”,這是為什麼呢?原因就是is_file有快取。第一次呼叫is_file函數的時候,PHP會把檔案的屬性(file stat)保存下來,當再次呼叫is_file的時候,如果檔案名稱更第一次的一樣,那麼就會直接回傳快取.
那麼把is_file改為file_exists呢?我們可以把上面程式碼的is_file函數改為file_exists函數,再用上面的測試方法測試。結果如下:
test.txt exists!
test.txt no exists!
第二次呼叫file_exists的時候回傳檔案不存在,這是因為file_exists函數沒有緩存,沒次呼叫file_exists的時候都會去磁碟搜尋檔案是否存在,所以第二次才會回傳false。
所以說is_file是不能取代file_exists使用

以上是為什麼is_file()函數不能取代file_exists()函數的理由的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

無法以 root 身份登錄 mysql 無法以 root 身份登錄 mysql Apr 08, 2025 pm 04:54 PM

無法以 root 身份登錄 MySQL 的原因主要在於權限問題、配置文件錯誤、密碼不符、socket 文件問題或防火牆攔截。解決方法包括:檢查配置文件中 bind-address 參數是否正確配置。查看 root 用戶權限是否被修改或刪除,並進行重置。驗證密碼是否準確無誤,包括大小寫和特殊字符。檢查 socket 文件權限設置和路徑。檢查防火牆是否阻止了 MySQL 服務器的連接。

SQL刪除行後如何恢復數據 SQL刪除行後如何恢復數據 Apr 09, 2025 pm 12:21 PM

直接從數據庫中恢復被刪除的行通常是不可能的,除非有備份或事務回滾機制。關鍵點:事務回滾:在事務未提交前執行ROLLBACK可恢復數據。備份:定期備份數據庫可用於快速恢復數據。數據庫快照:可創建數據庫只讀副本,在數據誤刪後恢復數據。慎用DELETE語句:仔細檢查條件,避免誤刪數據。使用WHERE子句:明確指定要刪除的數據。使用測試環境:在執行DELETE操作前進行測試。

Navicat查看MongoDB數據庫密碼的方法 Navicat查看MongoDB數據庫密碼的方法 Apr 08, 2025 pm 09:39 PM

直接通過 Navicat 查看 MongoDB 密碼是不可能的,因為它以哈希值形式存儲。取回丟失密碼的方法:1. 重置密碼;2. 檢查配置文件(可能包含哈希值);3. 檢查代碼(可能硬編碼密碼)。

Navicat for MariaDB如何查看數據庫密碼? Navicat for MariaDB如何查看數據庫密碼? Apr 08, 2025 pm 09:18 PM

Navicat for MariaDB 無法直接查看數據庫密碼,因為密碼以加密形式存儲。為確保數據庫安全,有三個方法可重置密碼:通過 Navicat 重置密碼,設置複雜密碼。查看配置文件(不推薦,風險高)。使用系統命令行工具(不推薦,需要對命令行工具精通)。

centos7如何安裝mysql centos7如何安裝mysql Apr 14, 2025 pm 08:30 PM

優雅安裝 MySQL 的關鍵在於添加 MySQL 官方倉庫。具體步驟如下:下載 MySQL 官方 GPG 密鑰,防止釣魚攻擊。添加 MySQL 倉庫文件:rpm -Uvh https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm更新 yum 倉庫緩存:yum update安裝 MySQL:yum install mysql-server啟動 MySQL 服務:systemctl start mysqld設置開機自啟動

Centos停止維護2024 Centos停止維護2024 Apr 14, 2025 pm 08:39 PM

CentOS將於2024年停止維護,原因是其上游發行版RHEL 8已停止維護。該停更將影響CentOS 8系統,使其無法繼續接收更新。用戶應規劃遷移,建議選項包括CentOS Stream、AlmaLinux和Rocky Linux,以保持系統安全和穩定。

mysql 無法終止進程 mysql 無法終止進程 Apr 08, 2025 pm 02:48 PM

MySQL中的kill命令有時會失效,原因包括進程特殊狀態、信號級別不當。有效終止MySQL進程的方法包括:確認進程狀態、使用mysqladmin命令(推薦)、謹慎使用kill -9、檢查系統資源,以及深入排查錯誤日誌。

Navicat查看PostgreSQL數據庫密碼的方法 Navicat查看PostgreSQL數據庫密碼的方法 Apr 08, 2025 pm 09:57 PM

從Navicat直接查看PostgreSQL密碼是不可能的,因為Navicat出於安全原因對密碼進行了加密存儲。若要確認密碼,嘗試連接數據庫;要修改密碼,請使用psql或Navicat的圖形界面;其他目的需在代碼中配置連接參數,避免硬編碼密碼。為增強安全性,建議使用強密碼、定期修改和啟用多因素認證。

See all articles