Question programmation C
Fermémamiemando Messages postés 33446 Date d'inscription jeudi 12 mai 2005 Statut Modérateur Dernière intervention 20 décembre 2024 - 23 nov. 2023 à 13:31
- Question programmation C
- Application de programmation - Guide
- Programmation logo tortue télécharger - Télécharger - Études & Formations
- Problème de programmation digicode extel klavy 3 ✓ - Forum Loisirs / Divertissements
- Programmation binaire - Guide
- Programmation carte à puce vierge ✓ - Forum Matériel & Système
5 réponses
12 nov. 2023 à 20:19
bonjour,
as-tu affiché l'adresse et la valeur de chaque variable?
qu'as-tu essayé?
As-tu seulement essayé de compiler ce code? Il ne compile pas chez moi.
Fais également afficher les warning avec les options -Wall -Wextra
Avant de jouer avec les pointeurs, tu aurais intérêt à revoir la section de ton cours qui en discute.
Je te donne un seul exemple:
int *c = *a;
C'est une erreur car tu as déclaré a comme int. *a veut dire que a est un pointeur.
Modifié le 13 nov. 2023 à 12:50
Salut aymane,
La réponse à cette question suppose, en théorie, de savoir quelle est la taille d'un int en bytes et quelle est taille d'un pointeur en bytes.
Ces tailles ne sont pas standardisées par le language, lesquelles dépendent de l'implémentation du C et concrètement du compilateur (et éventuellement du processeur).
En pratique, cependant, même avec ces informations, répondre à ta question est hasardeux, car le standard du C ne va pas non plus te garantir :
- que la pile commencera à une certaine adresse,
- ni que l'ordre dans lequel tes variables apparaissent dans le code correspondra à un un même ordre en mémoire,
- ni si pour un ordre donné la pile grandit en incrémentant les adresses mémoire ou en les diminuant,
- ni si l'espace entre deux variables stockées correspondra exactement à leur taille en mémoire (par exemple, à des fins d'optimisation, les adresses des variables pourront être alignées sur des adresses mémoires multiples de la taille d'une adresse sur l'architecture concernée afin que la lecture prenne moins de cycles processeur).
C'est encore ici le compilateur qui décide selon son implémentation.
Par exemple, et chez moi :
#include <stdio.h> #include <inttypes.h> int main(void) { int n = 12; int * ptr = &n; printf("Pour ce programme un int occupe \t %zu bytes\n", sizeof(n)); printf("Pour ce programme un pointeur occupe \t %zu bytes\n", sizeof(void *)); printf("Pour ce programme un int * occupe donc \t %zu bytes\n", sizeof(ptr)); printf("La variable n est à l'adresse \t\t %" PRIuPTR "\n", (uintptr_t)&n); printf("La variable ptr est à l'adresse \t %" PRIuPTR "\n", (uintptr_t)&ptr); return 0; }
donne :
$ gcc -Wall -Wextra 37945168.c
$ ./a.out
Pour ce programme un int occupe 4 bytes
Pour ce programme un pointeur occupe 8 bytes
Pour ce programme un int * occupe donc 8 bytes
La variable n est à l'adresse 140721523672508
La variable ptr est à l'adresse 140721523672496
Avec un gcc 8.3.0 64 bits sous Linux Debian 64 bits.
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question23 nov. 2023 à 13:31
Bonjour,
Je pense qu'il s'agit d'un exercice théorique (d'où les erreurs dans le code et les hypothèses un peu approximatives).
Sauf erreur de ma part :
- a vaut 1 par définition
- b est un pointeur (invalide) dont la valeur vaut 1
- c n'a aucun sens : on ne peut pas normalement pas assigner un entier dans un pointeur (même si moralement une adresse est une sorte d'entier). Mais même si on s'affranchit de ça, ça n'a aucune sens, car a vaut 1, et donc *a signifie "lire la valeur à l'adresse 1 de type int*". Or a cette adresse, ton programme n'a pas le droit de lire, ce qui provoquera en pratique une erreur de segmentation.
- d est initialisé à l'adresse de a, donc 1000.
- e est aussi initialisé à 1000, mais le type du pointeur n'est pas consistent (à cette adresse se trouve un int, pas un pointeur int *)
- f contient l'adresse de d soit 1000 + sizeof(int) + 2 * sizeof(int *) selon l'énoncé
- g vaut la valeur pointée par f, soit ce qui se trouve à l'adresse 1000, c'est-à-dire la valeur de d donc 1000.
Bonne chance