Problème de comprehension de programme... [Résolu]

Signaler
Messages postés
16
Date d'inscription
mardi 14 avril 2009
Statut
Membre
Dernière intervention
19 mai 2009
-
Messages postés
16
Date d'inscription
mardi 14 avril 2009
Statut
Membre
Dernière intervention
19 mai 2009
-
Bonjour à tous,

Dans le cadre de mon stage je dois faire un programme en C++ (à l'aide de Borland C++) pour identifier des tags RFID, j'utilise pour cela un code (exemple) fourni par le fournisseur mais n'étant pas très familiére avec le C++ je ne comprend pas cette partie du code:

char* Tag2Ascii(MW_IDT tag) {
  int i;
  int j;
  static char str[20];
  j = 0;
  for (i = 0; i < sizeof(MW_IDT); i++) {
    str[j++] = "0123456789ABCDEF"[(tag[i]>>4)&0x0f];
    str[j++] = "0123456789ABCDEF"[(tag[i]>>0)&0x0f];
  }
  str[j] = '\0';
  return str;
}

Je sais que cette application me renvoi les ID de mes tags et je dois dans mon application recuperer ces ID, et les analyser pour pouvoir dire a quoi elles sont associées (peut-être avec un IF?).

Exemple:
Le programme me renvoi 0000030C00003872FF
je dois pouvoir afficher que cela correspond à une remorque...

Merci pour votre aide

4 réponses

Messages postés
3829
Date d'inscription
dimanche 12 décembre 2004
Statut
Modérateur
Dernière intervention
8 janvier 2021
114
Mis à jour, avec les éléments que tu m'as donné.

char* Tag2Ascii(MW_IDT tag)
{
  int i;
  int j;
  static char str[20];
Cette
ligne veut dire que tu as une variable globale dont la portée est
limité à cette fonction. Je suppose que c'est là par souci
d'optimisation, et pour simplifier un peu le code, puisque tu aurais
été obligé, sans cela d'instancier une chaîne, ou en passer une
argument.
  j = 0;
  for (i = 0; i < sizeof(MW_IDT); i++)
(MW_IDT) est un tableau statique de 9 case, donc sizeof (MW_IDT) vaut 9 et on fera 9 tour de boucle (de 0 à 8 compris).
  {
    str[j++] = "0123456789ABCDEF"[(tag[i]>>4)&0x0f];
On va décomposer cette ligne en plusieurs instructions:
int tmp = tag[i] >> 0;
Ici on récupère le ième élément, et on décale le résultat de 0 bit vers la droite, ce qui revient à ne rien faire.
Exemple:
100 >> 0 => 100, 100 >> 4 => 6. Renseigne toi sur les
décalage de bit, si tu ne comprends pas ces résultats.
tmp = tmp & 0x0f;
On applique ensuite un masque sur les 4 bits de poids faibles. Seul ceux-ci seront pris en compte, tout le reste sera mis à 0.
char tab[] = "0123456789ABCDEF";
str[j] = tab[tmp];
Enfin,
on stocke dans le caractère en cours de str, le caractère contenu dans
tab correspondant qui est à la position tmp, que l'on à calculé
précédemment.
j++;
On passe alors à la case suivante, dans str
  }
  str[j] = '\0';
On
oublie pas le caractère terminal, pour indiquer la fin de la chaîne,
surtout si celle-ci n'est pas remplit au maximum de sa capacité, il ne
faut pas présumer que toutes les cases restantes vaudront forcément
zéro !
  return str;
}

Je t'ai expliqué, ligne à ligne ce code. Je ne peux rien faire de plus.
Bonne chance.
Messages postés
3829
Date d'inscription
dimanche 12 décembre 2004
Statut
Modérateur
Dernière intervention
8 janvier 2021
114
Ca ressemble plus à du C qu'à du C++.
Il me manque des éléments:
- A quoi correspond MW_IDT ?
- Que contient tag ? (Je suppose que c'est une chaîne de caractères, ou un tableau ?

char* Tag2Ascii(MW_IDT tag)
{
  int i;
  int j;
  static char str[20];
Cette ligne veut dire que tu as une variable globale dont la portée est limité à cette fonction. Je suppose que c'est là par souci d'optimisation, et pour simplifier un peu le code, puisque tu aurais été obligé, sans cela d'instancier une chaîne, ou en passer une argument.
  j = 0;
  for (i = 0; i < sizeof(MW_IDT); i++)
Si on suppose que MW_IDT est un pointeur, alors c'est super bizare, car dans ce cas tu ne feras que 4 tours de boucle, quoiqu'il arrive (pour un tableau de 20 éléments, c'est étrange).
  {
    str[j++] = "0123456789ABCDEF"[(tag[i]>>4)&0x0f];
Vu que je ne connais pas le type de tag[i], je vais supposer que c'est un tableau. Si ce n'était pas un tableau, mais une valeur entière, ce serait différent. A noter qu'il est possible de faire une addition, grâce au tableau.
Par exemple: 8 + 2 peut aussi s'écrire : (int)&((char*)8)[2] ou (int)&((char*)2)[8].
    str[j++] = "0123456789ABCDEF"[(tag[i]>>0)&0x0f];
On va décomposer cette ligne en plusieurs instructions:
int tmp = tag[i] >> 0;
Ici on récupère le ième élément, et on décale le résultat de 0 bit vers la droite, ce qui revient à ne rien faire.
Exemple: 100 >> 0 => 100, 100 >> 4 => 6. Renseigne toi sur les décalage de bit, si tu ne comprends pas ces résultats.
tmp = tmp & 0x0f;
On applique ensuite un masque sur les 4 bits de poids faibles. Seul ceux-ci seront pris en compte, tout le reste sera mis à 0.
char tab[] = "0123456789ABCDEF";
str[j] = tab[tmp];
Enfin, on stocke dans le caractère en cours de str, le caractère contenu dans tab correspondant qui est à la position tmp, que l'on à calculé précédemment.
j++;
On passe alors à la case suivante, dans str
  }
  str[j] = '\0';
On oublie pas le caractère terminal, pour indiquer la fin de la chaîne, surtout si celle-ci n'est pas remplit au maximum de sa capacité, il ne faut pas présumer que toutes les cases restantes vaudront forcément zéro !
  return str;
}
Messages postés
16
Date d'inscription
mardi 14 avril 2009
Statut
Membre
Dernière intervention
19 mai 2009

Voila ce que j'ai reussi à trouver dans mon programme:
-typedef unsigned char MW_IDT[9];
et si j'execute ceci:
cout << "Tag #" << i << ": " << Tag2Ascii(tags[i]) << endl;
J'obtiens:
0004030C00003870FF par exemple (ID d'un de mes tags)

Merci de ton aide
Messages postés
16
Date d'inscription
mardi 14 avril 2009
Statut
Membre
Dernière intervention
19 mai 2009

Merci beaucoup!!