Speicherleistung steigert mit Generatoren und Nikic/Iter
Feb 16, 2025 am 09:17 AMPHP -Iterator und Generator: Ein leistungsstarkes Tool zur effizienten Verarbeitung gro?er Datens?tze
Arrays und Iterationen sind der Eckpfeiler jeder Anwendung. Wenn wir neue Tools erhalten, sollte sich auch die Art und Weise, wie wir Arrays verwenden, verbessern.
zum Beispiel ist ein Generator ein neues Werkzeug. Zuerst haben wir nur Arrays, und dann erlangen wir die F?higkeit, unsere eigene Klassenarray -Struktur (als Iteratoren bezeichnet) zu definieren. Seit PHP 5.5 k?nnen wir jedoch schnell Klassen -Iteratorstrukturen erstellen, die als Generatoren bezeichnet werden.
Der Generator sieht aus wie Funktionen, aber wir k?nnen sie als Iteratoren verwenden. Sie bieten uns eine einfache Syntax, um im Wesentlichen unterbrechbare, wiederholbare Funktionen zu erstellen. Sie sind unglaublich!
Wir werden mehrere Bereiche betrachten, in denen Generatoren verwendet werden k?nnen, und einige Probleme untersuchen, auf die bei der Verwendung von Generatoren geachtet werden müssen. Schlie?lich werden wir eine gro?artige Bibliothek lernen, die vom talentierten Nikita Popov erstellt wurde.
Der Beispielcode finden Sie unter https://github.com/sitepoint-editors/generators-and-iter.
Schlüsselpunkte
- Generatoren (verfügbar, da PHP 5.5 verfügbar ist) sind leistungsstarke Tools zum Erstellen von Iteratoren, die die Erstellung interruptierbarer, wiederholbarer Funktionen erm?glichen, die Verarbeitung gro?er Datens?tze vereinfachen und die Speicherleistung verbessern.
- nikita popov erstellt eine Nikic/Iter -Bibliothek, die Funktionen einführt, die mit Iteratoren und Generatoren verwendet werden k?nnen, wodurch ein erheblichem Speicher speichert, indem es vermeiden, unn?tige Zwischenarrays zu erstellen.
- Die Bibliotheken Generator und Nikic/Iter sind besonders nützlich, wenn sie mit gro?en CSV -Dateien arbeiten, die gro?e Datens?tze verarbeiten k?nnen, ohne sie alle gleichzeitig in Speicher zu laden.
- W?hrend Generatoren die Speicherleistung erheblich verbessern k?nnen, stellen sie auch einige ihrer eigenen Herausforderungen vor, wie z.
array_filter
array_map
Angenommen, Sie haben viele relationale Daten und m?chten einige Vorspannungen vornehmen. M?glicherweise sind die Daten von Kommas getrennt. Sie müssen jeden Datentyp laden und zusammen gruppieren.
Sie k?nnen mit dem folgenden einfachen Code beginnen:
Sie k?nnen dann versuchen, verwandte Elemente durch Iterieren oder h?here Ordnung zu verkettet:
function readCSV($file) { $rows = []; $handle = fopen($file, "r"); while (!feof($handle)) { $rows[] = fgetcsv($handle); } fclose($handle); return $rows; } $authors = array_filter( readCSV("authors.csv") ); $categories = array_filter( readCSV("categories.csv") ); $posts = array_filter( readCSV("posts.csv") );
Sieht gut aus, oder? Was passiert also, wenn wir eine gro?e Anzahl von CSV -Dateien analysieren k?nnen? Lassen Sie uns die Speicherverwendung ein wenig analysieren ...
function filterByColumn($array, $column, $value) { return array_filter( $array, function($item) use ($column, $value) { return $item[$column] == $value; } ); } $authors = array_map(function($author) use ($posts) { $author["posts"] = filterByColumn( $posts, 1, $author[0] ); // 對 $author 進行其他更改 return $author; }, $authors); $categories = array_map(function($category) use ($posts) { $category["posts"] = filterByColumn( $posts, 2, $category[0] ); // 對 $category 進行其他更改 return $category; }, $categories); $posts = array_map(function($post) use ($authors, $categories) { foreach ($authors as $author) { if ($author[0] == $post[1]) { $post["author"] = $author; break; } } foreach ($categories as $category) { if ($category[0] == $post[1]) { $post["category"] = $category; break; } } // 對 $post 進行其他更改 return $post; }, $posts);
(Der Beispielcode enth?lt
function formatBytes($bytes, $precision = 2) { $kilobyte = 1024; $megabyte = 1024 * 1024; if ($bytes >= 0 && $bytes < $kilobyte) { return $bytes . " b"; } if ($bytes >= $kilobyte && $bytes < $megabyte) { return round($bytes / $kilobyte, $precision) . " kb"; } return round($bytes / $megabyte, $precision) . " mb"; } print "memory:" . formatBytes(memory_get_peak_usage());, mit dem Sie diese CSV -Dateien erstellen k?nnen ...)
generate.php
Wenn Sie über gro?e CSV -Dateien verfügen, sollte dieser Code angezeigt, wie viel Speicher erforderlich ist, um diese Arrays miteinander zu verknüpfen. Mindestens die gleiche Gr??e wie die Datei, die Sie lesen müssen, da PHP alles im Speicher halten muss.
Generator kommt, um zu retten!
Eine M?glichkeit, dieses Problem zu verbessern, besteht darin, einen Generator zu verwenden. Wenn Sie mit ihnen nicht vertraut sind, ist jetzt ein guter Zeitpunkt, um mehr zu lernen.
Mit dem Generator k?nnen Sie eine kleine Menge an Gesamtdaten gleichzeitig laden. Sie müssen nicht viel mit dem Generator machen:
function readCSV($file) { $rows = []; $handle = fopen($file, "r"); while (!feof($handle)) { $rows[] = fgetcsv($handle); } fclose($handle); return $rows; } $authors = array_filter( readCSV("authors.csv") ); $categories = array_filter( readCSV("categories.csv") ); $posts = array_filter( readCSV("posts.csv") );
Wenn Sie CSV -Daten iterieren, werden Sie feststellen, dass die erforderliche Menge an Speicher sofort reduziert wird:
function filterByColumn($array, $column, $value) { return array_filter( $array, function($item) use ($column, $value) { return $item[$column] == $value; } ); } $authors = array_map(function($author) use ($posts) { $author["posts"] = filterByColumn( $posts, 1, $author[0] ); // 對 $author 進行其他更改 return $author; }, $authors); $categories = array_map(function($category) use ($posts) { $category["posts"] = filterByColumn( $posts, 2, $category[0] ); // 對 $category 進行其他更改 return $category; }, $categories); $posts = array_map(function($post) use ($authors, $categories) { foreach ($authors as $author) { if ($author[0] == $post[1]) { $post["author"] = $author; break; } } foreach ($categories as $category) { if ($category[0] == $post[1]) { $post["category"] = $category; break; } } // 對 $post 進行其他更改 return $post; }, $posts);
Wenn Sie zuvor Megabyte der Speichernutzung gesehen haben, werden Sie jetzt Kilobytes sehen. Dies ist eine enorme Verbesserung, aber nicht ohne Probleme.
Zun?chst array_filter
und array_map
funktionieren nicht mit Generatoren. Sie müssen andere Tools finden, um diese Art von Daten zu verarbeiten. Hier ist ein Werkzeug, das Sie versuchen k?nnen!
function formatBytes($bytes, $precision = 2) { $kilobyte = 1024; $megabyte = 1024 * 1024; if ($bytes >= 0 && $bytes < $kilobyte) { return $bytes . " b"; } if ($bytes >= $kilobyte && $bytes < $megabyte) { return round($bytes / $kilobyte, $precision) . " kb"; } return round($bytes / $megabyte, $precision) . " mb"; } print "memory:" . formatBytes(memory_get_peak_usage());
Diese Bibliothek führt einige Funktionen ein, die mit Iteratoren und Generatoren verwendet werden k?nnen. Wie erhalten Sie also noch all diese relevanten Daten, ohne Daten im Speicher zu speichern?
function readCSVGenerator($file) { $handle = fopen($file, "r"); while (!feof($handle)) { yield fgetcsv($handle); } fclose($handle); }
Dies kann einfacher sein:
foreach (readCSVGenerator("posts.csv") as $post) { // 使用 $post 執(zhí)行某些操作 } print "memory:" . formatBytes(memory_get_peak_usage());
(Jeden Mal jede Datenquelle neu zu lesen ist jedes Mal ineffizient. Erw?gen Sie, kleinere verwandte Daten (wie Autoren und Kategorien) im Speicher zu speichern.
Andere interessante Dinge
Für Nikics Bibliothek ist dies nur die Spitze des Eisbergs! Wollten Sie schon immer ein Array (oder Iterator/Generator) abflachen?
composer require nikic/iter
Sie k?nnen Funktionen wie slice
und take
verwenden, um Schnitte iterierbarer Variablen zurückzugeben:
// ... (后續(xù)代碼與原文類似,但使用iter庫函數(shù)進行優(yōu)化,此處省略以節(jié)省篇幅) ...
Wenn Sie Generatoren mehr verwenden, stellen Sie m?glicherweise fest, dass Sie sie nicht immer wiederverwenden müssen. Betrachten Sie das folgende Beispiel:
// ... (使用iter庫函數(shù)簡化代碼,此處省略以節(jié)省篇幅) ...
Wenn Sie versuchen, den Code auszuführen, sehen Sie eine Ausnahme, die aufzufordern: "Der geschlossene Generator kann nicht durchqueren". Jede Iteratorfunktion in dieser Bibliothek hat eine austauschbare entsprechende Funktion:
// ... (使用iter\flatten和iter\toArray函數(shù)的示例代碼,此處省略以節(jié)省篇幅) ...
Sie k?nnen diese Zuordnungsfunktion mehrmals verwenden. Sie k?nnen sogar Ihren eigenen Generator wiederspulen lassen:
// ... (使用iter\slice和iter\toArray函數(shù)的示例代碼,此處省略以節(jié)省篇幅) ...
Was Sie daraus erhalten, ist ein wiederverwendbarer Generator!
Schlussfolgerung
Für jeden Schleifenbetrieb, den Sie berücksichtigen müssen, ist der Generator m?glicherweise eine Option. Sie sind sogar nützlich für andere Dinge. Wenn Sprachmerkmale nicht ausreichend sind, bietet die Nikic-Bibliothek eine gro?e Anzahl von Funktionen h?herer Ordnung.
Verwenden Sie bereits den Generator? M?chten Sie weitere Beispiele dafür sehen, wie Sie sie in Ihrer eigenen Anwendung für einige Leistungsverbesserungen implementieren k?nnen? Bitte sagen Sie es uns!
(Der FAQS -Teil ?hnelt dem Originaltext und wird hier weggelassen, um Platz zu sparen. Der FAQS -Teil kann nach Bedarf optional aufbewahrt oder neu organisiert werden.)
Das obige ist der detaillierte Inhalt vonSpeicherleistung steigert mit Generatoren und Nikic/Iter. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Hei?e KI -Werkzeuge

Undress AI Tool
Ausziehbilder kostenlos

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Clothoff.io
KI-Kleiderentferner

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

Hei?er Artikel

Hei?e Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

H?ufige Probleme und L?sungen für den variablen PHP -Umfang umfassen: 1. Die globale Variable kann innerhalb der Funktion nicht zugegriffen werden, und sie muss bei der Verwendung des globalen Schlüsselworts oder Parameters übergeben werden. 2. Die statische Variable wird statisch deklariert und nur einmal initialisiert und der Wert wird zwischen mehreren Aufrufen beibehalten. 3.. Hyperglobale Variablen wie $ _get und $ _post k?nnen direkt in jedem Bereich verwendet werden, aber Sie müssen auf eine sichere Filterung achten. 4. Die anonymen Funktionen müssen über das Schlüsselwort verwenden, und wenn Sie externe Variablen ?ndern, müssen Sie eine Referenz übergeben. Das Beherrschen dieser Regeln kann dazu beitragen, Fehler zu vermeiden und die Code -Stabilit?t zu verbessern.

Um PHP -Datei -Uploads sicher zu verarbeiten, müssen Sie die Quelle und die Type und die Eingabe des Dateinamens und des Pfades überprüfen, Serverbeschr?nkungen festlegen und Mediendateien zweimal verarbeiten. 1. überprüfen Sie die Upload -Quelle, um CSRF durch Token zu verhindern, und erkennen Sie den realen MIME -Typ über die Finfo_file mithilfe der Whitelist -Steuerung. 2. Benennen Sie die Datei in eine zuf?llige Zeichenfolge um und bestimmen Sie die Erweiterung, um sie gem?? dem Erkennungstyp in einem Verzeichnis ohne Web zu speichern. 3. Die PHP -Konfiguration begrenzt die Hochladengr??e und das tempor?re Verzeichnis Nginx/Apache verbietet den Zugriff auf das Upload -Verzeichnis. 4. Die GD -Bibliothek stellt die Bilder neu, um potenzielle b?swillige Daten zu l?schen.

Es gibt drei g?ngige Methoden für den PHP -Kommentarcode: 1. Verwenden Sie // oder #, um eine Codezeile zu blockieren, und es wird empfohlen, // zu verwenden. 2. Verwenden Sie /.../, um Codebl?cke mit mehreren Zeilen zu wickeln, die nicht verschachtelt werden k?nnen, aber gekreuzt werden k?nnen. 3.. Kombinationskenntnisse Kommentare wie die Verwendung / if () {} / Um Logikbl?cke zu steuern oder um die Effizienz mit Editor -Verknüpfungsschlüssel zu verbessern, sollten Sie auf die Schlie?ung von Symbolen achten und das Verschachteln bei der Verwendung vermeiden.

AgneeratorinphpiSamemory-effizientes WaytoiterateOverlargedatasetsByyieldingValueatimeinsteadofReturningThemallatonce.1.GeneratorsusetheyieldKeywordtoproduktenvaluesonDemand, ReducingMemoryUsage.2.TheyareusefulforfulforfulfordlingBiglopploups, Lesebiglochen, Leselungen, Lesebigs, Leselung, oder

Der Schlüssel zum Schreiben von PHP -Kommentaren liegt in der Kl?rung des Zwecks und der Spezifikationen. Kommentare sollten "Warum" und nicht "was getan" erkl?ren, um Redundanz oder zu Einfachheit zu vermeiden. 1. Verwenden Sie ein einheitliches Format wie Docblock (/*/) für Klassen- und Methodenbeschreibungen, um die Lesbarkeit und die Kompatibilit?t der Werkzeuge zu verbessern. 2. Betonen Sie die Gründe für die Logik, z. B. warum JS -Sprünge manuell ausgeben müssen. 3. Fügen Sie eine übersichtsbeschreibung vor komplexem Code hinzu, beschreiben Sie den Prozess in Schritten und helfen Sie, die Gesamtidee zu verstehen. V. Gute Anmerkungen k?nnen die Kommunikationskosten senken und die Effizienz der Code -Wartung verbessern.

Tolearnphpeffectival, startbysettingupalocalerverenVironmentusexs -LikexamppandacodeeditorikevScode.1) InstallxamppForapache, MySQL und Php.SeacodeeditorForsyntaxSupport.3) testyourscludingveliktingveliktelaThbiliodble.Neclyble.NektFile

In PHP k?nnen Sie quadratische Klammern oder lockige Klammern verwenden, um Zeichenfolgenspezifikationsspezifische Indexzeichen zu erhalten, aber quadratische Klammern werden empfohlen. Der Index startet von 0 und der Zugriff au?erhalb des Bereichs gibt einen Nullwert zurück und kann keinen Wert zugewiesen; MB_SUBSTR ist erforderlich, um Multi-Byte-Zeichen zu verarbeiten. Zum Beispiel: $ str = "Hallo"; echo $ str [0]; Ausgabe H; und chinesische Zeichen wie Mb_Substr ($ str, 1,1) müssen das richtige Ergebnis erzielen. In den tats?chlichen Anwendungen sollte die L?nge der Zeichenfolge vor dem Schleifen überprüft werden, dynamische Zeichenfolgen müssen für die Gültigkeit verifiziert werden, und mehrsprachige Projekte empfehlen, Multi-Byte-Sicherheitsfunktionen einheitlich zu verwenden.

Toinstallphpquickly, usexampponwindowsorhomebrewonmacos.1.onwindows, download undInstallxampp, SelectComponents, Startapache und PlaceFilesinhtdocscs.2.Anternativ, manuellinstallphpfrfr
