Heim > Artikel > Backend-Entwicklung > Was fehlt PHP im Vergleich zu C/C++ oder Java? Multithreading, Multithreading, Multithreading…
Ich habe mich gestern mit einem ehemaligen Kollegen unterhalten und mich über PHP und Swoole beschwert. Er glaubte, dass PHP voller Fallstricke sei und dass PHP große Einschränkungen habe. PHP+Swoole ist nicht für Server mit hoher Parallelität geeignet, C+Swoole ist die beste Lösung. C++ verfügt über verschiedene Datenstrukturen, C++ kann Threads öffnen und C++ kann Objekte teilen. Es scheint notwendig, es sorgfältig zu erklären.
Was fehlt HP im Vergleich zu C/C++ oder Java? Multithreading, Multithreading, Multithreading...
Ja. PHP hat weniger Threads als C/C++ und Java. PHP verfügt nur über eine Multiprozesslösung, daher werden globale Variablen und Objekte in PHP nicht gemeinsam genutzt, Datenstrukturen können nicht prozessübergreifend betrieben werden, Socket-Dateideskriptoren können nicht gemeinsam genutzt werden usw. PHP hat also Einschränkungen?
Multi-Threading scheint viel leistungsfähiger zu sein als Multi-Processing. Tatsächlich kann ich Ihnen mit gutem Gewissen sagen, dass Multi-Threading mehr Fallstricke mit sich bringt.
Probleme bei der Datensynchronisierung führen zum Absturz. Entweder Sie opfern die Leistung und fügen überall Sperren hinzu, oder Sie verwenden die höllisch harte, gleichzeitige Programmierung ohne Sperren. Soweit ich weiß, gibt es in China nur sehr wenige Leute, die diese Fähigkeit beherrschen.
Glauben Sie nicht, dass alles gut wird, wenn Sie eine Sperre hinzufügen. Sie werden Probleme mit dem Deadlock-Problem haben. Wenn Ihre Programmlogik komplexer wird, wird es immer schwieriger, Sperren zu kontrollieren. Sobald Ihr Programm blockiert ist, ist es im Grunde zum Scheitern verurteilt.
Wenn ein bestimmter Thread hängt, werden alle Threads beendet
Stattdessen werden mehrere Prozesse betrachtet, was eigentlich viel einfacher ist.
Mit der prozessübergreifenden Kommunikation können Sie grundsätzlich jeden Datenaustausch erreichen. Beispielsweise wird ein Prozess zum gezielten Speichern von Datenstrukturen und Objekten verwendet, und alle Datenoperationen anderer Prozesse werden an diesen Prozess übergeben.
Mehrere Prozesse benötigen keine Sperren.
Mehrere Prozesse können verwendet werden Shared-Memory-Datenstrukturen zur Implementierung einiger Multithreading-Funktionen. Beispielsweise können Table und Atomic von Swoole den Datenaustausch realisieren, die Kosten sind jedoch sehr gering. In Zukunft werden auch Shared-Memory-Warteschlangen hinzugefügt
Die sogenannten PHP-Restriktionen Swoole sind völliger Unsinn. Durch die ordnungsgemäße Verwendung von Table, Atomic, SendMessage/PipeMessage und Task von Swoole kann asynchrone und nicht blockierende Codelogik vollständig implementiert werden.
In C++ geschriebene Programme haben eine bessere Leistung?
Das ist völlig blinder Aberglaube. C++ hat Vorteile für rechenintensive Programme. Der Kern des gleichzeitigen Servers ist IO, nicht umfangreiches, intensives Computing. Aus sprachlicher Sicht bietet C++ keine Vorteile. Darüber hinaus verfügen die meisten Datenstrukturen in C++ über entsprechende Implementierungen in PHP. Wenn dies nicht möglich ist, können Sie das Problem trotzdem lösen, indem Sie selbst eine spezielle Erweiterung schreiben.
Ein einzelner Server mit hoher Parallelität kann 10-W-Verbindungen aufrechterhalten und 3-5 W pro Sekunde gesendete und empfangene Nachrichten verarbeiten. Dieses Leistungsniveau kann bereits auf das Kernsystem von BAT angewendet werden.
Was bedeutet schnelle Entwicklungseffizienz?
Dieser Kollege sagte auch, dass die PHP-Serverentwicklung zwar schneller ist als C++, C++ jedoch dennoch erforderlich ist, um die ultimative Leistung zu erzielen. Ich werde Ihnen sagen, was es bedeutet, effizient zu sein. Ein gutes Programm zu entwickeln ist keine leichte Aufgabe und erfordert von Programmierern viel Zeit und Energie. Die Bedeutung der Verbesserung der Entwicklungseffizienz liegt nicht nur darin, dass ich die Arbeit in kürzerer Zeit abschließen kann, sondern auch darin, dass Sie in der verbleibenden Zeit Komponententests hinzufügen, Fehler beheben, die Benutzererfahrung verbessern, Details verbessern, unterstützende Tools bereitstellen, die Leistung optimieren und Schlüssel hinzufügen können Protokolle, erhöhen Sie die Anzahl der Überwachungsalarme und fügen Sie Notfallwiederherstellungspläne hinzu.