C++:参数

一、基础

  1. 实参是形参的初始值,对每个形参都需要穿一个能转换为它的实参
  2. 形参列表中的形参通常用逗号隔开,其中每个形参都含有一个声明符的声明

二、main(int argc, char *argv[])

有时我们需要给main穿递实参,常见的情况是用户通过设置一组选项确定函数所要执行的操作
argc---->代表argv中的元素个数,argv---->代表元素为char *的指针数组
cmd下:
通过执行main函数所在的可执行文件prog.exe

prog -d -o ofile data0   

向main内传参
argv[0] 通常是函数名或者一个空字符串,可选的实参从argv开始

三、传引用参数与const情况(省略一部分简单情况)

引用参数 目的:使用引用避免拷贝,加快效率
关于重载函数的一部分:void fcn(const int i) 与 void fcn(int i)是一样的,因为形参的初始化和变量的初始
化方式是一样的,const int i在初始化是忽略顶层const

把不会改变的形参定义为常量引用,对要改变的定义为普通引用
eg:

bool is_sentence1(const string &s){...}
bool is_sentence2(string &s){...}

常量引用形参的实参可以是对象或者常量,但不可以"改变形参"
普通引用可以"改变形参",但实参只能是对象

四、数组形参和const

通常的形参情形:

一维的
void print(const int *)
void print(const int[]);
void print(const int[10]);
二维的
void print(int (*matrix)[10]);

数组引用形参形式:void print(int (&arr)[10])--->像这样的形参只能将函数作用于大小为10的数组

分析:

因为形参的初始化和变量的初始化方式是一样的--->书上说的

但我们并不能

void func(int a[]){...}
or
void func(int *a){...} -->比如字符串就可以如此
int main(){
func({0,1,2,3});
return 0;
}

如何能func({0, 1, 2, 3}) 成功?(根据报错可知传递{0, 1, 2, 3}是"brace-enclosed initializer list"类型)
1.通过c11的initializer_list标准库类型()
2.通过void func(const int (&a)[4])的形参设置-->const使得可以接收常量实参,int (&a)[4]的想法和之前
对for范围循环的特性二有关,int (&a)[4]才能完整传递数组且得知道数组大小--->个人看法

五、含有可变参数的形参

  1. initializer_list--->同vector一样是模板类型,但元素永远是常量
    void error_msg(initializer_list il){....}
    error_msg({'lalalal', 'your error'})
  2. 省略符类型
    void foo(parm_list, ...);
    or
    void foo(...);
    只能这样两者形式,详情见C++省略符
posted @ 2019-09-12 13:55  Dedicate_labors  阅读(495)  评论(0编辑  收藏  举报
……