Heim Backend-Entwicklung PHP-Tutorial Gründe, warum die Funktion is_file() die Funktion file_exists() nicht ersetzen kann

Gründe, warum die Funktion is_file() die Funktion file_exists() nicht ersetzen kann

Jul 11, 2017 am 10:52 AM
file Warum 替代

Kann

is_file wirklich file_exists ersetzen? Die Antwort ist nein. Warum? Der Grund ist sehr einfach: is_file hat einen Cache

Wir können den folgenden Code verwenden, um ihn zu testen:

Der Code lautet wie folgt:

<?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";
      }
?>
Nach dem Login kopieren

in Beim Ausführen des Testcodes stellen wir sicher, dass die Datei test.txt vorhanden ist. Im obigen Code wird zum ersten Mal die Funktion is_file verwendet, um festzustellen, ob die Datei vorhanden ist, und dann wird die Sleep-Funktion aufgerufen, um 10 Sekunden lang zu schlafen. Innerhalb dieser 10 Sekunden löschen wir die test.txt-Datei . Schauen Sie sich abschließend das Ergebnis des zweiten Aufrufs der Funktion is_file an. Das Ausgabeergebnis lautet wie folgt:
test.txt existiert!
test.txt existiert!
Nun, Sie haben richtig gelesen, „test.txt existiert“ zweimal. Der Grund dafür ist, dass is_file über einen Cache verfügt. Wenn die Funktion is_file zum ersten Mal aufgerufen wird, speichert PHP das Attribut (Dateistatus) der Datei . Wenn is_file erneut aufgerufen wird, wird dies der Fall sein, wenn der Dateiname mit dem ersten Mal übereinstimmt direkt zurückgegeben werden.
Was ist mit der Änderung von is_file in file_exists? Wir können die Funktion is_file im obigen Code in die Funktion file_exists ändern und die obige Testmethode erneut zum Testen verwenden. Die Ergebnisse lauten wie folgt:
test.txt existiert!
test.txt existiert nicht!
Wenn file_exists zum zweiten Mal aufgerufen wird, wird zurückgegeben, dass die Datei nicht existiert. Dies liegt daran, dass file_exists Die Funktion wird nicht zwischengespeichert und wird jedes Mal ausgeführt, wenn file_exists aufgerufen wird. Gehen Sie zur Festplatte , um zu suchen, ob die Datei vorhanden ist. Daher wird nur beim zweiten Mal „false“ zurückgegeben.
Is_file kann also nicht anstelle von file_exists verwendet werden

Das obige ist der detaillierte Inhalt vonGründe, warum die Funktion is_file() die Funktion file_exists() nicht ersetzen kann. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Ich kann mich nicht als Stamm bei MySQL anmelden Ich kann mich nicht als Stamm bei MySQL anmelden Apr 08, 2025 pm 04:54 PM

Die Hauptgründe, warum Sie sich bei MySQL nicht als Root anmelden können, sind Berechtigungsprobleme, Konfigurationsdateifehler, Kennwort inkonsistent, Socket -Dateiprobleme oder Firewall -Interception. Die Lösung umfasst: Überprüfen Sie, ob der Parameter Bind-Address in der Konfigurationsdatei korrekt konfiguriert ist. Überprüfen Sie, ob die Root -Benutzerberechtigungen geändert oder gelöscht und zurückgesetzt wurden. Stellen Sie sicher, dass das Passwort korrekt ist, einschließlich Fall- und Sonderzeichen. Überprüfen Sie die Einstellungen und Pfade der Socket -Dateiberechtigte. Überprüfen Sie, ob die Firewall Verbindungen zum MySQL -Server blockiert.

Navicat -Methode zum Anzeigen von MongoDB -Datenbankkennwort Navicat -Methode zum Anzeigen von MongoDB -Datenbankkennwort Apr 08, 2025 pm 09:39 PM

Es ist unmöglich, das MongoDB -Passwort direkt über Navicat anzuzeigen, da es als Hash -Werte gespeichert ist. So rufen Sie verlorene Passwörter ab: 1. Passwörter zurücksetzen; 2. Überprüfen Sie die Konfigurationsdateien (können Hash -Werte enthalten). 3. Überprüfen Sie Codes (May Hardcode -Passwörter).

Wie kann ich das Datenbankkennwort in Navicat für Mariadb anzeigen? Wie kann ich das Datenbankkennwort in Navicat für Mariadb anzeigen? Apr 08, 2025 pm 09:18 PM

