Maison  >  Article  >  développement back-end  >  Comment implémenter votre propre sizeof en C

Comment implémenter votre propre sizeof en C

WBOY
WBOYavant
2023-09-14 16:17:08601parcourir

Comment implémenter votre propre sizeof en C

Pour utiliser sizeof(), nous pouvons utiliser la variable x pour obtenir la valeur, utilisez &x et elle imprimera son adresse. Maintenant, si nous augmentons la valeur de &x, elle peut augmenter d'une manière différente. Si un seul octet est ajouté, cela signifie qu'il est de type caractère, si la valeur ajoutée est 4, il est de type int ou float, et ainsi de suite. Ainsi, en calculant la différence entre &x + 1 et &x, nous pouvons obtenir la taille de x.

Ici, nous utiliserons des macros car le type de données n'est pas défini dans la fonction. Encore une chose, nous utilisons (char*) pour la conversion de type afin qu'il nous dise combien de données de type de caractère nous pouvons mettre à cet emplacement. Parce que le type de caractère occupe un octet de données.

Exemple

#include <stdio.h>
#define my_sizeof(type) (char *)(&type+1)-(char*)(&type)
main(void) {
   int x = 10;
   char y = &#39;f&#39;;
   double z = 254748.23;
   printf("size of x: %d</p><p>", my_sizeof(x));
   printf("size of y: %d</p><p>", my_sizeof(y));
   printf("size of z: %d</p><p>", my_sizeof(z));
}

Sortie

size of x: 4
size of y: 1
size of z: 8

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!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer