判断机器是否是大端法存储(来散散分,各抒己见)

qhh0205
博客专家认证
2016-03-18 05:09:27
闲话不多说,直接上代码...
//  判断机器是否是大端存储
bool IsBigEndia(void)
{
short int n = 0x1234;
char *pn = (char *)&n;
if (*pn == 0x12)
{
return true;
}
return false;
}
...全文
234 15 打赏 收藏 转发到动态 举报
写回复
用AI写文章
15 条回复
切换为时间正序
请发表友善的回复…
发表回复
sdghchj 2016-03-22
  • 打赏
  • 举报
回复
short n=1; return *(char*)&n == 0;
qhh0205 2016-03-21
  • 打赏
  • 举报
回复
过两天结贴!差不多了!
wang0635 2016-03-21
  • 打赏
  • 举报
回复
引用 楼主 qianghaohao 的回复:
闲话不多说,直接上代码...
//  判断机器是否是大端存储
bool IsBigEndia(void)
{
    short int n = 0x1234;
    char *pn = (char *)&n;
    if (*pn == 0x12)
    {
        return true;
    }
    return false;
}
你能确保short是16位的?我用的是

        int        a = 0x1234;
        return !(*(char *)&a == 0x34);
赵4老师 2016-03-21
  • 打赏
  • 举报
回复
理解讨论之前请先学会如何观察! 计算机组成原理→DOS命令→汇编语言→C语言(不包括C++)、代码书写规范→数据结构、编译原理、操作系统→计算机网络、数据库原理、正则表达式→其它语言(包括C++)、架构…… 对学习编程者的忠告: 多用小脑和手,少用大脑、眼睛和嘴,会更快地学会编程! 眼过千遍不如手过一遍! 书看千行不如手敲一行! 手敲千行不如单步一行! 单步源代码千行不如单步Debug版对应汇编一行! 单步Debug版对应汇编千行不如单步Release版对应汇编一行! 不会单步Release版对应汇编?在你想单步Release版C/C++代码片断的前面临时加一句DebugBreak();重建所有,然后在IDE中运行。(一般人我不告诉他!) VC调试时按Alt+8、Alt+7、Alt+6和Alt+5,打开汇编窗口、堆栈窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应堆栈、内存和寄存器变化,这样过一遍不就啥都明白了吗。 对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
szn_409 2016-03-20
  • 打赏
  • 举报
回复
弄个int值到内存里看看就知道了。。。
cocoabird 2016-03-19
  • 打赏
  • 举报
回复
补充下:c和i都是从低地址开始对齐的
cocoabird 2016-03-19
  • 打赏
  • 举报
回复
BOOL  isBigEndian()
    {
       union
       {
          int  i;
            char  c;
       }test;
       
         test.c = 2;
     
        return  test.i != 2;
    }
lm_whales 2016-03-19
  • 打赏
  • 举报
回复
char *ByteOrder(){ int i=1; if(1 == *( (char*)&i) ) {return "II"; else return "MM"; } 话说,一般来说,不用判断字节序, 因为CPU类型,编译器的开发者都知道。 对应CPU的程序开发者,也都知道。 这东西,应该是个宏
动力风暴 2016-03-18
  • 打赏
  • 举报
回复
以前看资料看到过这个: 试题1:请写一个C函数,若处理器是Big_endian的,则返回0;若是Little_endian的,则返回1   解答: int checkCPU() {  {   union w   {    int a;    char b;   } c;   c.a = 1;   return (c.b == 1);  } }   剖析:   嵌入式系统开发者应该对Little-endian和Big-endian模式非常了解。采用Little-endian模式的CPU对操作数的存放方式是从低字节到高字节,而Big-endian模式对操作数的存放方式是从高字节到低字节。例如,16bit宽的数0x1234在Little-endian模式CPU内存中的存放方式(假设从地址0x4000开始存放)为: 内存地址存放内容 0x40000x34 0x40010x12   而在Big-endian模式CPU内存中的存放方式则为: 内存地址存放内容 0x40000x12 0x40010x34   32bit宽的数0x12345678在Little-endian模式CPU内存中的存放方式(假设从地址0x4000开始存放)为: 内存地址存放内容 0x40000x78 0x40010x56 0x40020x34 0x40030x12   而在Big-endian模式CPU内存中的存放方式则为: 内存地址存放内容 0x40000x12 0x40010x34 0x40020x56 0x40030x78   联合体union的存放顺序是所有成员都从低地址开始存放,面试者的解答利用该特性,轻松地获得了CPU对内存采用Little-endian还是Big-endian模式读写。如果谁能当场给出这个解答,那简直就是一个天才的程序员。
小灸舞 2016-03-18
  • 打赏
  • 举报
回复
顶起
ztenv 版主 2016-03-18
  • 打赏
  • 举报
回复
茴香豆的茴有几种写法?
qhh0205 2016-03-18
  • 打赏
  • 举报
回复
引用 2 楼 paschen的回复:
http://blog.csdn.net/cai0538/article/details/7185564
学习了,学习了
qhh0205 2016-03-18
  • 打赏
  • 举报
回复
引用 1 楼 cutmelon的回复:
你都这样写了。。。。 [quote=引用 楼主 qianghaohao 的回复:] 闲话不多说,直接上代码...
//  判断机器是否是大端存储
bool IsBigEndia(void)
{
    short int n = 0x0100;
    return *((bool *)&n);
}
[/quote] 学习了,学习了
paschen 版主 2016-03-18
  • 打赏
  • 举报
回复
cutmelon 2016-03-18
  • 打赏
  • 举报
回复
你都这样写了。。。。
引用 楼主 qianghaohao 的回复:
闲话不多说,直接上代码...
//  判断机器是否是大端存储
bool IsBigEndia(void)
{
    short int n = 0x0100;
    return *((bool *)&n);
}

64,654

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