|
|
|
|
 请问下面程序的输出为什么是1,-1,-4? - zhhhuang [ 2005-10-24 13:27 | 577 byte(s)]
 Re: 请问下面程序的输出为什么是1,-1,-4? - antzcn [ 2005-10-25 21:05 | 208 byte(s)]
 Re: 请问下面程序的输出为什么是1,-1,-4? - whone23 [ 2005-10-26 09:22 | 409 byte(s)]
 Re: 请问下面程序的输出为什么是1,-1,-4? - zxm927 [ 2005-10-25 11:28 | 1,179 byte(s)]
 Re: 请问下面程序的输出为什么是1,-1,-4? - sportstiger [ 2005-10-25 20:57 | 820 byte(s)]
 Re: 请问下面程序的输出为什么是1,-1,-4? - lxmxml [ 2005-10-25 11:16 | 750 byte(s)]
|
|
|
|
[Original]
[Print]
[Top]
|
#include <stdio.h>
#include <stdlib.h>
#include <iostream.h>
struct bit
{ int a:3;
int b:2;
int c:3;
};
int main()
{
bit s;
char *c = (char*)&s;
*c = 0x99;
cout << s.a <<endl <<s.b<<endl<<s.c<<endl;
return 0;
}
运行在intel平台下的Linux2.4.18
|
|
|
----
|
|
[Original]
[Print]
[Top]
|
|
[Original]
[Print]
[Top]
|
#include <stdio.h>
#include <stdlib.h>
#include <iostream.h>
struct bit
{
int a:3;
int b:2;
int c:3;
};
int main()
{
bit s;
char *c = (char*)&s;
*c = 0x99;
cout << s.a <<endl <<s.b<<endl<<s.c<<endl;
return 0;
}
int a:3的意思是a占3个bit依次类推
用debug查看内存。
初始化时是CC即11001100其中c:110 b01 a:100
故初始为c -2 b 1 a -4
c指向s,*c=0x99后,CC变为99,即100 11 001故a=1 b= -1 c= -4
|
|
|
[Original]
[Print]
[Top]
|
|
[Original]
[Print]
[Top]
|
我也看不懂。这是我的机器上的一段反汇编代码(我改成printf了,结果也一样),一会算术移,一会逻辑移,也没看出怎么移出-1来.
0x080483a2 <main+58>: mov 0xfffffffc(%ebp),%al
0x080483a5 <main+61>: sar $0x5,%al
0x080483a8 <main+64>: movsbl %al,%eax
0x080483ab <main+67>: push %eax
0x080483ac <main+68>: mov 0xfffffffc(%ebp),%al
0x080483af <main+71>: shl $0x3,%eax
0x080483b2 <main+74>: sar $0x6,%al
0x080483b5 <main+77>: movsbl %al,%eax
0x080483b8 <main+80>: push %eax
0x080483b9 <main+81>: mov 0xfffffffc(%ebp),%al
0x080483bc <main+84>: shl $0x5,%eax
0x080483bf <main+87>: sar $0x5,%al
0x080483c2 <main+90>: movsbl %al,%eax
0x080483c5 <main+93>: push %eax
0x080483c6 <main+94>: push $0x80484d0
0x080483cb <main+99>: call 0x80482b0 <_init+56>
|
|
|
[Original]
[Print]
[Top]
|
|
[Original]
[Print]
[Top]
|
lxmxml:
#include <stdio.h>
#include <stdlib.h>
#include <iostream.h>
struct bit
{
int a:3;
int b:2;
int c:3;
};
int main()
{
bit s;
char *c = (char*)&s;
*c = 0x99;
cout << s.a <<endl <<s.b<<endl<<s.c<<endl;
return 0;
}
int a:3的意思是a占3个bit依次类推
用debug查看内存。
初始化时是CC即11001100其中c:110 b01 a:100
故初始为c -2 b 1 a -4
c指向s,*c=0x99后,CC变为99,即100 11 001故a=1 b= -1 c= -4
嘿嘿,补充一点:最高位为符号位所以a=-1 b=-1 c=-4
|
|
|
[Original]
[Print]
[Top]
|
|
[Original]
[Print]
[Top]
|
100(算术右移)
=>1111 1111 1111 1100 = -4
11(算术右移)
=>1111 1111 1111 1111 = -1
001(算术右移)
=>0000 0000 0000 0001 = 1
|
|
----
Freedom!
|
|
[Original]
[Print]
[Top]
|
|
[Original]
[Print]
[Top]
|
100(算术右移)
=>1111 1111 1111 1100 = -4
11(算术右移)
=>1111 1111 1111 1111 = -1
001(算术右移)
=>0000 0000 0000 0001 = 1
再说明白一点,最高位是1,就向左补齐1,最高位是0,就补0,然后按补码看,
如100,最高位是1,按32位补齐成1111 1111 1111 1100 ,这是补码,还原成原码,减一取反为100,负的100,即-4
|
|
|
[Original]
[Print]
[Top]
|
|
|