p187~p199:

【传值参数】

【传引用参数】

使用引用形参返回额外信息:传入一个(或者多个)额外的引用实参,令其保存字符出现的次数。

6.11

#include <iostream>
using namespace std;
void reset(int &i)
{
i = ;
}
int main()
{
int i = ;
reset(i);
cout << "i = " << i << endl; // output: i = 0
return ;
}

6.12

#include <iostream>
using namespace std;
void swap(int &p, int &q)
{
int temp;
temp = p;
p = q;
q = temp;
}
int main()
{
int a = , b = ;
cout << a << " " << b << endl;
swap(a , b);
// 交换之后
cout << a << " " << b << endl;
/* output:
4
3
*/
return ;
}

6.13

void f(T)中的T在调用函数的时候将拷贝实参的值,而voidd f(&T)中的T则是传入实参的临时别名。

6.14

感觉几乎都可以用引用类型,想到的一个是“删减字符串然后返回”,但是仍然可以在函数内部定义局部变量再进行操作。

6.15

因为不希望在函数里面改变string的值,因此s是常量引用(s设置为const可以提高可读性、更加安全,但是这应该不是必须的)。

s定义为引用类型可以避免拷贝,occurs定义为引用类型是为了返回“额外的信息”,定义成常量就无法统计值了。

至于c为什么不是引用类型。。。(更多原因见下文)

【const形参和实参】

续上节,补充尽量使用常量引用的原因:形参的初始化和变量的初始化是相同的,常量引用相比普通引用能够接收更多的类型。一个实例是f(string &s)无法传入字面值(非常量引用无非用字面值来初始化),如果传入将发生编译错误。正确的做法是:f(const string &s)。

6.16

见上文。

6.17

#include <iostream>
using namespace std;
// 函数1
bool has_bigc(const string &s)
{
for (char c : s) {
if (c >= 'A' || c <= 'Z') {
return true;
}
}
return false;
}
// 函数2
void to_Lower(string &s)
{
int L = 'A' - 'a';
for (char &c : s) {
if (c >= 'A' || c <= 'Z') {
c -= L;
}
}
}
int main()
{
cout << (has_bigc("Lovecpp") ? "Yes!" : "No!") << endl;
string s = "HeLlo WORLD";
to_Lower(s);
cout << s << endl;
return ;
}

6.18

bool compare(matrix&, matrix&);
vector<int>::iterator change_val(int , vector<int>::iterator);

6.19

不合法 合法 合法  合法

6.20

略。

【数组形参】

一维数组

含有数组形参的函数的声明方式:

void opera_array(const int*); // 推荐,更符合实际意义
void opera_array(const int[]);
void opera_array(const int[]);

以上三个函数是等价的。可以看出,函数参数实际接收的是指向数组首元素的指针(假设一个数组a,传入a等价于传入&a[0])。因为数组是以指针形式传递给函数,所以函数并不知道数组的确切尺寸。调用者因此应该提供额外的信息,主要有三种途径:

1、在数组尾部放标记。(例如c风格的字符串尾部的'\0')

2、传入指向数组首尾元素的指针。(借助标准库的begin(a);end(j);)

3、显式传入长度。(例如void f(int *a, int len);)

多维数组

多位数组实质上是“数组的数组”,数组的第二维(以及以后的维度)的大小都是数组类型的一部分,在声明的时候不可省略!正确使用的例子:

void f(int (*array)[]);

避免混乱的一个好办法就是:坚持一种直观的方式。

6.21

const int *p;

6.22

#include <iostream>
using namespace std;
void swap(int* &p, int* &q)
{
int* temp;
temp = p;
p = q;
q = temp;
}
int main()
{
int i = ;
int *p = &i;
int *q = nullptr;
swap(p, q);
cout << *q << endl;
return ;
}

6.23

略。

6.24

打印元素个数为10的int型数组元素,代码没问题。

【main:处理命令行选项】

简单的示例:

#include <iostream>
using namespace std;
int main(int argc, char *argv[])
{
for (size_t i = ; i != argc; ++i)
cout << argv[i] << endl; // c风格的字符串可以当成字面值来用。
return ;
}
$ a hello world i love you
a # 第一个元素是exe文件的名字
hello # 以下是传入的参数
world
i
love
you

6.25

#include <iostream>
#include <string>
using namespace std;
int main(int argc, char *argv[])
{
string hi = "";
for (size_t i = ; i != argc; ++i){
hi += argv[i];
hi += " ";
}
cout << hi << endl;
return ;
}

6.26

略。

【含有可变形参的函数】

initializer_list<T> 的特点:1、元素永远是常量 2、传入值要加花括号

6.27

#include <iostream>
#include <initializer_list>
using namespace std;
int sum(initializer_list<int> il)
{
int sum = ;
for (auto &x : il) {
sum += x;
}
return sum;
}
int main()
{
cout << sum({, , , , }) << endl; // output=15
return ;
}

6.28

string

6.29

看具体情况。

