<html><head><meta name="qrichtext" content="1" /></head><body style="font-size:10pt;font-family:Bitstream Vera Serif">
<p>On Wednesday 28 September 2005 12:08, Leopoldo Ghielmetti wrote:</p>
<p></p>
<p>> Je ne dirais pas que C est fortement typé, il est typé mais pas</p>
<p>> fortement.</p>
<p></p>
<p>Je crois que nous divergeons au sujet de la notion de "type". C EST un langage type dans le sens ou aucun symbole ne peut etre utilise sans une definition ! De plus, toutes les fonctions sont aussi typee, meme si l'absence de declaration implique un 'int' par defaut. Par exemple, on ne peut ecrire :</p>
<p></p>
<p>int toto()</p>
<p>{</p>
<p> return;</p>
<p>}</p>
<p></p>
<p>Le compilateur n'aime pas... </p>
<p></p>
<p>> C permet des conversion tacites entre types, chose qui </p>
<p>> affaiblit son typage.</p>
<p></p>
<p>Stop ! Toutes les conversion "autorisees" entre certains type sont explicitement definies par le standard ANSI. Il n'y a aucune zone d'ombre... De plus, lors de conversion implicite dans le passage de parametres dans des fonctions, ou lors d'assignation a un type "autorise" mais different, des limitations sont verifiees et notifiees si necessaire. C'est particulierement vrai pour les suites 'long -> int -> short' et 'double -> float'. Dans chacun de ces cas, il y a risque de perte de precision ou de valeurs. Or, ceci doit etre detecte par le compilateur. Comme il est evident que l'on ne peut ecrire :</p>
<p></p>
<p>float f;</p>
<p>char s[10];</p>
<p></p>
<p>f = s;</p>
<p>s = f;</p>
<p></p>
<p>Il donc bien d'un langage "type" qui ne permet pas n'importe quoi. Il est donc beaucoup plus limitatif que Python (par exemple) qui permet d'effectuer le genre d'ecriture ci-dessus, simplement parce que l'on peut redefinir des operateurs internes de conversion : __str__, __repr__, etc.</p>
<p></p>
<p>Il est bien entendu que ce que j'ai mentionne a propos de C n'est valable qu'a condition que l'on utilise la compilation en mode ANSI et que toutes les signatures de donctions soient declarees !</p>
<p></p>
<p>> Un langage fortement typé se plaint même si on </p>
<p>> fait une chose pareille:</p>
<p>> int a</p>
<p>> long b</p>
<p>> float c</p>
<p>> a = 5</p>
<p>> b = a <--- Erreur, int <> long</p>
<p></p>
<p>Non, il n'y a pas de perte de precison. Par contre l'inverse si !</p>
<p></p>
<p>> c = a <--- Erreur, int <> float</p>
<p></p>
<p>Non plus... Dans le cas inverse, ca devrait etre flaguer car un float (32 bits IEEE) donne 6.7 chiffres significatifs, alors que int nous donne un peu plus de 9 chiffres significatifs... </p>
<p></p>
<p>> Tandis que C laisse passer et considère ça comme:</p>
<p>> b = (long)a</p>
<p>> c = (float)a</p>
<p></p>
<p>C'est exactement l'operation qui est effectuee. Et cela ne pose aucun probleme du tout. Par contre, C permet d'ecrire ceci :</p>
<p></p>
<p>double d;</p>
<p>short i;</p>
<p>void *p;</p>
<p></p>
<p>p = &d;</p>
<p>i = *(short *)(p); /* Different de : i = (short)(*p) !!! */</p>
<p></p>
<p>Il y a perte de precision evidente et le compilateur n'y voit que du feu ! C'est la le vrai danger du C.</p>
<p></p>
<p>Ces regles sont exactement les memes que pour le 'C++' ! A la difference pret que C++ donne la possibilite d'ecrire du code qui peut "oriente" les conversions selon les desires du programmeurs.</p>
<p></p>
<p>> Celle-ci c'est l'une des principales faiblesses du C qui pose des</p>
<p>> problèmes de compatibilité et qui d'ailleurs avait fait tomber l'Ariane</p>
<p>> 5 lors du premier lancement car une routine était faite pour traiter des</p>
<p>> short (16 bits) et qui avait été utilisée pour la nouvelle fusée qui</p>
<p>> utilisait des int (32 bits) ou quelque chose dans le genre, pendant le</p>
<p>> vol il y a eu un dépassement et les calculs ont foiré. Boummm!</p>
<p></p>
<p>Boum sur les doigts de ceux qui ont ecrit le code !!!!!!!!! Le compilateur a parfaitement les moyens de verifier que l'on manipule bien des API equivalentes. Or, dans ce cas, le/les programmeurs ont sans doute commis une erreur (que je considere comme grave) dans la declaration de l'API. Mais,meme dans le cas ou ils auraient ommis la declaration de la signature des fonctions de l'API, ou declares des 'int', ils auraient du recevoir les warnings du compilateur. Donc, soit ils ont utilise le compilateur de mode "standard C", soit ils ont ignores les warnings, soit... Dans tous les cas, il s'agit d'une negligence qui a ete commise sciemment !</p>
<p></p>
<p>dc</p>
</body></html>