Poster une réponse à un sujet: Typecasting "automatique" en C++
Attention, ce sujet est un sujet ancien (6322 jours sans réponse)
KangOl
Dans mon code, j'aimerais qu'une méthode du type:
A::DoSomething(String & a) ou A::DoSomething(String * a)
puis être utilisée comme suit:
A::DoSomething("Hello World");
Pour ça, il te faut
- A::DoSomething(String const & a)
Et oui la chaîne "Hello World" est constante
antp
Dans la MFC de Visual C++5 ils ont un opérateur LPCSTR permettant de combiner les char* avec les CString (CString::operator LPCSTR) mais je ne sais plus dans quel sens c'est (CString => char* ou l'inverse), et je ne sais plus comment ça marche.
En résumé, mon post ne sert peut-être à rien
En résumé, mon post ne sert peut-être à rien
rfr
il n'a pas fait de new -> au pire destrution automatique à la fin du bloque.
Oui mais non ... justement ... Je ne veux pas que l'objet soit détruit.
Quand tu passes une "chaine" comme paramètre d'une méthode, le compilateur alloue une fois pour toute la chaine dans l'exécutable. On est donc sûr qu'à chaque instant, la référence vers cette chaine reste valide, ou que l'on soit dans le flow d'éxecution du process.
Le comportement n'est pas le même s'il y a destruction automatique de l'objet.
kortenberg
il n'a pas fait de new -> au pire destrution automatique à la fin du bloque.
gizmo
Quand tu utilises String(x) tu ne dois pas te soucier de la désallocation.
Il n'utilise pas le String standard, donc on n'en sait rien.
kortenberg
Quand tu utilises String(x) tu ne dois pas te soucier de la désallocation.
rfr
Je crois que je vais devoir me tapper un truc du genre si je vous écoute bien ...
#define _S(x) String(x)
#define _PS(x) &String(x)
Ou pour éviter la création d'objets inutiles:
#define _S(x) StringManager::GetString(x)
#define _PS(x) StringManager::GetStringPtr(x)
Cette dernière solution ayant au moins l'intérêt de ne créer l'objet qu'une seule fois pour chaque string unique. Au cout, bien évidement, d'un lookup dans une hashtable.
Ca assure aussi qu'on considère l'objet crée comme +/- "statique" et que donc on ne se tracasse plus de son existence pour la désallocation.
Mais comme les strings fixes seraient de toute façon marginales, on ne pénalise pas trop les perfs.
Bon ok, c'est pas terribles les defines mais si ça me permet de m'en sortir pour le reste...
#define _S(x) String(x)
#define _PS(x) &String(x)
Ou pour éviter la création d'objets inutiles:
#define _S(x) StringManager::GetString(x)
#define _PS(x) StringManager::GetStringPtr(x)
Cette dernière solution ayant au moins l'intérêt de ne créer l'objet qu'une seule fois pour chaque string unique. Au cout, bien évidement, d'un lookup dans une hashtable.
Ca assure aussi qu'on considère l'objet crée comme +/- "statique" et que donc on ne se tracasse plus de son existence pour la désallocation.
Mais comme les strings fixes seraient de toute façon marginales, on ne pénalise pas trop les perfs.
Bon ok, c'est pas terribles les defines mais si ça me permet de m'en sortir pour le reste...
ovh
Je ne suis pas un gourou du C++ mais quand même j'ai eu des cours dessus et je l'ai pas mal utilisé (maintenant moins), et à ce que je me souvienne la solution pour ce type de cas c'est la surcharge de fonction, clairement
philfr
C++ n'est pas à typage dynamique, et les conversions implicites n'existent que pour les types numériques...
Je crains que la surcharge ne soit ton seul salut...
Ou alors appeler toujours explicitement (ce qui n'est pas moins lisible AMHA):
A::DoSomething(String("Hello World"));
Je crains que la surcharge ne soit ton seul salut...
Ou alors appeler toujours explicitement (ce qui n'est pas moins lisible AMHA):
A::DoSomething(String("Hello World"));
zion
En gros, une bonne conversion automatique sans devoir chaque fois surcharger les methodes pour qu'elles acceptent les deux types
Ah oué flute...
Euh... Pascal est ton ami, sinon je laisse ma langue au chat