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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值