STL之容器作为形参的传递
来源:互联网 发布:app无网络提示 编辑:程序博客网 时间:2024/05/21 15:02
眼高手低,一看就会,一写就错,刚刚想起来用容器,结果连怎么传参数都忘了。
参考: http://blog.csdn.net/yishaxiaoyao/article/details/44344097
STL中的容器是个神器,第一次接触时,甚是感到C语言好坑,毫无留念的投入到STL。
自己的理解:
vect可以理解为数组,这个数组比较特殊,不用考虑长度,溢出等问题,系统都给我们做好。
vect作为参数传递时,和普通类型变量作为参数传递本质上是相似的,一般有两种方式。一种是值传递,一种是引用传递。
为什么要有两种方式? 因为每种方式各有优缺点,适用范围不同。
两种方式区别?
从书写角度看: 传值方式是 变量类型+变量名 如下述的void function(vector<int> a)
引用方式是 变量类型+&+变量名 如下述的void function(vector<int> & a)
从内部实现角度看: 值传递方式需要重新复制一段新的内存空间 ,对这段新的内存空间进行操作,并不影响原内存空间
引用传递方式则是对原内存空间增加一个新的别名(相当于多起个绰号),还是在原内存空间进行操作
从适用范围看: 值传递一般是需要进行操作的内存空间较小
引用传递一般应用在,需要进行操作的内存空间很大,如果复制一个新的空间效率不高,使用引用方式,直接进行操作
个人愚见,未能全面,欢迎拍砖,共同学习。下面是参阅一些其他博主的举例和分析,感觉讲的很好,如有侵权,请联系删除。
1、STL容器类自带的拷贝构造函数和符号“=”对容器进行深拷贝
常见的STL容器包括:vector,deque,list,set,multiset,map,multimap,stack,queue,priority_queue。
将STL容器当作参数传递给函数时,如果是值传递,则会自动调用STL容器的拷贝构造函数,如下面的程序片段。
vector<int> a;
...
void function(vector<int> a) {
//a的作用域仅仅是函数范围
//使用深拷贝在内存中重新分配了空间
//在这里改变a的值不影响function外a的值
...
}
//即使function中改了a的值,此处a没有任何变化
vector的拷贝构造函数会根据传进来的vector开辟相同的空间,然后将传进来的vector的元素一个一个拷贝到新的vector中。在逐个拷贝元素的过程中,如果该元素不是int型,而是一个自定义的类,那么必须使用该自定义的类的拷贝构造函数。那么,此时是否为深拷贝,取决于该自定义的类是否重写了拷贝构造函数。(关于STL容器内元素的拷贝问题,见引用1)
除了STL容器外,string类自带的拷贝构造函数也是深拷贝。
使用上述的容器或者string作为函数的参数时,引用传递和值传递的区别
值传递示意图:
引用传递示意图:
- STL之容器作为形参的传递
- stl容器之--自定义结构体作为stl容器元素成员的使用
- DLL之间的容器传递;STL+DLL
- C++ STL/ (9) STL容器中数据的传递
- 什么样的对象才能作为STL容器的元素
- auto_ptr预防作为STL容器元素的实现。
- auto_ptr智能指针不能作为STL标准容器的元素
- C++中将stack等容器类作为函数形参传递
- 二维数组的作为函数形参的地址传递
- STL之vector容器的实现框架
- STL之list容器的实现框架
- STL之deque容器的实现框架
- STL之deque容器的实现框架
- stl之顺序容器的选用
- stl之multiset容器的应用
- STL之关联容器的映射底层
- STL容器之size()函数的实现
- C++之STL基本容器的使用
- 我的模板库【填坑中】
- 递归形式二分查找
- 利用XML文件和Java代码来综合管理设计UI界面,比如
- nginx配置nodejs服务二级域名
- 使用MyBatis进行模糊查询时%到底写哪儿的解决办法
- STL之容器作为形参的传递
- RelativeLayout 的一些相关属性
- swustoj最近对问题(0794)
- QtCharts源码编译安装
- on a null object reference 错误
- windows、ubuntu双系统的安装与卸载
- java基础回顾
- Tomcat请求处理过程
- java实验4.(1)查询Mysql数据库