Fork() Dilema Percabangan
Dalam bidang pengaturcaraan berbilang proses, fungsi fork() berkuasa. Walau bagaimanapun, tingkah lakunya kadangkala boleh membingungkan mereka yang belum tahu. Pertimbangkan kod berikut:
<code class="c">#include <stdio.h> #include <sys/types.h> #include <unistd.h> int main(void) { int i; for(i = 0; i < 2; i++) { fork(); printf("."); } return 0; }</code>
Setelah dilaksanakan, program ini tidak menghasilkan 6 titik seperti yang dijangkakan, tetapi 8 titik yang menakjubkan. Bagaimanakah ini boleh berlaku?
Menyelidik ke dalam fork() Abyss
Jawapannya terletak pada cara kerja fork() yang rumit. Fungsi ini pada asasnya mencipta pendua hampir sempurna proses semasa, termasuk memori dan deskriptor fail terbuka. Perbezaan utama adalah dalam nilai pulangan, yang berbeza antara proses ibu bapa dan anak.
Dalam contoh kami, proses awal mencipta proses kedua melalui garpu pertama(). Kedua-dua proses ini kemudian mencetak satu titik, sebelum menggelung dan bercabang lagi. Selepas garpu kedua(), terdapat empat proses, setiap satunya mencetak titik sebelum keluar. Oleh itu, kita boleh mengambil kira enam titik.
Walau bagaimanapun, plot menebal dengan sifat tersembunyi printf(). Secara lalai, printf() menampan outputnya, menangguhkan paparan sebenarnya. Akibatnya, titik pertama yang dicetak sebelum panggilan fork() pertama kekal tidak kelihatan. Titik tersembunyi ini, bersama-sama dengan empat titik penimbal daripada ibu bapa dan tiga anak diproses selepas garpu kedua(), menghasilkan pengiraan akhir 8 titik.
Untuk Mengelakkan Maze Tertimbal
Untuk memintas tingkah laku ini dan memastikan printf() keluar dengan serta-merta, fungsi fflush(stdout) boleh digunakan selepas setiap panggilan printf(). Ini memaksa output penimbal untuk ditulis, menghalang titik daripada lenyap ke dalam bayang-bayang.
Atas ialah kandungan terperinci Mengapa Program C Ini Mencetak 8 Titik Daripada 6 Apabila Menggunakan garpu()?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!