


Output fungsi Rekursif PHP yang tidak dijangka: Kenapa fungsi tambahan mudah dicetak '85' dan bukannya '8'?
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
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:
- Panggilan pertama ke
sd()
dipanggil,a=3
,b=2
,c = 3 2 = 5
. Oleh keranac , fungsi itu memanggilnya secara rekursif dan parameter menjadi <code>sd(3, 5)
. - Dalam panggilan rekursif,
a=3
,b=5
,c = 3 5 = 8
. Pada masa inic >= 6
, rekursi berakhir.echo $c;
Cetak 8. - Program ini kembali ke lokasi di mana panggilan pertama
sd()
dipanggil.echo $c;
Cetak nilaic
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
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!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

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

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

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.

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.

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).

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).

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 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.

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.

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).
