方法一:
typedef int type;
#define OS_BITS (((int)((type *)0 + 1)) << 3)
方法二:
#include <stdio.h>
#include <string.h>
char buf[17];
int main(int argc, char* argv[])
{
int *p=(int *)-1;
sprintf(buf,"%X",p);
printf("System is %d bit.\n",strlen(buf)*4);
}
这样做的方法都不对,这样只能知道编译器是什么型的,不能知道系统是什么型的。
因为想(int *)或者sizeof(int)都是由编译器处理的东西,它们的长度由编译器确定,并不受目标系统的影响。
编译器屏蔽了硬件细节。应用层看不出什么内容,从OS内部或者驱动去获取详
我是這麼寫的,想法是將-1存入某個寄存器,然後對寄存器做移位操作,直到為0,記錄操作步數。後來發現eax總是32位的,無論是32位CPU還是64位CPU。對彙編不太熟悉,應該可以找到這樣一個寄存器。
#include <stdio.h>
int main(int argc,char **argv)
{
int i=0;
double a=0;
__asm
{
mov eax,-1;
start:
cmp eax,0;
je end;
shl eax,1;
mov ecx,i;
inc ecx;
mov i,ecx;
jmp start;
end:
}
printf("%d\n",i);
return 0;
}
为了代码兼容,EAX都是32位的,64位的是RAX,当然你如果在32位系统里用了带RAX的指令,执行时肯定有非法指令错误。
很多编译器选择的整数模型中32/64都是32位int。
补充:intel32位机器中机器字长(寄存器最大长度)是32位,intel64位机器中机器字长是64位,intel64指令集保持了与intel32指令集向后兼容并增加了新的指令集,一般gcc编译器规定intel64和intel32中标准数据类型大小:
C声明 intel64 intel32
char 1 1
short 2 2
int 4 4
long int 8 4
long long 8 8
char * 8 4
float 4 4
double 8 8
long double10/16 10/12(不管是分配12字节还是16字节,实际只会用到最低位的10字节)