c++ constructeur / compilation - C++ - Programmation
Marsh Posté le 22-12-2010 à 09:40:25
gee a écrit : Salut, |
Salut,
Rien n'est appelé à la compilation. Tu as surement voulu dire à la construction de D.
Sinon oui, le constructeur de C est appelé à la construction de D de façon implicite. Tu peux appeler explicitement un autre constructeur de C dans le constructeur de D de la façon suivante :
Code :
|
Sinon, tu peux aussi faire comme tu as dit, déclarer un pointeur sur C dans D , et instancier C à la main où tu veux dans D ( y compris dans le constructeur ).
Marsh Posté le 22-12-2010 à 10:09:30
Ah mais c'est fort dommage cela.
Comment declarer des valeurs par defaut dans un constructeur s'il est uniquement appele par "new" ?
En gros :
C c; => pas de valeurs par defaut possibles pour les members de C
C* c = new C => valeurs par defaut.
C'est bien cela?
Pour la possibilite d'appeler un autre constructeur je ne savais pas c'est sympa!
Merci bien!
Marsh Posté le 22-12-2010 à 10:16:49
gee a écrit : Ah mais c'est fort dommage cela. |
Si si, je n'ai peut être pas été clair. Si tu n'appelles pas de constructeur de C dans le constructeur de D, alors le constructeur par défaut de C est appelé implicitement.
Marsh Posté le 22-12-2010 à 11:14:25
Donc C c1; appele aussi le contructeur defaut, celui sans parametre?
Si c'est le cas, c'est ce que je voulais mais alors je ne comprend pas mon bug
Merci!
Marsh Posté le 22-12-2010 à 11:20:13
En gros mon code est ainsi:
D.h:
Code :
|
d.cpp:
Code :
|
C.h:
Code :
|
C.pp
Code :
|
le r->UneAutreFonction() plante dans ce cas, mais si je passe le membre C de C a C* dans D, tout se passe bien (dans tous les cas D d est cree par un new, donc sur la pile).
Enfin je ne sais pas si c'est plus clair la
Le probleme est peut etre l'utilisation du singleton dans un constructeur utilise par compilation et non pas sur la pile?
Marsh Posté le 22-12-2010 à 11:35:11
en debug, combien vaut r dans la fonction C::UneFonction() ?
As-tu un autre constructeur déclaré dans C ?
Est ce que tu as bien la syntaxe du constructeur par défaut et non autre chose ? Car sinon, le constructeur D appelle implicitement le constructeur par défaut C , qui , si tu ne l'as pas ou mal déclaré , sera implicite aussi.
Marsh Posté le 22-12-2010 à 11:39:46
1- je n'ai pas encore trouve comment utilise le debugger sous kdevelop donc je ne sais pas, mais je vais regarder
2- Pour un autre constructeur non, uniquement le defaut.
Marsh Posté le 22-12-2010 à 11:45:08
je viens d'écrire ton code, il fonctionne sans problème.
Code :
|
Affiche bien toto ( aucune vérification / désallocation , etc ... crade mais juste pour mettre en oeuvre ce que tu souhaites faire ).
Marsh Posté le 22-12-2010 à 11:50:23
Hmmmm faudra que je re-regarde apres dormir alors, peut etre que le fait qu'il soit 3h du mat me fasse zapper un truc important.
Dans tous les cas merci bien pour ton aide
A demain!
Marsh Posté le 23-12-2010 à 10:07:20
Je suis de retour
Donc j'ai reflechi a l'example et a mon vrai code, j'ai fait un petit test et trouve une difference et je crois que c'est cela.
Donc en fait pour le singleton j'ai 2 fonctions importantes:
- Instance() qui me donne l'instance de ma classe si elle existe, et sinon qui plante (un peu bizarre pour un singleton mais la suivante explique).
- Instantiate(string s, int i) qui cree une instance si elle n'existe pas, et utilise les parametres. Comme je n'ai pas envie de passer ces parametres a toutes les classes qui appele Instance, j'ai fait une 2nd fonction qui est appele au debut du programme. Est-ce mauvais?
Donc:
Quand C se construit et appelle R::Instance(), R::Instanciate(s,i) n'a pas encore ete appelee vu que cela se passe dans le programme et non la compilation et donc R::Instance() me retourne 0 (au lieu de planter, hmm j'imagine qu'un exit(0) sur une fonction appelee a la compilation n'est pas tres ruse).
Ca tiens la route tout cela?
Merci
Marsh Posté le 23-12-2010 à 11:22:08
tu confonds encore un peu compilation et execution. Aucune fonction n'est appelé à la compilation.
Marsh Posté le 23-12-2010 à 11:38:07
C'est vrai.
Mais alors a quel moment est appele le constructeur par defaut de mes classes qui sont sur la pile?
Marsh Posté le 23-12-2010 à 11:41:04
Si tes instances de classe ne sont pas sur la pile, c'est que soit tu les alloues sur le tas ( new ), dans ce cas , tu sais exactement à quel moment le constructeur est appelé, soit ce sont des variables globales, dans ce cas, c'est juste avant l'entrée dans le main. Donc dans tous les cas, à l'exécution ( au début ou non ).
Le danger est de déclarer plusieurs objets en variable globale, tu ne connais pas l'ordre d'appel des constructeurs.
Marsh Posté le 23-12-2010 à 11:49:12
Oooh je vois.
Ca parait donc une mauvaise idee de dependre de l'ordre d'execution de constructeurs non appeles avec new.
Merci beaucoup pour toutes ces explications ca aide!
Marsh Posté le 22-12-2010 à 09:15:44
Salut,
bete question peut etre mais ca fait longtemps que je n'ai pas touche a du c++
Si je declare une instance c d'une classe C comme membre d'une autre classe D, est-ce que le constructeur de C sera appele pendant la compilation ou bien autre chose se passe?
Ma question est due au fait que j'avais un probleme qui a ete resolu en passant c de C a C*, et en appelant le constructeur de C a la main plus tard.
Merci!
---------------
"Phildar t'es vraiment une pute pas finie toi! Et Manu le gros porc arrete de t'marrer!"