免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 689 | 回复: 0
打印 上一主题 下一主题

两道c语言题目 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-06-08 20:51 |只看该作者 |倒序浏览
1> 如何判断一个板子的cpu 是big-endian 还是 Little-endian的?
用c实现非常简单,10行左右,就可以判断了, 关键考察新人是否了解了什么是endian ,big-endian与little-endian的区别在哪里, 如果这些不清楚,就算c再强,也是憋不出来的。
2> 判断了 endian 后, 如何进行转换, 写两个函数。
如果说上面的那个, 可能不能正确的考察出新人的c水平,下面这个,可就可以显示了。
尤其是写一个宏, 来实现。 我觉得宏最能体现出一个人的水平了, 大家都知道一个功能强大的,但是写法又
非常简单的宏,是不好写的。 尤其是注意类型转换, 大扩号什么的。 写一个函数就容易多了。
实现起来,或者 用宏,或者 用函数的形式, 都可以, 最好都试一下。
主要看的就是宏的使用。
比如:
写成函数的形式:
typedef unsigned int u32 ;
typedef unsigned short u16 ;
u16 bswap16(u16);
u32 bswap32(u32);

写成宏的形式:

#define BSWAP_16(x)
....
#define BSWAP_32(x)
....
比如: 0x1234 变成: 0x3412
或者: 0x12345678 变成 : 0x78563412

---
在下面的回复写出来,就有点乱了, 干脆在这里铁出来吧 ,格式比较好:

1》判断endian的问题, 很简单。

判断endian :
#include stdio.h>
#include stdlib.h>
int main(void)
{
    short int a = 0x1234;
    char *p = (char *)&a;
   
    printf("p=%#hhx\n",*p);
    if(*p == 0x34)
        printf("Little endian \n");
    else if(*p == 0x12)
        printf("Big endian \n");
    else
        printf("Unknow endian \n");
    return 0;
}

2>如何进行转换:

#include stdio.h>
#include stdio.h>
typedef unsigned int u32;
typedef unsigned short u16;
#if 0
//simple: not check varible types
#define BSWAP_16(x) \
          ( (((x) & 0x00ff)  8 ) | \
     (((x) & 0xff00) >> 8 ) \
     )
//complex:check varible types
#else
#define BSWAP_16(x) \
     (u16) ( ((((u16)(x)) & 0x00ff)  8 ) | \
                 ((((u16)(x)) & 0xff00) >> 8 ) \
          )
#endif
#define BSWAP_32(x) \
     (u32) ( (( ((u32)(x)) & 0xff000000 ) >> 24) | \
                    (( ((u32)(x)) & 0x00ff0000 ) >> 8 ) | \
     (( ((u32)(x)) & 0x0000ff00 )  8 ) | \
     (( ((u32)(x)) & 0x000000ff )  24) \
              )
u16 bswap16(u16 x)
{
    return (x & 0x00ff)  8 |
     (x & 0xff00) >> 8
    ;
}
u32 bswap32(u32 x)
{
    return     ( x & 0xff000000 ) >>24 |
        ( x & 0x00ff0000 ) >>8 |
        ( x & 0x0000ff00 ) 8 |
        ( x & 0x000000ff )  24
    ;
}
   
int main(void)
{
    //u16 var_short = 0x123490;
    //u32 var_int = 0x1234567890;
    //关键是要能对错误进行处理,给一个0x123490 照样能得出 0x9034的值,而且, 占内存要小的
    printf("macro conversion:%#x\n",BSWAP_16(0x123490 ));//要能正确转换
    printf("macro conversion:%#x\n", BSWAP_32(0x1234567890)); //要能正确转换
   
    printf("-----------------\n");
   
    printf("function conversion:%#x\n",bswap16(0x123490));
    printf("function conversion:%#x\n", bswap32(0x1234567890));
   
   
    return 0;
}


本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u2/70722/showart_730134.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP