c++中常用的vector容器作为参数时,有三种传参方式,分别如下(为说明问题,用二维vector):

  • function1(std::vector<std::vector<int> > vec),传值
  • function2(std::vector<std::vector<int> >& vec),传引用
  • function3(std::vector<std::vector<int> >* vec),传指针

注意,三种方式分别有对应的const形式,不在此讨论。

三种方式对应的调用形式分别为:

  • function1(vec),传入值
  • function2(vec),传入引用
  • function3(&vec),传入地址

三种方式的效果分别为:

  • 会发生拷贝构造
  • 不会发生拷贝构造
  • 不会发生拷贝构造

验证程序:

  1. #include <iostream>
  2. #include <vector>
  3.  
  4. using namespace std;
  5.  
  6. void function1(std::vector<std::vector<int> > vec)
  7. {
  8. cout<<"-----------------------------------------"<<endl;
  9. //打印vec的地址
  10. cout<<"function1.&vec:"<<&vec<<endl;
  11. //打印vec[i]的地址(即第一层vector的地址)
  12. cout<<"function1.&vec[i]:"<<endl;
  13. for(int i=;i<;i++)
  14. cout<<&vec[i]<<endl;
  15. //打印vec的各元素地址
  16. cout<<"function1.&vec[i][j]:"<<endl;
  17. for(int i=;i<;i++)
  18. {
  19. for(int j=;j<;j++)
  20. cout<<&vec[i][j]<<" ";
  21. cout<<endl;
  22. }
  23. cout<<"---------------------------"<<endl;
  24. //打印vec的各元素值
  25. cout<<"function1.vec[i][j]:"<<endl;
  26. for(int i=;i<;i++)
  27. {
  28. for(int j=;j<;j++)
  29. cout<<vec[i][j]<<" ";
  30. cout<<endl;
  31. }
  32. }
  33. void function2(std::vector<std::vector<int> >& vec)
  34. {
  35. cout<<"-----------------------------------------"<<endl;
  36. //打印vec的地址
  37. cout<<"function2.&vec:"<<&vec<<endl;
  38. //打印vec[i]的地址(即第一层vector的地址)
  39. cout<<"function2.&vec[i]:"<<endl;
  40. for(int i=;i<;i++)
  41. cout<<&vec[i]<<endl;
  42. //打印vec的各元素地址
  43. cout<<"function2.&vec[i][j]:"<<endl;
  44. for(int i=;i<;i++)
  45. {
  46. for(int j=;j<;j++)
  47. cout<<&vec[i][j]<<" ";
  48. cout<<endl;
  49. }
  50. cout<<"---------------------------"<<endl;
  51. //打印vec的各元素值
  52. cout<<"function2.vec[i][j]:"<<endl;
  53. for(int i=;i<;i++)
  54. {
  55. for(int j=;j<;j++)
  56. cout<<vec[i][j]<<" ";
  57. cout<<endl;
  58. }
  59.  
  60. }
  61. void function3(std::vector<std::vector<int> > *vec)
  62. {
  63. cout<<"-----------------------------------------"<<endl;
  64. //打印vec的地址
  65. cout<<"function3.&vec:"<<vec<<endl;
  66. //打印vec[i]的地址(即第一层vector的地址)
  67. cout<<"function3.&vec[i]:"<<endl;
  68. for(int i=;i<;i++)
  69. cout<<&(*vec)[i]<<endl;
  70. //打印vec的各元素地址
  71. cout<<"function3.&vec[i][j]:"<<endl;
  72. for(int i=;i<;i++)
  73. {
  74. for(int j=;j<;j++)
  75. cout<<&(*vec)[i][j]<<" ";
  76. cout<<endl;
  77. }
  78. cout<<"---------------------------"<<endl;
  79. //打印vec的各元素值
  80. cout<<"function3.vec[i][j]:"<<endl;
  81. for(int i=;i<;i++)
  82. {
  83. for(int j=;j<;j++)
  84. cout<<(*vec)[i][j]<<" ";
  85. cout<<endl;
  86. }
  87. }
  88.  
  89. int main()
  90. {
  91. //创建2*3的vector容器v,初始值均初始化为0 1 2 1 2 3
  92. std::vector<std::vector<int> > v(,std::vector<int>(,));
  93. for(int i=;i<;i++)
  94. {
  95. for(int j=;j<;j++)
  96. v[i][j]=i+j;
  97. }
  98.  
  99. //打印v的地址
  100. cout<<"&v:"<<&v<<endl;
  101. //打印v[i]的地址(即第一层vector的地址)
  102. cout<<"&v[i]:"<<endl;
  103. for(int i=;i<;i++)
  104. cout<<&v[i]<<endl;
  105. //打印v的各元素地址
  106. cout<<"&v[i][j]:"<<endl;
  107. for(int i=;i<;i++)
  108. {
  109. for(int j=;j<;j++)
  110. cout<<&v[i][j]<<" ";
  111. cout<<endl;
  112. }
  113.  
  114. cout<<"---------------------------"<<endl;
  115. //打印v的各元素值
  116. cout<<"v[i][j]:"<<endl;
  117. for(int i=;i<;i++)
  118. {
  119. for(int j=;j<;j++)
  120. cout<<v[i][j]<<" ";
  121. cout<<endl;
  122. }
  123.  
  124. function1(v);
  125. function2(v);
  126. function3(&v);
  127.  
  128. return ;
  129. }

