PHP Unconference Europe 2015

Come leggere la definizione di una funzione (prototipo)

Nel manuale ciascuna funzione è documentata per un rapido riferimento. Conoscendo come leggere e capendo il testo si è in grado di apprendere il PHP molto più facilmente. Piuttosto che appoggiarsi sugli esempi o sul copia e incolla, preferirai sicuramente sapere come leggere la definizione di una funzione. Cominciamo:

Nota: Pre-requisito: comprensione di base dei tipi di variabili

Sebbene il PHP sia un linguaggio poco tipizzato (loosely typed), è importante avere una conoscenza di base delle tipologie di variabili per il loro importante significato.

La definizione della funzione ci dice quale tipo di valore viene restituito. Utilizziamo la definizione di strlen() come nostro primo esempio:

strlen

(PHP 4, PHP 5)
strlen -- Restituisce la lunghezza di una stringa

Description
int strlen ( string $string )

Restituisce la lunghezza di una stringa.

Spiegazione della definizione di una funzione
Parte Descrizione
strlen Nome della funzione.
(PHP 4, PHP 5) strlen() è disponibile in tutte le versioni di PHP 4 e PHP 5
int Tipo di valore restituito dalla funzione, il quale è un integer (la lunghezza di una stringa si misura in numeri).
( string $string ) Il primo (ed in questo caso unico) parametro/argomento per questa funzione si chiama string, ed è una string.

Si potrebbe riscrivere la funzione precedente in modo generico:

      returned type    function name    ( parameter type   parameter name )

Diverse funzioni hanno diversi parametri, tipo in_array(). Il loro prototipo è:

      bool in_array ( mixed $needle, array $haystack [, bool $strict])

Cosa significa? in_array() restituisce un valore boolean value, TRUE se riesce (se il parametro needle viene trovato in haystack) oppure FALSE se fallisce (se il parametro needle non viene trovato in haystack). Il primo parametro si chiama needle e può essere di diversi tipi, pertanto lo chiameremo "mixed". Questo parametro needle di tipo mixed (che indica che il valore che stiamo cercando) può essere sia un valore scalare (stringa, intero, oppure float), sia una matrice o array. haystack (che indica la variabile in cui cercare) è il secondo parametro. Il terzo parametro opzionale è chiamato strict. Tutti i parametri opzionali sono racchiusi tra parentesi [ quadre ]. Il manuale indica che il valore di default per strict è il boolean FALSE. Vedere le pagine del manuale di ciascuna funzione per i dettagli di come funziona.

Esistono anche funzioni con complesse informazioni sulla versione PHP. Ad esempio la funzione html_entity_decode():

(PHP 4 >= 4.3.0, PHP 5)

Questo significa che questa funzione è disponibile solo a partire dalla release PHP 4.3.0.

add a note add a note

User Contributed Notes 2 notes

up
1
ceo at l-i-e dot com
9 years ago
Another thing to watch for is the & in the argument list.

That generally means that the function is going to *CHANGE* the value you pass in, in some way, and you can't rely on it being the same as what you handed off to the function.
up
1
php dot devel at homelinkcs dot com
9 years ago
More specifically, an ampersand (&) prepended to an argument name means that the argument will be passed by reference (http://www.php.net/manual/en/language.references.pass.php).
To Top