Rumah pembangunan bahagian belakang tutorial php Output fungsi Rekursif PHP yang tidak dijangka: Kenapa fungsi tambahan mudah dicetak '85' dan bukannya '8'?

Output fungsi Rekursif PHP yang tidak dijangka: Kenapa fungsi tambahan mudah dicetak '85' dan bukannya '8'?

Apr 01, 2025 am 06:12 AM
kenapa

Output yang tidak dijangka fungsi rekursif PHP: Mengapa fungsi tambahan mudah dicetak

Penjelasan terperinci mengenai fungsi rekursif PHP: Menganalisis output fungsi tambahan yang tidak dijangka

Artikel ini menganalisis contoh fungsi rekursif PHP untuk menjelaskan mengapa hasil outputnya tidak sepadan dengan jangkaan. Kodnya adalah seperti berikut:

  Php
fungsi sd ($ a = 3, $ b = 2) {
   $ c = $ a $ b;
   jika ($ c 
Salin selepas log masuk
Salin selepas log masuk

Fungsi sd() menerima dua parameter a dan b , dan nilai lalai masing -masing adalah 3 dan 2. Fungsi ini mengira jumlah a dan b dan memberikan nilai kepada c . Jika c kurang daripada 6, maka rekursif memanggil sendiri dan lulus a dan nilai c baru sebagai parameter. Akhirnya, fungsi mencetak nilai c .

Selepas melaksanakan sd() , hasil output adalah "85", bukannya "8" yang diharapkan. Ini kerana terdapat kecenderungan dalam memahami susunan panggilan rekursif dan pelaksanaan pernyataan echo .

Proses pelaksanaan program adalah seperti berikut:

  1. Panggilan pertama ke sd() dipanggil, a=3 , b=2 , c = 3 2 = 5 . Oleh kerana c , fungsi itu memanggilnya secara rekursif dan parameter menjadi <code>sd(3, 5) .
  2. Dalam panggilan rekursif, a=3 , b=5 , c = 3 5 = 8 . Pada masa ini c >= 6 , rekursi berakhir. echo $c; Cetak 8.
  3. Program ini kembali ke lokasi di mana panggilan pertama sd() dipanggil. echo $c; Cetak nilai c pada panggilan pertama, iaitu 5.

Oleh itu, output akhir ialah "85". Bukannya pembolehubah c tidak ditimpa, tetapi pernyataan echo adalah pada akhir fungsi dan dilaksanakan setiap kali rekursif berakhir, mengakibatkan dua cetakan.

Untuk mendapatkan hasil "8", anda perlu mengubah suai logik fungsi, seperti meletakkan pernyataan echo dalam if bersyarat, atau mencetak hasil akhir hanya pada akhir rekursi. Kod yang diubahsuai boleh seperti berikut:

  Php
fungsi sd ($ a = 3, $ b = 2) {
   $ c = $ a $ b;
   jika ($ c 
Salin selepas log masuk
Salin selepas log masuk

Versi yang diubahsuai ini menggunakan pernyataan return untuk mengembalikan nilai c , memastikan hasil akhir dicetak hanya selepas rekursi berakhir.

Atas ialah kandungan terperinci Output fungsi Rekursif PHP yang tidak dijangka: Kenapa fungsi tambahan mudah dicetak '85' dan bukannya '8'?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Tidak dapat log masuk ke mysql sebagai akar Tidak dapat log masuk ke mysql sebagai akar Apr 08, 2025 pm 04:54 PM

Sebab utama mengapa anda tidak boleh log masuk ke MySQL sebagai akar adalah masalah kebenaran, ralat fail konfigurasi, kata laluan tidak konsisten, masalah fail soket, atau pemintasan firewall. Penyelesaiannya termasuk: periksa sama ada parameter pengikat di dalam fail konfigurasi dikonfigurasi dengan betul. Semak sama ada kebenaran pengguna root telah diubahsuai atau dipadam dan ditetapkan semula. Sahkan bahawa kata laluan adalah tepat, termasuk kes dan aksara khas. Semak tetapan dan laluan kebenaran fail soket. Semak bahawa firewall menyekat sambungan ke pelayan MySQL.

Cara Memulihkan Data Selepas SQL Memadam Barisan Cara Memulihkan Data Selepas SQL Memadam Barisan Apr 09, 2025 pm 12:21 PM

Memulihkan baris yang dipadam secara langsung dari pangkalan data biasanya mustahil melainkan ada mekanisme sandaran atau transaksi. Titik Utama: Rollback Transaksi: Jalankan balik balik sebelum urus niaga komited untuk memulihkan data. Sandaran: Sandaran biasa pangkalan data boleh digunakan untuk memulihkan data dengan cepat. Snapshot Pangkalan Data: Anda boleh membuat salinan bacaan pangkalan data dan memulihkan data selepas data dipadam secara tidak sengaja. Gunakan Pernyataan Padam dengan berhati -hati: Periksa syarat -syarat dengan teliti untuk mengelakkan data yang tidak sengaja memadamkan. Gunakan klausa WHERE: Secara jelas menentukan data yang akan dipadam. Gunakan Persekitaran Ujian: Ujian Sebelum Melaksanakan Operasi Padam.

Kaedah Navicat untuk melihat kata laluan pangkalan data MongoDB Kaedah Navicat untuk melihat kata laluan pangkalan data MongoDB Apr 08, 2025 pm 09:39 PM

Tidak mustahil untuk melihat kata laluan MongoDB secara langsung melalui Navicat kerana ia disimpan sebagai nilai hash. Cara mendapatkan kata laluan yang hilang: 1. Tetapkan semula kata laluan; 2. Periksa fail konfigurasi (mungkin mengandungi nilai hash); 3. Semak Kod (boleh kata laluan Hardcode).

Bagaimana untuk melihat kata laluan pangkalan data di Navicat untuk MariaDB? Bagaimana untuk melihat kata laluan pangkalan data di Navicat untuk MariaDB? Apr 08, 2025 pm 09:18 PM

Navicat untuk MariaDB tidak dapat melihat kata laluan pangkalan data secara langsung kerana kata laluan disimpan dalam bentuk yang disulitkan. Untuk memastikan keselamatan pangkalan data, terdapat tiga cara untuk menetapkan semula kata laluan anda: Tetapkan semula kata laluan anda melalui Navicat dan tetapkan kata laluan yang kompleks. Lihat fail konfigurasi (tidak disyorkan, risiko tinggi). Gunakan alat baris perintah sistem (tidak disyorkan, anda perlu mahir dalam alat baris arahan).

Cara Memasang MySQL di CentOS7 Cara Memasang MySQL di CentOS7 Apr 14, 2025 pm 08:30 PM

Kunci untuk memasang MySQL dengan elegan adalah untuk menambah repositori MySQL rasmi. Langkah -langkah khusus adalah seperti berikut: Muat turun kekunci GPG rasmi MySQL untuk mencegah serangan pancingan data. Tambah fail repositori MySQL: rpm -uvh https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm kemas kini yum repository cache: yum update mysql: yum pemasangan mysql-server mysql Server.

CentOS berhenti penyelenggaraan 2024 CentOS berhenti penyelenggaraan 2024 Apr 14, 2025 pm 08:39 PM

CentOS akan ditutup pada tahun 2024 kerana pengedaran hulu, RHEL 8, telah ditutup. Penutupan ini akan menjejaskan sistem CentOS 8, menghalangnya daripada terus menerima kemas kini. Pengguna harus merancang untuk penghijrahan, dan pilihan yang disyorkan termasuk CentOS Stream, Almalinux, dan Rocky Linux untuk memastikan sistem selamat dan stabil.

mysql tidak dapat menamatkan prosesnya mysql tidak dapat menamatkan prosesnya Apr 08, 2025 pm 02:48 PM

Perintah membunuh di MySQL kadang -kadang gagal kerana status khas proses dan tahap isyarat yang tidak betul. Kaedah untuk menamatkan proses MySQL dengan berkesan termasuk: mengesahkan status proses, menggunakan perintah mysqladmin (disyorkan), menggunakan Kill -9 dengan berhati -hati, memeriksa sumber sistem, dan penyelesaian masalah yang mendalam mengenai log ralat.

Kaedah navicat untuk melihat kata laluan pangkalan data sqlite Kaedah navicat untuk melihat kata laluan pangkalan data sqlite Apr 08, 2025 pm 09:36 PM

Ringkasan: Navicat tidak dapat melihat kata laluan SQLite kerana: SQLite tidak mempunyai medan kata laluan tradisional. Keselamatan SQLite bergantung pada kawalan kebenaran sistem fail. Jika kata laluan fail dilupakan, ia tidak boleh diambil (kecuali pangkalan data disulitkan, kunci diperlukan).

See all articles