Bonsoir.
Comment faire pour qu'un fonction retourne l'adresse d'une structure ??
Merci d'avance
Bonsoir.
Comment faire pour qu'un fonction retourne l'adresse d'une structure ??
Merci d'avance
Hope it helps.
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10 typedef struct { int i; } structToto; structToto* fonctiontoto() { [...] return &sToto; //la variable est de type structToto }
« L'effort par lequel toute chose tend à persévérer dans son être n'est rien de plus que l'essence actuelle de cette chose. »
Spinoza — Éthique III, Proposition VII
Je pense que ça ira, merci
Et mince... Petit problème...
En fait, ma structure est déja déclarée dans ma classe, et c'est un pointeur car je fais une allocation dynamique pendant le programme. Ainsi, ma fonction doit retourner l'adresse d'une partie du tableau de structure en question.
Comment faire ?
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4 struct Data_Texture_Sol C_Terrain::*Get_DataTextureSol(int TextureSol) { return &Data_TextureSol[TextureSol]; }
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10 class C_Terrain { private: [...] struct Data_Texture_Sol *Data_TextureSol; public: struct Data_Texture_Sol *Get_DataTextureSol(int TextureSol); };
Si j'ai bien compris, Data_TextureSol est un tableau? Si oui, alors:
[/quote]
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10 class C_Terrain { private: [...] Data_Texture_Sol *Data_TextureSol; //pas de struct en début de ligne public: Data_Texture_Sol *Get_DataTextureSol(int TextureSol); //pas de struct en début de ligne };
Ce code devrait fonctionner, mais il est absolument horrible.
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11 Data_Texture_Sol* C_Terrain::Get_DataTextureSol(int TextureSol) { if (TextureSol<size) //size=taille de ton tableau { return &Data_TextureSol[TextureSol]; } else { return NULL; } }
Dans une optique purement didactique, je me permet de le corriger un peu:
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28 #include <vector> typedef struct { int toto; } Data_Texture_Sol; class CTerrain // Evite de mette des "_" partout, ça rend le code inutilement illisible { private: [...] std::vector<Data_Texture_Sol*> m_DataTextureSolList; //l'utilisation du template vector est infiniment préférable à un tableau de type C //de plus, utilise de préférence un tableau de pointeurs, c'est plus souple //enfin, l'utilisation du préfixe "m_" indique qu'il s'agit d'une variable membre. C'est une convention utilisée par beaucoup de développeur. public: Data_Texture_Sol* GetDataTextureSol(int iIndex); //la pertinence des noms de variables est importante. De plus, le mot "index" représente un concept ultra fréquent en programmation. }; Data_Texture_Sol* CTerrain::Get_DataTextureSol(int iIndex) { if (iIndex<m_DataTextureSolList.size()) { // toujours tester la validité d'un indice quand on attaque un tableau return m_DataTextureSolList.at(iIndex); } else { return NULL; } }
« L'effort par lequel toute chose tend à persévérer dans son être n'est rien de plus que l'essence actuelle de cette chose. »
Spinoza — Éthique III, Proposition VII
On en fait pas de typedef struct machin {} en C++, le typedef ne sert plus
Je plussoie r0d
Merci Rod, là j'ai pas le temps, j'étudierai le code demain. Les vecteurs n'ont-ils pas un résultat en performances plus faibles ?? Prennent-ils plus de ressources ??
Encore merci
Les performances, c'est à laisser pour la phase d'otimisation lorsqu'on a vérifié que le goulot d'étranglement était à ce niveau. Que ce soit pour la consommation CPU ou mémoire. Après profiling.
Et puis de toutes façon, je pense qu'en général un vector est plus efficace, autant en ce qui concerne les performances que le poids des données. En effet, les conteneurs de la stl sont optimisés à tous les niveaux.
« L'effort par lequel toute chose tend à persévérer dans son être n'est rien de plus que l'essence actuelle de cette chose. »
Spinoza — Éthique III, Proposition VII
Ok, je crois que je vais me mettre à utiliser beaucoups plus souvent les vector.
Par contre, j'ai une petite question... Je comprends pas trop comment tu veux que j'utilise des pointeurs ?
Dans mon programme, j'initialise les structures sans pointeur, et je donne l'adresse de la structure à chacun de mes cases...
Concernant les données membres, si je fais un pointeur vers ces données, j'enlève le m_ dans le nom du pointeur je suppose ? Ou y-a-il un nom spécial pour les pointeurs ?
Je reposterai peut-etre si j'ai d'autres questions... Encore merci
En voilà une bonne résolutionEnvoyé par insomniak
Je ne comprends pas ton problème :/Envoyé par insomniak
le préfixe m_ signifie que la variable appartient à la classe. En c++, on est toujours dans une classe. Les variables que tu déclare dans ta classe (dans le .h) commencerons toutes par m_. Les autres variables (paramètres des méthodes, variables locales, etc.) n'auront pas ce suffixe.Envoyé par insomniak
Pour les pointeurs, on utilise p. Par exemple un pointeur sur un objet de type Toto sera déclaré ainsi: Toto* pToto; Et si cette variable est membre de la classe, donc déclarée dans le .h, elle sera notée m_pToto.
Hope it helps.
« L'effort par lequel toute chose tend à persévérer dans son être n'est rien de plus que l'essence actuelle de cette chose. »
Spinoza — Éthique III, Proposition VII
Ces histoires de m_ devant les variables, ça vient des tréfonds de la programmation, la notation hongroise, ...
On peut largement s'en passer.
En effet, je plussoie. En fait, dans cette discussion, j'ai mis l'accent sur cette notation car je voulais exprimer que le nommage est important. Après c'est sût qu'on utilise la convention que l'on souhaite. CErtains utilisent leurs propres conventions. Et s'il y en a certaines que je n'apprécie pas particulièrement (comme le fait de mettre un _ avant, pour les variables membre), l'important est d'en utiliser une. Depuis quelque temps, j'utilise plutôt celle préconisée par Herb Sutter, en mettant des _ après le nom de variable.
« L'effort par lequel toute chose tend à persévérer dans son être n'est rien de plus que l'essence actuelle de cette chose. »
Spinoza — Éthique III, Proposition VII
Vous avez un bloqueur de publicités installé.
Le Club Developpez.com n'affiche que des publicités IT, discrètes et non intrusives.
Afin que nous puissions continuer à vous fournir gratuitement du contenu de qualité, merci de nous soutenir en désactivant votre bloqueur de publicités sur Developpez.com.
Partager