Dalam persekitaran berbilang teras, amalan terbaik untuk melaksanakan algoritma selari dengan PHP termasuk: Berbilang proses: Gunakan proses berbeza untuk melaksanakan kod untuk memanfaatkan sepenuhnya berbilang teras CPU. Multithreading: Laksanakan berbilang utas dalam satu proses dan kongsi sumber memori. Coroutine: Menggunakan coroutine ringan, pelaksanaan boleh dijeda dan disambung semula untuk menggunakan CPU sepenuhnya.
Dalam era pemproses berbilang teras, penggunaan sepenuhnya selari adalah penting untuk meningkatkan prestasi aplikasi. PHP mempunyai beberapa ciri dan perpustakaan terbina dalam yang membantu kami melaksanakan algoritma selari.
Berbilang proses membolehkan anda melaksanakan kod dalam proses yang berbeza, dengan memanfaatkan sepenuhnya berbilang teras CPU.
<?php $procs = []; for ($i = 0; $i < 4; $i++) { $procs[] = new Process(['php', 'script.php', $i]); } foreach ($procs as $proc) { $proc->start(); } foreach ($procs as $proc) { $proc->wait(); } ?>
Dalam contoh ini, kami mencipta 4 proses kanak-kanak untuk dilaksanakan secara selari script.php
脚本,每个进程都使用不同的参数 $i
.
Multi-threading ialah pelaksanaan berbilang thread dalam satu proses, dengan itu berkongsi sumber memori.
<?php $threads = []; for ($i = 0; $i < 4; $i++) { $threads[] = new Thread(function () use ($i) { // 执行代码 }); } foreach ($threads as $thread) { $thread->start(); } foreach ($threads as $thread) { $thread->join(); } ?>
Dalam contoh ini, kami mencipta 4 utas, setiap satu menjalankan blok kodnya sendiri. Benang berkongsi ruang memori proses dan oleh itu mempunyai akses kepada pembolehubah global.
Coroutine adalah serupa dengan utas, tetapi ia lebih ringan dan boleh menjeda dan menyambung semula pelaksanaan.
<?php $tasks = [ function () { // 代码块 1 }, function () { // 代码块 2 }, function () { // 代码块 3 }, ]; $scheduler = new Scheduler(); foreach ($tasks as $task) { $scheduler->schedule($task); } $scheduler->run(); ?>
Dalam contoh ini, kami menggunakan penjadual untuk melaksanakan 3 tugasan secara selari. Coroutine secara automatik dijeda dan disambung semula untuk menggunakan sepenuhnya CPU yang tersedia.
Andaikan kita mempunyai direktori yang mengandungi sejumlah besar imej, dan kita perlu menjana lakaran kecil untuk setiap imej. Kita boleh mencapai ini menggunakan ciri selari PHP.
<?php $images = glob('images/*'); $threads = []; foreach ($images as $image) { $threads[] = new Thread(function ($image) { // 缩略图生成代码 }, $image); } foreach ($threads as $thread) { $thread->start(); } foreach ($threads as $thread) { $thread->join(); } ?>
Dengan menggunakan kumpulan benang, kami boleh menyelaraskan penjanaan lakaran kecil imej, dengan ketara mengurangkan jumlah masa pemprosesan.
Atas ialah kandungan terperinci Amalan Terbaik untuk Melaksanakan Algoritma Selari dengan PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!