输出(为便于观察,简单处理了一下效果):

简而言之,vector的内部存储模型是这个样子(以main()函数中的v为例):

关于12个字节的问题,请参考博客http://blog.csdn.net/kangroger/article/details/38386099

vector作为参数的三种传参方式的更多相关文章

  1. C++学习3--编程基础(vector、string、三种传参)

    知识点学习 Vector容器 vector是C++标准程序库中的一个类,其定义于头文件中,与其他STL组件一样,ventor属于STD名称空间: ventor是C++标准程序库里最基本的容器,设计之初 ...

  2. 浅谈C++三种传参方式

    浅谈C++三种传参方式 C++给函数传参中,主要有三种方式:分别是值传递.指针传递和引用传递. 下面通过讲解和实例来说明三种方式的区别. 值传递 我们都知道,在函数定义括号中的参数是形参,是给函数内专 ...

  3. Vue-router的三种传参方式

    第一种传递参数:name传参 两步完成name传参并显示在模板中: 第一在router/index.js中配置name属性, routes: [ { path: '/', name: 'HelloWo ...

  4. vue的三种传参方式

    <template> <div> <router-link :to="{'name':'x',params:{'type':'users'}}"> ...

  5. vector做形参时的三种传参方式

    vector在做形参的时候传参的方式和普通的变量是一样的,要么传值.要么传引用.要么传指针. 现在分别定义三个以vector为形参的函数: (1) fun1(vector <int> v) ...

  6. vue路由router的三种传参方式

    方法三: 传参页面传递参数方式: this.$router.push({ path: 'indexTwoDetails', query: { "id": id } }) 接受参数页 ...

  7. c# 三种传参方式 in,out,ref

    in:默认方式,传值不返回 out:不传值 但是会返回新值给予传参对象 ref:传存储地址,所以传参前必须赋值初始化,传值后的运算结果直接作用在传参上 Out和ref的效果差不多

  8. PHP四种传参方式

    test1界面: <html> <head> <title>testPHP</title> <meta http-equiv = "co ...

  9. vue param和query两种传参方式

    1.传参方式 query传参方式 this.$router.push({ path: "/home", query: {code:"123"} }) param ...

随机推荐

  1. 使用moment.js轻松管理日期和时间

    大家在前端Javascript开发中会遇到处理日期时间的问题,经常会拿来一大堆处理函数才能完成一个简单的日期时间显示效果.今天我给大家介绍一个轻量级的Javascript日期处理类库:moment.j ...

  2. CDN内容分发网络

    CDN的全称是Content Delivery Network,即内容分发网络,其设计思想是尽可能避开互联网上有可能影响数据传输速度和稳定性的瓶颈和环节,使内容传输的更快.更稳定. CDN系统是在网络 ...

  3. java iframe 嵌套,session失效重新登录页面嵌套问题

    将后台跳转改写成 PrintWriter out = response.getWriter(); out.println("<html>");    out.print ...

  4. [SinGuLaRiTy] 树形存储结构阶段性测试

    [SinGuLaRiTy-1011] Copyright (c) SinGuLaRiTy 2017. All Rights Reserved. G2019级信息奥赛专项训练 题目 程序名 时间 内存 ...

  5. 老李分享:持续集成学好jenkins之解答疑问

    老李分享:持续集成学好jenkins之解答疑问   poptest(www.poptest.cn)在培训的过程中使用jenkins搭建持续集成环境,让学员真正交流持续集成到底是什么,怎么去做的. Je ...

  6. 1.Redis 的安装

    一.Redis 介绍 Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API. 作为Key-value型数据库,Red ...

  7. JAVA加密算法系列-AES

    package ***; import java.io.UnsupportedEncodingException; import java.security.InvalidKeyException; ...

  8. mysql 分析3使用分析sql 性能 show profiles ;

    show variables like '%profiling%';    查看状态  查看时间去哪了``` set  profiling=1;// 打开 show profiles;  查看执行过的 ...

  9. gulp 学习笔记

    以这次学习gulp为契机来同时了解和学习node相关的知识和概念,比如 npm,package.json等,为以后学习node打好基础. 目录   npm     查看模块     安装模块      ...

  10. java多线程基本概述(三)——同步方法

    非线程安全其实是在多个线程对同一个对象实例的变量进行并发访问的时候发生,产生的后果就是脏读,也就是取到的数据是修改过的.而线程安全就是获得的实例变量的值是经过同步处理的,从而不会出现脏读现象. 1.1 ...