IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

 C++ Discussion :

const char * et cast


Sujet :

C++

  1. #1
    Membre éclairé
    Profil pro
    Étudiant
    Inscrit en
    Décembre 2007
    Messages
    630
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2007
    Messages : 630
    Par défaut const char * et cast
    [Suite à cette discussion ]

    Bonjour,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    char const *b = reinterpret_cast< char const * >(a);
    1) Pourquoi ce const devant le *b ?
    2) un dynamic_cast ne suffirait il pas ?

    Merci d'avance
    ( je suis débutant en c++ )

  2. #2
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 392
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 392
    Par défaut
    1. Parce qu'on a un pointeur const en entrée; ne pas le mettre en sortie violerait la const-correctness.
    2. dynamic_cast, c'est pour les classes uniquement (et encore, seulement celles avec des fonctions membres virtuelles*).

    *On ne va pas parler de "classe de base virtuelle" ici, ce n'est pas pour débutants.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  3. #3
    Membre éclairé
    Profil pro
    Étudiant
    Inscrit en
    Décembre 2007
    Messages
    630
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2007
    Messages : 630
    Par défaut
    D'acc. Ceci est correcte alors ? :
    const char *data1;
    const unsigned char *data2 = reinterpret_cast< const unsigned char * >(data1);

  4. #4
    Rédacteur
    Avatar de 3DArchi
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    7 634
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 7 634
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    [*]dynamic_cast, c'est pour les classes uniquement (et encore, seulement celles avec des fonctions membres virtuelles*).
    et en plus uniquement héritage publique (enfin avec visibilité là où se fait le cast)


    Citation Envoyé par ikuzar Voir le message
    D'acc. Ceci est correcte alors ? :
    const char *data1;
    const unsigned char *data2 = reinterpret_cast< const unsigned char * >(data1);
    oui.
    J'ose le UTFC (à rapprocher du RTFM)

  5. #5
    Membre éclairé
    Profil pro
    Étudiant
    Inscrit en
    Décembre 2007
    Messages
    630
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2007
    Messages : 630
    Par défaut
    Je reviens vers vous car je n'ai pas trouvé de solutions à mon problème de conversion de const char* en unsigned const char*. reinterpret_cast me semble le plus pertinent après avoir lu http://cpp.developpez.com/faq/cpp/?page=conversions
    Mais ce n'est pas le cas, apparemment il me génère un problème.

    en effet, je dois utliser une fonction OpenSSL pour décodé un string ( format PEM codé en base 64, en une structure interne C ( internal C structure ). Voici le prototype de la fonction:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    X509 *d2i_X509(X509 **px, const unsigned char **in, int len);
    la doc se trouve ici : http://www.openssl.org/docs/crypto/d...#RETURN_VALUES

    En gros cette fonction lit un string en format PEM qui se trouve dans const unsigend char **in et renvoie une structure X509*

    Maintenant, pourquoi j'ai utilisé un cast ? parce que mon constructeur prend en paramètre un PEM de type const char *str. Voici le code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    certificate(const char *str, size_t clen) {
         unsigned char const *u_str = reinterpret_cast< unsigned char const * >(str);
         X509* mycert = d2i_X509(NULL, &u_str, clen);
    A priori, je ne peux/dois pas changer la signature de ce constructeur. Donc je suis obligé de partir d'un const char *str.

    quand je debug, mycert est NULL, ca signifie que d2i_X509 a échoué. l'erreur est en fait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    error:0D07209B:asn1 encoding routines:ASN1_get_object:too long
    Je crois que c'est à cause du reinterpret_cast.

    Est ce que il y a d'autres moyen de résoudre le problème de conversion const char* => unsigned const char* ?

    Merci d'avance pour votre aide.

  6. #6
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 392
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 392
    Par défaut
    La fonction modifie u_str: Regarde si tu ne dois pas reporter la modification sur str...
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  7. #7
    Membre éclairé
    Profil pro
    Étudiant
    Inscrit en
    Décembre 2007
    Messages
    630
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2007
    Messages : 630
    Par défaut
    Je n'ai pas très bien compris,
    la fonction d2i_x509 ne fait que lire ce qu'il y a dans u_str, pourquoi il le modifierait ?
    Je ne peux pas reporter la modification sur str car d2i_x509 veut un u_str et non pas un str !

  8. #8
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 392
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 392
    Par défaut
    La fonction lit les données pointées, mais incrémente le pointeur.

    Code C++ : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    certificate(const char *str, size_t clen) { //Peut-être aussi en faire un char** ou char*&
    	unsigned char const *u_str = reinterpret_cast< unsigned char const * >(str);
    	X509* mycert = d2i_X509(NULL, &u_str, clen);
    	str = reinterpret_cast< char const * >(u_str);
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

Discussions similaires

  1. Réponses: 8
    Dernier message: 07/05/2008, 09h57
  2. [Appli Console]Pb exec command ac fct system(const char *)
    Par Le_magicien999 dans le forum MFC
    Réponses: 2
    Dernier message: 16/08/2005, 16h07
  3. Conversion CString en const char*
    Par LRobi dans le forum MFC
    Réponses: 8
    Dernier message: 19/07/2005, 12h12
  4. Réponses: 13
    Dernier message: 06/03/2005, 15h21
  5. Pb d'nitialisation d'un const char*
    Par davkick dans le forum C++
    Réponses: 9
    Dernier message: 09/12/2004, 16h27

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo