C获取系统是32位还是64位

方法一:

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字节)

你可能感兴趣的:(c,OS,System,编译器)