4235|4

84

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

获取CPU采用Big-ending或者Little-ending的方法 [复制链接]

int chekCPU()
{
    union w
    {
          int a;
          char b;
     } c;
     c.b=1;
     return (c.b == 1 );//主要是这句
}

我已经了解union的存放顺序是所有成员都从低地址开始存放,但 这句 c.b == 1 应该怎样理解?

最新回复

#include "stdafx.h" int main(int argc, char* argv[]) {         if( 'X' == ( ( ( *( unsigned short * )"XP" ) >> 8 ) & 0xff ) )         {                 printf( "big\r\n" );         }         else         {                 printf( "little\r\n" );         }         return 0; }复制代码 前面写的错了,这个   详情 回复 发表于 2010-4-7 09:48
点赞 关注

回复
举报

76

帖子

0

TA的资源

一粒金砂(初级)

沙发
 
应该是c.a==1判断a是否等于1,等于1大端序不等于1小端序
 
 

回复

63

帖子

0

TA的资源

一粒金砂(初级)

板凳
 
另一种方法

if( ( ( "XP" >> 8 ) & 0xff ) == 'X' )
{
    // 大头
}
else
{
    // 小头
}

不过俺从来都使用宏定义来直接决定
 
 
 

回复

81

帖子

0

TA的资源

一粒金砂(初级)

4
 
引用 2 楼 jennyvenus 的回复:
另一种方法

if( ( ( "XP" >> 8 ) & 0xff ) == 'X' )
{
  // 大头
}
else
{
  // 小头
}

不过俺从来都使用宏定义来直接决定


闲杂大家基本都是用宏定义 。

MARK/.
 
 
 

回复

71

帖子

0

TA的资源

一粒金砂(初级)

5
 

  1. #include "stdafx.h"

  2. int main(int argc, char* argv[])
  3. {
  4.         if( 'X' == ( ( ( *( unsigned short * )"XP" ) >> 8 ) & 0xff ) )
  5.         {
  6.                 printf( "big\r\n" );
  7.         }
  8.         else
  9.         {
  10.                 printf( "little\r\n" );
  11.         }
  12.         return 0;
  13. }
复制代码

前面写的错了,这个
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表