Ctype.h: differenze tra le versioni
Contenuto cancellato Contenuto aggiunto
LiveRC : Annullata la modifica di 94.64.154.148; ritorno alla versione di 130.192.232.23 |
Nessun oggetto della modifica |
||
(8 versioni intermedie di 8 utenti non mostrate) | |||
Riga 1:
{{Libreria_standard_C}}
{{titolo minuscolo}}
'''ctype.h''' è l'[[header file]] che, all'interno della [[libreria standard del C]], dichiara funzioni utilizzate per la classificazione dei caratteri.
== Storia ==
I primi programmatori in
if ('A' <= c && c <= 'Z' || 'a' <= c && c <= 'z')
Line 16 ⟶ 15:
A differenza di quanto riportato sopra, le funzioni di classificazione di caratteri non sono scritte in forma di test comparativi. Nella maggior parte delle librerie C, infatti, esse sono implementate con delle ricerche in tabelle [[allocazione statica della memoria|allocate staticamente]].
Ad esempio, la tabella può essere implementata con un [[array]] di 256 [[Numero intero (informatica)|interi]] da 8 [[bit]] ciascuno, organizzati come [[bitfield]], dove a ciascun bit corrisponde una particolare proprietà del carattere: ''numero'', ''lettera'' e così via. Se il [[bit meno significativo]] del numero intero corrispondesse alla proprietà ''numero'', il codice per la funzione (o, meglio, la macro) <code>isdigit()</code> potrebbe essere scritto semplicemente come:
#define isdigit(x) (TABLE[x] & 1)
Line 24 ⟶ 23:
#define isdigit(x) ((x) >= '0' && (x) <= '9')
Questa definizione potrebbe causare problemi se la determinazione del valore di <code>x</code> avesse degli effetti collaterali, come in <code>isdigit(x++)</code> oppure <code>isdigit(esegui_qualcosa())</code>. In questo caso l'espressione sarebbe valutata due volte, cosa non immediatamente evidente al programmatore distratto. Per questo, il metodo della tabella è utilizzato più diffusamente (vedere anche il messaggio di [[Linus Torvalds]] nella [[mailing list]] del kernel Linux, in basso alla pagina).
== Funzioni ==
Line 34 ⟶ 33:
!Nome || Descrizione
|- bgcolor=#f2f2f2
|colspan=2 align=center|<
|-
|<code>isalnum</code> || Controlla che il carattere passato sia ''alfanumerico''.
Line 60 ⟶ 59:
|<code>isxdigit</code> || Controlla che il carattere passato sia ''esadecimale'', cioè sia compreso in 0-9, oppure a-f, oppure A-F.
|- bgcolor=#f2f2f2
|colspan=2 align=center|<
|-
|<code>tolower</code> || Converte il carattere passato nel suo corrispondente minuscolo, se applicabile.
Line 91 ⟶ 90:
== Collegamenti esterni ==
*{{en}} [
[[Categoria:Libreria standard del C]]
|