i++ i+=1 i=i+1 汇编代码效率比较
结论:一样。编译器和编译器之间可能有点区别但是程序不会变。
0x00
一直不清楚到底是因为懒还是真的为了效率,要把" i = i + 1 "写成" i++ "或者" i += 1 ",
今日闲来无事,尝试一下。
0x01
直接的赋值语句。
编译器:Dev-C++ 5.11
代码:
void asd() {}
int main() {
int i=;
i++;
asd(); //方便在IDA中区分上下文
i=i+;
asd();
i+=;
return ;
}
反汇编:
mov [rbp+i], 0 //i的初始化
add [rbp+i], 1 //i++;
call _Z3asdv ; asd(void)
add [rbp+i], 1 //i=i+1;
call _Z3asdv ; asd(void)
add [rbp+i], 1 //i+=1;
总结:一毛一样。
0x02
换个编译器
编译器:Microsoft Visual Studio 2013
代码:跟上边的一样
反汇编: //突然变得裹脚布
mov [ebp+i], 0 //i的初始化
mov eax, [ebp+i] //这三行是i++
add eax, 1 //先取出i放到eax,加1之后再放回去
mov [ebp+i], eax
call sub_41110E //void asd()
mov eax, [ebp+i] //这三行是i=i+1
add eax,
mov [ebp+i], eax
call sub_41110E //void asd()
mov eax, [ebp+i] //这三行是i+=1
add eax,
mov [ebp+i], eax
总结:一毛一样。
0x03
换一种语句,用for试试
编译器:Dev-C++ 5.11
代码:
void asd() {}
int main() {
int i;
for(i=; i<; i++) ;
asd();
for(i=; i<; i++) ;
asd();
for(i=; i<; i++) ;
asd();
return ;
}
反汇编: 总而言之还是那个样子。
0x04
换编译器:Microsoft Visual Studio 2013
代码:和上边一样
反汇编: 总而言之还是老样子。
0x05
还是不太放心
试试,如果是两个变量呢?
编译器:Dev-C++ 5.11
代码:
void asd() {}
int main() {
int i, j;
asd();
i=i+j;
asd();
i+=j;
asd();
return ;
}
反汇编:
call _Z3asdv ; asd(void)
mov eax, [rbp+var_8]
add [rbp+var_4], eax
call _Z3asdv ; asd(void)
mov eax, [rbp+var_8]
add [rbp+var_4], eax
call _Z3asdv ; asd(void)
一样。
0x06
总结:i++、i=i+1、i+=1, 效果一样。
i+=j、i=i+j,也是一样的
但是既然能够少写两个字符,为什么还要多写两个呢?
况且,用 i += j 的,总是看不起写 i = i + j 的。
i++ i+=1 i=i+1 汇编代码效率比较的更多相关文章
- linux内核分析作业:以一简单C程序为例,分析汇编代码理解计算机如何工作
一.实验 使用gcc –S –o main.s main.c -m32 命令编译成汇编代码,如下代码中的数字请自行修改以防与他人雷同 int g(int x) { return x + 3; } in ...
- linux内核分析作业4:使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用
系统调用:库函数封装了系统调用,通过库函数和系统调用打交道 用户态:低级别执行状态,代码的掌控范围会受到限制. 内核态:高执行级别,代码可移植性特权指令,访问任意物理地址 为什么划分级别:如果全部特权 ...
- 简单C程序生成的汇编代码分析
首先给出完整的C代码: int g(int x) { ; } int f(int x) { return g(x); } int main(void) { )+; } 使用命令:gcc –S –o h ...
- uC/OS-II汇编代码
;*************************************************************************************************** ...
- 分析一个C语言程序生成的汇编代码-《Linux内核分析》Week1作业
署名信息 郭春阳 原创作品转载请注明出处 :<Linux内核分析>MOOC课程 http://mooc.study.163.com/course/USTC-1000029000 C源码 这 ...
- 20145311利用gdb调试汇编代码
利用GDB调试汇编代码 首先编写c语言原代码,我使用的是同学分析过的代码 #include<stdio.h>short addend1 = 1;static int addend2 = 2 ...
- -fomit-frame-pointer 编译选项在gcc 4.8.2版本中的汇编代码研究
#include void fun(void) { printf("fun"); } int main(int argc, char *argv[]){ fun(); return ...
- c++(vs上)与g++(linux下)对于++操作的汇编代码解读
先来看一个代码,估计很多同学都碰到过其中的某一个. #include <stdio.h> #include <iostream> using namespace std; in ...
- 在汇编代码中调用C函数
对于ARM体系来说,不同语言撰写的函数之间相互调用(mix calls)遵循的是 ATPCS(ARM-Thumb Procedure Call Standard),ATPCS主要是定义了函数呼叫时参数 ...
随机推荐
- (十)T检验-第一部分
介绍T分布.T检验.Z检验与T检验.P值.相依样本以及配对样本的非独立T检验. T分布 在到目前为止举的所有例子中,我们都假设我们知道总体参数 μ 和 σ,但很多时候,我们并不知道,我们通常只有样本, ...
- Odoo的@api.装饰器
转载请注明原文地址:https://www.cnblogs.com/cnodoo/p/9281437.html Odoo自带的api装饰器主要有:model,multi,one,constrains, ...
- Solr服务在Linux上的搭建详细教程
一.系统环境 注:欢迎大家转载,非商业用途请在醒目位置注明本文链接和作者名dijia478即可,商业用途请联系本人dijia478@163.com. CentOS-6.7-i386-bin-DVD1 ...
- 使用Charles进行移动APP抓包分析
一.简介 Charles是目前最强大最流行的http抓包调试工具,Mac.Unix.Windows各个平台都支持.特别是做APP开发,调试与服务端的通信,Charles是必备工具. 目前Charles ...
- P2758 编辑距离
题目描述 设A和B是两个字符串.我们要用最少的字符操作次数,将字符串A转换为字符串B.这里所说的字符操作共有三种: 1.删除一个字符: 2.插入一个字符: 3.将一个字符改为另一个字符: !皆为小写字 ...
- 1.1《想成为黑客,不知道这些命令行可不行》(Learn Enough Command Line to Be Dangerous)——运行终端
终端是个允许我们运行命令行的程序,运行命令前,先打开它.在MacOS系统上,可以使用macOS应用 Spotlight来打开终端窗口,Spotlight也有其他两种方式触发,一种是键入⌘␣(comma ...
- vue+vux-ui+axios+mock搭建一个简单vue框架
1.首先感谢同事 2.之前一直在做angularjs的项目,目前vue火热,所以自己搭建了一个的vue框架,在此作为记录 vue+vux-ui这里就不介绍了,有很多博客都写的很详细了. 下面简单记录下 ...
- 聊聊iOS Keychain
某天,小熊碰见这样一个错误 Couldn't update the Keychain Item问题处理 ,网上搜索了下网上很多解决方案,依然百撕不得骑姐.后来参考下面两篇文章.才发现是用法不正确,网上 ...
- Java面向对象之多态(来源于身边的案例)
2019年1月3日 星期四 Java面向对象之多态(来源于身边的案例) 1. 为什么要用多态? 1.1 多态是面向对象的三大特性之一 1.2 多态是基于接口设计的模型 1.3 多态具有横向扩展特性 1 ...
- #leetcode刷题之路46-全排列
给定一个没有重复数字的序列,返回其所有可能的全排列.示例:输入: [1,2,3]输出:[ [1,2,3], [1,3,2], [2,1,3], [2,3,1], [3,1,2], [3,2,1]] 两 ...