Maison > Questions et réponses > le corps du texte
Si vous utilisez le compilateur GCC pour exécuter le programme suivant sous Linux, quel est le résultat ?
#include<stdio.h>
int main(){
char c=127;
printf("%d",++c);
printf("%d",++c);
return 0;
}
Sachez simplement que cela implique une conversion de type, une troncature et un remplissage des données. Mais vous ne connaissez pas l’explication précise ?
Source de la question originale : Plusieurs questions d'entretien classiques en langage C sous Linux
巴扎黑2017-06-26 11:01:02
char
的长度是 1 字节,并且,大多数的机器都将其视为有符号数的,所以它的表示范围是 [-128, 127]
(参见《深入理解计算机系统》P27~P28)。所以,当你给 c
赋值 127 时,你执行了 ++c
, cela provoquera alors un débordement, car il ne contient qu'un seul octet.
représente 127 dans la machine. Une fois converti en binaire, cela ressemble à ceci 01111111
,可以看到,当你加 1 之后,结果就变成了 10000000
,由于在计算机内部,负数是用补码来表示的,所以就变成了 -128。之后再 ++c
, qui vaut -127.
Quant aux différents types, ils se comportent tous de la même manière à l'intérieur de l'ordinateur, qui est un morceau de mémoire. Le type n’est donc pas une limitation.
天蓬老师2017-06-26 11:01:02
Cette question teste 编译器
, pas la langue.
Définissez 3 variables :
char c; // 表示一个 ascii字符
signed char s_c; //有符号 1字节 整数
unsigned char u_c; //无符号 1字节 整数
En langage C, lorsque c participe au calcul, le fait que c soit converti en s_c ou u_c est déterminé par 编译器
.
gcc considère c comme signé, et les calculs et sorties ultérieurs sont traités comme des nombres signés.