前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >考察新人的两道c语言题目

考察新人的两道c语言题目

作者头像
Java架构师必看
发布2021-03-22 11:08:19
6970
发布2021-03-22 11:08:19
举报
文章被收录于专栏:Java架构师必看

1>如何判断一个板子的cpu是big-endian还是Little-endian的?用c实现C/C++

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; }

本文由来源 21aspnet,由 javajgs_com 整理编辑,其版权均为 21aspnet 所有,文章内容系作者个人观点,不代表 Java架构师必看 对观点赞同或支持。如需转载,请注明文章来源。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档