Incrémentation d'un pointeur Int : pourquoi l'incrément de 4 octets ?
Lorsque vous travaillez avec des pointeurs, il peut être intuitif de s'attendre à ce que l'incrémentation d'un le pointeur int avancerait sa valeur de 1 octet, comme cela se produit avec les tableaux. Cependant, en pratique, l'incrémentation d'un pointeur int augmente en réalité sa valeur de 4 octets.
La raison de l'incrémentation de 4 octets
La raison de ce comportement réside dans le taille d'un type de données entier. Un int occupe généralement 4 octets de mémoire. Si un pointeur int devait s'incrémenter de seulement 1 octet, cela aurait pour résultat de pointer vers un entier partiel, ce qui n'aurait aucun sens.
Comprendre l'incrément du pointeur
Pour illustrer, considérons la représentation mémoire suivante :
[...| 0 1 2 3 | 0 1 2 3 | ...] [...| int | int | ...]
Ici, chaque int occupe 4 octets. Lorsqu'un pointeur int s'incrémente de 1, il est logiquement logique qu'il se déplace vers la section de 4 octets suivante, comme indiqué ci-dessous :
[↓ ] [...| 0 1 2 3 | 0 1 2 3 | ...] [...| int | int | ...]
Cela garantit que le pointeur continue de pointer vers un entier valide.
Accès aux octets individuels
Si le besoin s'en fait sentir d'accéder aux octets individuels d'un entier, vous pouvez utiliser un pointeur char. Puisque char a toujours une taille de 1 octet, vous pouvez utiliser un pointeur char* pour incrémenter d'un octet à la fois et accéder aux octets correspondants d'un entier.
Exemple :
int i = 0; int* p = &i; char* c = (char*)p; char x = c[1]; // access the second byte of the integer
Remarque supplémentaire :
Il est important de se rappeler que l'incrémentation un pointeur void* n'est pas autorisé, car void est un type incomplet et n'a pas de taille définie.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!