C++11 initializer_list 和 Range-based for loop 学习理解
win10 + vs2017
源码如下:
int main()
{
vector< int > numbers = { 1, 2, 3, 4, 5 };
for (auto num : numbers)
{
printf( "num = %d\n", num );
}
return 0;
}
汇编理解如下:
int main()
{
# 入栈
00933F63 sub esp,150h
00933F69 push ebx
00933F6A push esi
00933F6B push edi
00933F6C lea edi,[ebp-150h]
00933F72 mov ecx,54h
00933F77 mov eax,0CCCCCCCCh
00933F7C rep stos dword ptr es:[edi]
00933F7E mov eax,dword ptr [__security_cookie (093E004h)]
00933F83 xor eax,ebp
00933F85 mov dword ptr [ebp-4],eax
vector< int > numbers = { 1, 2, 3, 4, 5 };
// memset( &numbers, 0x00, sizeof ( numbers ) );
// sizeof ( numbers ) == 10h
00933F88 push 10h
00933F8A lea ecx,[numbers]
00933F8D call std::vector<int,std::allocator<int> >::__autoclassinit2 (09314ABh)
// [ebp-14Ch, ebp-138h) 这段内存是5个整形(20个字节),分别赋值为1,2,3,4,5
00933F92 mov dword ptr [ebp-14Ch],1
00933F9C mov dword ptr [ebp-148h],2
00933FA6 mov dword ptr [ebp-144h],3
00933FB0 mov dword ptr [ebp-140h],4
00933FBA mov dword ptr [ebp-13Ch],5
// 创建allocator对象,供后面vector构造使用,地址为 ebp-111h
00933FC4 lea ecx,[ebp-111h]
00933FCA call std::allocator<int>::allocator<int> (0931163h)
00933FCF push eax
// std::initializer_list<int> 构造
// initializer_list(const _Elem *_First_arg, const _Elem *_Last_arg)
00933FD0 lea eax,[ebp-138h]
00933FD6 push eax
00933FD7 lea ecx,[ebp-14Ch]
00933FDD push ecx
00933FDE lea ecx,[ebp-124h]
00933FE4 call std::initializer_list<int>::initializer_list<int> (09314A6h)
// vector 构造
// vector(initializer_list<_Ty> _Ilist, const _Alloc& _Al = _Alloc())
// _Al参数是在 00933FCF 位置压栈的
// _Ilist参数是按值传递,将成员_First和_Last分两次压栈,对应下面4行
00933FE9 mov edx,dword ptr [eax+4]
00933FEC push edx
00933FED mov eax,dword ptr [eax]
00933FEF push eax
00933FF0 lea ecx,[numbers]
00933FF3 call std::vector<int,std::allocator<int> >::vector<int,std::allocator<int> > (0931168h)
for (auto num : numbers)
// std::vector<int,std::allocator<int> >::begin() 结果保存在 dword ptr [ebp-30h]
00933FF8 lea eax,[numbers]
00933FFB mov dword ptr [ebp-24h],eax
00933FFE mov ecx,dword ptr [ebp-24h]
00934001 call std::vector<int,std::allocator<int> >::_Unchecked_begin (09311FEh)
00934006 mov dword ptr [ebp-30h],eax
// std::vector<int,std::allocator<int> >::end() 结果保存在 dword ptr [ebp-3Ch]
00934009 mov ecx,dword ptr [ebp-24h]
0093400C call std::vector<int,std::allocator<int> >::_Unchecked_end (09312C1h)
00934011 mov dword ptr [ebp-3Ch],eax
// 跳转 for 循环的条件比较
00934014 jmp main+0BFh (093401Fh)
// 迭代器加1
00934016 mov eax,dword ptr [ebp-30h]
00934019 add eax,4
0093401C mov dword ptr [ebp-30h],eax
// eax = dword ptr [ebp-30h]
// eax 和 vector::end() 比较,如果相等则跳出循环
0093401F mov eax,dword ptr [ebp-30h]
00934022 cmp eax,dword ptr [ebp-3Ch]
00934025 je main+0E2h (0934042h)
// 将 dword ptr [ebp-30h] 迭代器指向的整形数值取出来,放到 dword ptr [ebp-48h]
00934027 mov eax,dword ptr [ebp-30h]
0093402A mov ecx,dword ptr [eax]
0093402C mov dword ptr [ebp-48h],ecx
{
printf( "num = %d\n", num );
// 从 dword ptr [ebp-48h] 取出整形数值,压栈
// 将 "num = %d\n" 压栈
// 调用 printf
0093402F mov eax,dword ptr [ebp-48h]
00934032 push eax
00934033 push offset string "num = %d\n" (093BC88h)
00934038 call _printf (093153Ch)
0093403D add esp,8
}
// 跳转到迭代器加1位置
00934040 jmp main+0B6h (0934016h)
return 0;
00934042 mov dword ptr [ebp-130h],0
// vecotr析构
0093404C lea ecx,[numbers]
0093404F call std::vector<int,std::allocator<int> >::~vector<int,std::allocator<int> > (0931078h)
// 将返回值0放入eax寄存器
00934054 mov eax,dword ptr [ebp-130h]
}
// 出栈
0093405A push edx
0093405B mov ecx,ebp
0093405D push eax
0093405E lea edx,ds:[93408Ch]
00934064 call @_RTC_CheckStackVars@8 (09313F7h)
00934069 pop eax
0093406A pop edx
0093406B pop edi
0093406C pop esi
0093406D pop ebx
0093406E mov ecx,dword ptr [ebp-4]
00934071 xor ecx,ebp
00934073 call @__security_check_cookie@4 (0931415h)
00934078 add esp,150h
0093407E cmp ebp,esp
00934080 call __RTC_CheckEsp (0931212h)
00934085 mov esp,ebp
00934087 pop ebp
00934088 ret
C++11 initializer_list 和 Range-based for loop 学习理解的更多相关文章
- Node.js Event Loop 的理解 Timers,process.nextTick()
写这篇文章的目的是将自己对该文章的理解做一个记录,官方文档链接The Node.js Event Loop, Timers, and process.nextTick() 文章内容可能有错误理解的地方 ...
- 11种常用css样式之border学习
边框border通常简写为"border:1px solid red;"但其实一个完整的border边框其实是由1.border-width/*边框宽度*/,2.border-st ...
- C++11新特性——range for
很多编程语言都有range for语法功能,自C++11起,终于将这个重要功能加入C++标准中.range for语句,可以方便的遍历给定序列中的每个元素并对其执行某种操作. 1.基本语法 for(d ...
- C++11中自定义range
python中的range功能非常好用 for i in range(100): print(i) 现在利用C++11的基于范围的for循环特性实现C++中的range功能 class range { ...
- c++11::initializer_list
#include <initializer_list> template <class T> class initializer_list; initializer_list对 ...
- getSelection、range 对象属性,方法理解,解释
网上转了一圈发现没有selection方面的解释,自己捣鼓下 以这段文字为例子.. <p><b>法国国营铁路公司(SNCF)20日承认,</b>新订购的2000列火 ...
- 对Node.JS的事件轮询(Event Loop)的理解
title: Node.JS的事件轮询(event loop)的理解 categories: 理解 tags: Node JS 机制 当我们知道I/O操作和创建新线程的开销是巨大的! 网站延迟的开销 ...
- 11个超棒的iOS开发学习网站
原文:11 Insanely Great iOS Developers Sites 永不止步地向他人学习 我相信,要想从一个"还不错"的人变成一个卓越的人,我们需要不停地向他人学习 ...
- 编辑器开发之 Range 范围对象的学习
写在前面: 网上有各种富文本编辑器,微博分享等操作,这些功能非常实用,他们就是使用 range,selection 对象来实现的,这两个对象偏冷门,不涉及编辑器一般用不到,range 对象是对选区的操 ...
随机推荐
- spring boot(8)-mybatis三种动态sql
脚本sql XML配置方式的动态SQL我就不讲了,有兴趣可以自己了解,下面是用<script>的方式把它照搬过来,用注解来实现.适用于xml配置转换到注解配置 @Select(" ...
- IIS7 使用server farms 进行负载均衡
1.首先,到微软官网下载web平台安装程序: https://www.microsoft.com/web/downloads/ 2.安装好后,会在IIS里有这个图标: 3.双击这个图标:安装 4.安装 ...
- Python学习---django重点之视图函数
django重点之视图函数 http请求中产生两个核心对象: http请求:HttpRequest对象,由Django自己创建 http响应:HttpResponse对象,由开发自己创建,必须返回一个 ...
- Linux bash内置命令集
man cd -->查询不到,所以会提示bash的内置命令 . alias bg bind break builtin caller cd command compgen complete c ...
- 乘风破浪:LeetCode真题_006_ZigZag Conversion
乘风破浪:LeetCode真题_006_ZigZag Conversion 一.前言 到这里我们对基本的问题有了一定的理解,其中字符串的操作一直是一个比较困难的问题,这一点我们需要认真对待,采用合理的 ...
- python3 邮件,多用户,抄送
#!/usr/bin/env python # -*- coding: utf-8 -*- # @Time : 2017/8/19 10:44 # @Author : Lys # @Site : # ...
- 【SQL.基础构建-第四节(4/4)】
-- Tips:数据更新 --一.插入数据 --1.INSERT 语句的基本语法 --语法:--INSERT INTO <表名>(列1, 列2, ...) VALUES (值1, ...
- 左右值无限级分类 MVC + EntityFramework 的简单实现
在度娘上查了大半个月的资料,最后发现每个网友分享的文章都有一定的错误(PS:大家是故意的么?).最后是在看了一个ASP版本后知道了大概流程:看了一个存储过程实现的文章后知道了大概需要的功能:看了一个S ...
- BZOJ 1191 超级英雄Hero 二分图匹配
题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=1191 题目大意: 现在电视台有一种节目叫做超级英雄,大概的流程就是每位选手到台上回答主 ...
- shouldRasterize 光栅化、(缓存)复用、内存、内容稳定
使用场景:稳定的视图(layer)被反复使用或进行动画: 本质:牺牲内存解放cpu: 反例:牺牲内存牺牲cpu. 单次使用或者视图有变动,shouldRasterize不会有任何用途,反而会牺牲内存. ...