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 :

Méthode de compression : cast sensible


Sujet :

C

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    104
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 104
    Points : 84
    Points
    84
    Par défaut Méthode de compression : cast sensible
    Bonsoir,

    Alors voilà je devais mettre au point une méthode de compression pour les nombres entiers positifs. Au lieu d'écrire un petit int sur 4 octets, mieux vaut l'écrire sur le nombre de bits adéquats. Bon l'algorithme fonctionne bien.

    L'algorithme est performant pour des petits nombres, en gros sur chaque octet 7 bits servent à code le nombre et le dernier dit si la lecture continue ou non.

    Le problème c'est lorsque je veux caster un int en (unsigned char), plus rien ne fonctionne normalement et la solution revient à ne rien caster du tout, et on laisse le car tronquer de lui même en gros.

    Je vous montre le bout de code :

    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
    void
    ecrire_entier(void* fichier, unsigned int nombre)
    {
        static unsigned char tableau[NB_OCTETS];
        unsigned char tmp;
        int i;
        int c = 0;
     
        for (i = NB_OCTETS - 1; i >= 0; i--)
        {
    	tmp = ((nombre & ((1 << 7) - 1) << 7 * i)) >> 7 * i;
    	if (tmp > 0 || c > 0 || i == 0)
    	{
    	    if (i > 0)
    	    {
    		BIT_A_1(tmp, 7);
    	    }
    	    tableau[c] = tmp;
    	    c++;
    	}
        }
        fwrite(tableau, sizeof(char), c, fichier);
    }
    Le castage se situe au niveau de l'affectation de la variable tmp, quelqu'un sait pourquoi le fait de caster en unsigned char ou en char fausse tout le résultat ? (ici je l'ai enlevé et ça fonctionne très bien maintenant). Y a t-il une subtilité du langage ?

    Merci à vous.

    Bye.

  2. #2
    Membre expérimenté
    Profil pro
    Développeur en systèmes embarqués retraité
    Inscrit en
    Mars 2006
    Messages
    946
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2006
    Messages : 946
    Points : 1 351
    Points
    1 351
    Par défaut
    Salut,

    Ta compression est exactement celle employée dans le Bxml (binary xml) pour le codage d'offsets dans ses tables de chaines. C'est une version très compressée (et illisible pour un humain) de fichiers Xml.

    La différence entre un type signé et un non signé réside dans l'interprétation du bit de poids fort. Dans un cas, c'est un bit normal, dans l'autre, c'est le bit de signe. S'il est à 1, il faut faire le complément à 2 et ajouter 1 pour avoir la valeur absolue. D'où vraisemblablement ton problème de cast.

    A+

    Pfeuh

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    104
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 104
    Points : 84
    Points
    84
    Par défaut
    D'accord merci à toi ;-)

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

Discussions similaires

  1. cast et surcharge d'une méthode
    Par fenrir22 dans le forum Débuter avec Java
    Réponses: 5
    Dernier message: 19/04/2011, 13h32
  2. [ZipArchive] Changer la méthode de compression
    Par birdyz53 dans le forum Bibliothèques et frameworks
    Réponses: 2
    Dernier message: 27/07/2009, 10h58
  3. [Générics] Méthode de cast
    Par JohnNC dans le forum Langage
    Réponses: 8
    Dernier message: 26/02/2009, 16h48
  4. [compression] meilleur méthode
    Par daladim dans le forum Autres Logiciels
    Réponses: 6
    Dernier message: 27/10/2006, 12h27
  5. Méthode find sensible aux cellules fusionnées?
    Par spileo dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 12/09/2006, 01h22

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