Navicat für MariADB kann das Datenbankkennwort nicht direkt anzeigen, da das Passwort in verschlüsselter Form gespeichert ist. Um die Datenbanksicherheit zu gewährleisten, gibt es drei Möglichkeiten, Ihr Passwort zurückzusetzen: Setzen Sie Ihr Passwort über Navicat zurück und legen Sie ein komplexes Kennwort fest. Zeigen Sie die Konfigurationsdatei an (nicht empfohlen, ein hohes Risiko). Verwenden Sie Systembefehlsleitungs -Tools (nicht empfohlen, Sie müssen die Befehlszeilen -Tools beherrschen).

So wiederherstellen Sie Daten nach dem Löschen von SQL Zeilen So wiederherstellen Sie Daten nach dem Löschen von SQL Zeilen Apr 09, 2025 pm 12:21 PM

Das Wiederherstellen von gelöschten Zeilen direkt aus der Datenbank ist normalerweise unmöglich, es sei denn, es gibt einen Backup- oder Transaktions -Rollback -Mechanismus. Schlüsselpunkt: Transaktionsrollback: Führen Sie einen Rollback aus, bevor die Transaktion Daten wiederherstellt. Sicherung: Regelmäßige Sicherung der Datenbank kann verwendet werden, um Daten schnell wiederherzustellen. Datenbank-Snapshot: Sie können eine schreibgeschützte Kopie der Datenbank erstellen und die Daten wiederherstellen, nachdem die Daten versehentlich gelöscht wurden. Verwenden Sie eine Löschanweisung mit Vorsicht: Überprüfen Sie die Bedingungen sorgfältig, um das Verhandlich von Daten zu vermeiden. Verwenden Sie die WHERE -Klausel: Geben Sie die zu löschenden Daten explizit an. Verwenden Sie die Testumgebung: Testen Sie, bevor Sie einen Löschvorgang ausführen.

CentOS stoppt die Wartung 2024 CentOS stoppt die Wartung 2024 Apr 14, 2025 pm 08:39 PM

CentOS wird 2024 geschlossen, da seine stromaufwärts gelegene Verteilung RHEL 8 geschlossen wurde. Diese Abschaltung wirkt sich auf das CentOS 8 -System aus und verhindert, dass es weiterhin Aktualisierungen erhalten. Benutzer sollten eine Migration planen, und empfohlene Optionen umfassen CentOS Stream, Almalinux und Rocky Linux, um das System sicher und stabil zu halten.

MySQL kann den Prozess nicht beenden MySQL kann den Prozess nicht beenden Apr 08, 2025 pm 02:48 PM

Der Kill -Befehl in MySQL schlägt manchmal aufgrund des besonderen Status des Prozesses und des unsachgemäßen Signalpegels fehl. Zu den Methoden zur effektiven Beendigung des MySQL -Prozesses gehören: Bestätigung des Prozessstatus, Verwenden des Befehls von MySQLadmin (empfohlen), mithilfe von Kill -9 mit Vorsicht, Überprüfung der Systemressourcen und eingehender Fehlerbehebung von Fehlerprotokollen.

Die Methode von Navicat zum Anzeigen von PostgreSQL -Datenbankkennwort Die Methode von Navicat zum Anzeigen von PostgreSQL -Datenbankkennwort Apr 08, 2025 pm 09:57 PM

Es ist unmöglich, Postgresql -Passwörter direkt von Navicat anzuzeigen, da Navicat Passwörter aus Sicherheitsgründen gespeichert sind. Um das Passwort zu bestätigen, versuchen Sie, eine Verbindung zur Datenbank herzustellen. Um das Kennwort zu ändern, verwenden Sie bitte die grafische Schnittstelle von PSQL oder Navicat. Für andere Zwecke müssen Sie die Verbindungsparameter im Code konfigurieren, um hartcodierte Passwörter zu vermeiden. Um die Sicherheit zu verbessern, wird empfohlen, starke Passwörter, regelmäßige Änderungen zu verwenden und die Authentifizierung von Multi-Faktoren zu aktivieren.

So installieren Sie MySQL in CentOS7 So installieren Sie MySQL in CentOS7 Apr 14, 2025 pm 08:30 PM

Der Schlüssel zur eleganten Installation von MySQL liegt darin, das offizielle MySQL -Repository hinzuzufügen. Die spezifischen Schritte sind wie folgt: Laden Sie den offiziellen GPG -Schlüssel von MySQL herunter, um Phishing -Angriffe zu verhindern. Add MySQL repository file: rpm -Uvh https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm Update yum repository cache: yum update installation MySQL: yum install mysql-server startup MySQL service: systemctl start mysqld set up booting

See all articles