【c++ primer, 5e】参数传递的更多相关文章

  1. 【c++ primer, 5e】函数声明 & 分离式编译

    p186~p188: 函数声明1.函数只能定义一次,但是可以声明多次. 2.函数的接口:返回类型 + 函数名 + 形参类型 3.为什么要在头文件中进行函数声明???在源文件中定义?暂时理解到,这么做可 ...

  2. 【c++ primer, 5e】【函数基础】

    p182~p185: 函数1.在调用函数和执行return语句的同时,也发生了控制权的转移. 2.函数返回值不能是一个数组.(但是可以返回一个包含数组的对象,或者指向数组的指针) 3.重要概念:名字的 ...

  3. 【c++ primer, 5e】【try语句块】

    p172~p177:c++的try语句块和异常处理: 1.通常,与用户交互的代码和对象相加(底层的代码)是分离开的,异常由与用户交互的代码处理(底层代码抛出异常就可以了). 2.C++的runtime ...

  4. 【c++ primer, 5e】构造函数 & 拷贝、赋值和析构

    [构造函数] 1.构造器就是创建对象时被调用的代码. 2.如果没有自定义构造器,那么编译器将自动合成一个默认的无参构造器. 3.自定义的构造器不允许加const,所创建const的对象只有在构造器代码 ...

  5. 【c++ primer, 5e】定义类相关的非成员函数

    练习 7.6 & 7.7 #include <iostream> #include <string> using namespace std; // Sales_dat ...

  6. 【c++ primer, 5e】设计Sales_data类 & 定义改进的Sales_data类

    [设计Sales_data类] 1.考虑Sales_data类应该有那些接口. isbn.combine.add.read.print... 2.考虑如何使用这些接口. Sales_data tota ...

  7. 【c++ primer, 5e】函数指针

    简单的示例: #include <iostream> using namespace std; int sum(int x, int y) { return x + y; } int ma ...

  8. 【c++ primer, 5e】函数匹配

    练习 6.49 候选函数:与所调用的函数的名字相同的函数的集合. 可行函数:给候选函数加上参数数量.参数类型的约束所得到的函数的集合. 6.50 a 3.4可行,二义匹配 b 2.4可行,2是最佳匹配 ...

  9. 【c++ primer, 5e】特殊用途语言特性

    [默认实参] 1.注意点:函数的默认实参可以在函数的声明中添加,但是后续声明只能添加默认参数而不能改变先前声明的默认参数.(函数的声明通常是定义在头文件上的,多次声明同一个函数是合法的) 2.默认实参 ...

随机推荐

  1. JSP内置对象——application,page,pageContext,config,Exception

    application对象application对象实现了用户数据的共享,可存放全局变量.application开始于服务器的启动,终止于服务器的关闭.在用户的前后链接或不同用户之间的连接中,可以对a ...

  2. 『SharePoint 2010』Sharepoint 2010 Form 身份认证的实现(基于SQL)

    1:创建一个基于身份认证的应用程序(具体参见上篇基于AD) SQL-MembershipProvider 成员SQL-RoleManager 角色 2:修改管理中心,我们创建的应用程序,还有Web服务 ...

  3. 原生封装的ajax

    原生封装的ajax的代码如下: //将数据转换成 a=1&b=2格式; function json2url(json){ var arr = []; //加随机数防止缓存; json.t = ...

  4. [VS2015].NET4.0环境下使用.NET2.0程序集,使用sqlite时报异常 出现“混合模式程序集异常”

    在.net 4.0环境下使用sqlite时报异常 混合模式程序集是针对“v2.0.50727”版的运行时生成的,在没有配置其他信息的情况下,无法在 4.0 运行时中加载该程序集其调用的方法是从sqli ...

  5. C语言实现双链表(带头节点)

    双链表和单链表性质相似只是在多加了一个前指针 1.定义结构体 typedef struct Node{ int data; struct Node *prior; struct Node *next; ...

  6. linux 修改用户密码

    passwd 命令:用于对用户的密码进行管理,可以设置.修改.删除密码. 修改root用户的密码:$ sudo passwd root

  7. intellij idea 主题更换(换黑底或白底)

    更换主题: File-->setting-->Appearance&Behavior-->Appearance Intellij:白底黑字 Darcula:黑底白字

  8. PHP 支持8种基本的数据类型。

    四种标量类型:boolean (布尔型):这是最简单的类型,只有两种取值,可以为 TRUE/true 或 FALSE/false ,不区分大小写.详细请查看:PHP布尔类型(boolean)integ ...

  9. 拖拽js和jq写法

    第一种原生js写法 window.onload=function () { var oDrag=document.getElementById('drag'); oDrag.onmousedown=f ...

  10. PCI 设备详解二

    上篇文章主要从硬件的角度分析了PCI设备的特性以及各种寄存器,那么本节就结合LInux源代码分析下内核中PCI设备的各种数据结构以及相互之间的联系和工作机制 2016-10-09 注:一下代码参考LI ...