Fathilde
Messages postés16Date d'inscriptionmardi 14 avril 2009StatutMembreDernière intervention19 mai 2009
-
29 avril 2009 à 16:44
Fathilde
Messages postés16Date d'inscriptionmardi 14 avril 2009StatutMembreDernière intervention19 mai 2009
-
5 mai 2009 à 08:15
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...
cptpingu
Messages postés3837Date d'inscriptiondimanche 12 décembre 2004StatutModérateurDernière intervention28 mars 2023123 4 mai 2009 à 20:36
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.
cptpingu
Messages postés3837Date d'inscriptiondimanche 12 décembre 2004StatutModérateurDernière intervention28 mars 2023123 1 mai 2009 à 04:03
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;
}
Fathilde
Messages postés16Date d'inscriptionmardi 14 avril 2009StatutMembreDernière intervention19 mai 2009 4 mai 2009 à 11:32
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)