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++/CLI Discussion :

Encodage des chaînes de caractères


Sujet :

C++/CLI

  1. #1
    Expert éminent
    Avatar de StormimOn
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2005
    Messages
    2 593
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Sarthe (Pays de la Loire)

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

    Informations forums :
    Inscription : Mai 2005
    Messages : 2 593
    Points : 7 660
    Points
    7 660
    Par défaut Encodage des chaînes de caractères
    Bonjour,

    Ma question va sembler "bête", mais je suis confronté à quelque chose que je ne comprends pas donc je veux m'assurer d'une chose avant tout.

    En .Net les chaînes de caractères sont en unicode il me semble, quelle que soit l'origine de la donnée (lecture du contenu d'un fichier, ...). Si je converti ma chaîne de caractères en un pointeur (char *) avec la méthode StringToHGlobalAnsi pour ensuite recréer une chaîne de caractères managée
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    String ^ s1 = "äâàëêéèïîìöôòüûù";	
    char * c = static_cast<char*>(Marshal::StringToHGlobalAnsi(s1).ToPointer());	
    String ^ s2 = gcnew String(c, 0, s1->Length, Encoding::Default);
    il n'y a aucune "perte" possible au niveau des caractères et heureusement d'ailleurs, sinon bonjour le bordel. J'ai tout bon ou pas ?

    Je pose cette question parce que j'ai une API qui prend en entrée un char *, j'ai encapsulé l'appel à l'API dans un wrapper C++/CLI appelé par du C# et ce qui est bizarre c'est que suivant l'origine de la chaîne de caractères (lecture d'un fichier ou en dur dans le code), l'API ne réagit pas de la même façon.

    En fait je me fait jeter avec un message d'erreur comme quoi le format de la chaîne d'entrée est incorrect dans le cas où je passe par la lecture d'un fichier (j'utilise File.ReadAllText(chemin, Encoding.UTF8) pour la lecture) et la seule chose qui me vienne à l'esprit c'est un problème d'encodage des données.

    Si j'ai tout bon, il faudra que je vois du côté de l'API.

  2. #2
    Rédacteur
    Avatar de nico-pyright(c)
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    6 414
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 6 414
    Points : 16 075
    Points
    16 075
    Par défaut
    Salut StormimOn,

    je ne suis pas un pro des encodages, d'ailleurs ca m'enerve

    mais ce qui est certain c'est qu'un char ne peut contenir qu'un octet, donc une valeur ascii entre 0 et 255. C'est l'intéret de l'unicode ou des utf-32, de pouvoir stocker plus de valeurs afin de gérer plus de caractères.

    Donc, si tu convertis en char, il y a une possibilité de perte, enfin je pense

    Pourquoi tu n'utilises pas des wchar_t unicode ? la conversion est plus simple et moins risquée en plus. A moins que ton api n'ait besoin de char *

  3. #3
    Expert éminent
    Avatar de StormimOn
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2005
    Messages
    2 593
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Sarthe (Pays de la Loire)

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

    Informations forums :
    Inscription : Mai 2005
    Messages : 2 593
    Points : 7 660
    Points
    7 660
    Par défaut
    Ok, donc dans mon cadre il n'y a pas de risque de perte de données (stockage UTF-8 ou en dur dans le code, sans utilisation de caractères spéciaux, donc compatible avec le char *). Je vais essayer de voir du côté de l'API si je peux avoir des infos.

    Merci

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Encodage des chaînes de caractères en arabe
    Par elghali_sofiene dans le forum VB 6 et antérieur
    Réponses: 1
    Dernier message: 19/04/2007, 18h10
  2. [VBS]Gestion des chaînes de caractères
    Par Edoxituz dans le forum VBScript
    Réponses: 11
    Dernier message: 29/01/2006, 17h07
  3. Gestion des chaînes de caractères
    Par Furius dans le forum VBScript
    Réponses: 5
    Dernier message: 06/01/2006, 15h01
  4. Problème sur des chaînes de caractères
    Par Anonymous dans le forum Access
    Réponses: 9
    Dernier message: 16/09/2005, 08h21
  5. Passage des chaînes de caractères à une application CGI
    Par Thom@s dans le forum Composants VCL
    Réponses: 10
    Dernier message: 03/12/2004, 00h13

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