intval

(PHP 4, PHP 5, PHP 7, PHP 8)

intvalEstrae il valore intero da una variabile

Descrizione

intval(mixed $var, int $base = 10): int

Estrae il valore intero di var, utilizzando la base definita a parametro per la conversione (la base vale 10 di default). intval() non dovrebbe essere usata sugli oggetti, poichè facendolo emetterà un errore di livello E_NOTICE e restituirà 1.

Elenco dei parametri

var

Valore scalare da convertire in intero

base

Base per la conversione

Nota:

Se base è 0, la base usata è determinata dal formato di var:

  • se la stringa include un prefisso "0x" (o "0X"), la base è considerata 16 (esadecimale); altrimenti,
  • se la stringa inizia con "0", la base è considerata 8 (ottale); altrimenti,
  • la base è considerata 10 (decimale).

Valori restituiti

Il valore intero di var se riesce, oppure 0 in caso di errore. Gli array vuoti restituiscono 0, gli array non vuoti restituiscono 1.

Il valore massimo dipende dal sistema. Nei sistemi a 32 bit si ha come valore per il caso di intero con segno il range da -2147483648 a 2147483647. Così, ad esempio, su tali sistemi, la riga intval('1000000000000') restituirà 2147483647. Il massimo valore per un intero con segno sui sistemi a 64 bit è 9223372036854775807.

Le stringhe probabilmente restituiranno 0, sebbene il valore restituito dipenda dal primo carattere a sinistra della stringa. Si utilizzano le comuni di integer casting .

Esempi

Example #1 Esempi di uso di intval()

I seguenti esempi sono basati su un sistema a 32 bit.

<?php
echo intval(42); // 42
echo intval(4.2); // 4
echo intval('42'); // 42
echo intval('+42'); // 42
echo intval('-42'); // -42
echo intval(042); // 34
echo intval('042'); // 42
echo intval(1e10); // 1410065408
echo intval('1e10'); // 1
echo intval(0x1A); // 26
echo intval(42000000); // 42000000
echo intval(420000000000000000000); // 0
echo intval('420000000000000000000'); // 2147483647
echo intval(42, 8); // 42
echo intval('42', 8); // 34
echo intval(array()); // 0
echo intval(array('foo', 'bar')); // 1
?>

Note

Nota:

Il parametro base non ha influenza a meno che il parametro var non sia una stringa.

Log delle modifiche

Versione Descrizione
5.1.0 Genera E_NOTICE e restituisce 1, quando un oggetto è passato a var.

Vedere anche: