20171104作业
来源:互联网 发布:java内存模型书籍 编辑:程序博客网 时间:2024/06/06 00:16
1.如何用指针、结构体判断大小端?
1、利用指针强制类型转换
#include <stdio.h>
int main(void)
{
int data1 = 0x12345678;
int i;
for(i=0; i<4; i++)
{
printf("%#x ----->%p\n",*((char *)&data1 + i),(char *)&data1 + i);
}
return 0;
}
从输出的结果可以看出,高位地址0xbfc1b1ff存的是数据的高位0x12,低位地址0xbfc1b1fc存的是数据的低位0x78。所以是小端。同时我们亦可以看到,对数据data取地址实际指向的是存放低位数据的空间。
2.if与switch的区别
如果纯粹比较数字或字符,建议使用switch,因为它只会在一开始的switch括号中取出变量值一次,然后将这个值与下面所设定的case比较,但如果使用if,每次遇到条件式时,都要取出变量值,效率的差异就在这儿。例如:
if(a == 1)
//...
else if(a == 2)
//...
else if(a == 3)
//...
这个程序片段在最差的状况下,也就是a = 3时,共需3次比较,而每次比较都必须取出变量a的值一次。如果换成switch:
switch(a)
{
case 1:
//...
break;
case 2:
//...
break;
case 3:
//...
break;
}
在这个程序片段中,只在开头switch的括号中取出变量a的值,然后逐一比较下面的case,效率的差别就在这儿。当然并不是使用if就不好,遇到复合条件时,switch就帮不上忙了,由于无法在switch中组合复杂的条件语句,这时就得使用if了。简单地说,if与switch两者可以搭配着灵活使用。
3.汇编语言
- 20171104作业
- 作业
- 作业
- 作业
- 作业
- 作业
- 作业
- 作业
- 作业
- 作业
- 作业
- 作业~~~~~~~~~~~~~
- 作业
- 作业
- 作业
- 作业
- 作业
- 作业
- Mysql学习总结2
- Linux高性能服务器编程--线程池
- “戏”说spark---spark Shuffle详解(二)
- Google替代、阿里协作,人工智能不只有乐观与悲观之争
- 新媒体运营,微博运营简介与操作
- 20171104作业
- Jquery 的获取元素标签
- 通过可视化数据分析提升测试质量
- 权限申请
- VM中ubuntu安装vmware tools
- Tomcat Can't load AMD 64-bit .dll on a IA 32
- 如何让我们程序员走得更远
- 拦截器
- web 容器之tomcat