没有合适的资源?快使用搜索试试~ 我知道了~
存取效率的比较-非高斯噪声环境下基于rls的稀疏信道估计算法
需积分: 49 1.3k 下载量 113 浏览量
2021-06-03
23:54:48
上传
评论
收藏 755KB PDF 举报
温馨提示
(6)存取效率的比较 char s1[]=”aaaaaaaaaaaaaaa”; char *s2=”bbbbbbbbbbbbbbbbb”; aaaaaaaaaaa 是在运行时刻赋值的; 而 bbbbbbbbbbb 是在编译时就确定的; 但是,在以后的存取中,在栈上的数组比指针所指向的字符串(例如堆)快。 比如: #include voidmain() { char a=1; char c[]=”1234567890″; char *p=”1234567890″; a = c[1]; a = p[1]; return; } 对应的汇编代码 10:a=c[1]; 004010678A4DF1movcl,byteptr[ebp-0Fh] 0040106A884DFCmovbyteptr[ebp-4],cl 11:a=p[1]; 0040106D8B55ECmovedx,dwordptr[ebp-14h] 004010708A4201moval,byteptr[edx+1] 004010738845FCmovbyteptr[ebp-4],al 第一种在读取时直接就把字符串中的元素读到寄存器 cl 中,而第二种则要先把指针值读到 edx 中,在根据 edx 读取字符,显然慢了。 21、什么是预编译,何时需要预编译? 答:预编译又称为预处理,是做些代码文本的替换工作。处理#开头的指令,比如拷贝#include 包含的文件代码,#define 宏定义的替换,条件编译等,就是为编译做的预备工作的阶段,主 要处理#开始的预编译指令,预编译指令指示了在程序正式编译前就由编译器进行的操作,
资源推荐
资源评论
资源评论
菊果子
- 粉丝: 40
- 资源: 4076
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功