C++——函数及调用
1.函数调用:实参初始化形参;控制权交给被调函数
2.函数返回(return语句):返回return中的值;控制权交回主函数
3.参数传递
| 传值 | 传引用 | 传指针 | |
| 初始值 | 不变,拷贝给形参 |
可变,形参是实参的别名 若不想变,加const |
拷贝指针给形参 |
//1.传指针
void reset(int *p)
{
*ip=;//改变了指针所指向对象的值
ip=;// 只改变ip的局部拷贝,实参未被改变。指针本身可以在局部内任意变化,但指针指向的值没变
}
int i=;
reset(&i);//改变I的值,而非地址
cout<<i<<endl;//i=0 //2.传引用
void reset(int &i)
{
i=;
}
int j=;
reset(j);//改变I的值,而非地址
cout<<j<<endl;//j=0
4.const参数传递
void reset(int &i)//引用传递
{
i=;
} void reset(int *ip)//指针传递
{
*ip=;
} int i=;
const int ci=i;
string::size_type ctr=; reset(i);//引用传递
reset(&i);//引用传递
reset(ci);//×,int类型不能传递给const int类型
reset(&ci);//×,const in *类型不能传递给int *类型
reset();//×
reset(ctr);//×
如果函数参数是const呢?能接受什么参数传入?
5.数组形参
//三个函数等价,形参是const int*
void print(const int*);
void print(const int[]);//
void print(const int[]);//期望含有10个元素的数组,实际不一定,那实际怎么操作,如果元素>10的话? int i=,j[]={,};
print (&i);//int*类型
print(j);//自动转为int *
5.1 判断数组长度
1.使用标记(字符串末尾空)
void print(const char*cp)
{
if(cp)
{
while(*cp)//判断方法
cout<<*cp++
}
}
2.使用标准库
void print(const int *beg,const int *end)
{
while (beg!=end)
cout<<*beg++<<endl;
} int j[]={,};
print(begin(j),end(j));
3.显式传递大小
void print(const int ia[],size_t size)
{
for (size_t i=;i!=size;i++){
cout<<ia[i]<<endl;
}
}
6.main命令行,传递参数
int main(int argc, //
char *argv[])//argv是数组,元素是char*指针
{
} //与上式等价
int main(int argc,//
char ** argv)//argv 指向char*
{
} prog -d -o file data0//可执行文件prog,输入参数
//argc=5
//argv[0]= "prog";
//argv[1]= "-d";
//argv[2]="-o";
//argv[3]=" file";
//argv[4]=" data0";
7.可变形参
7.1 类型相同,数量不同——initializer_list标准库类型
常量值,无法改变,只读
void error_msg(initializer_list<string> istring)
{
for (auto beg=istring.begin();beg!=istring.end();++beg)
cout<<*beg<<" ";
cout << endl;
} if (expected !=actual)//2 个string 对象
error_msg({"FunctionX output:",expected, actual });//{}用于传递initializer_list序列
else
error_msg({"FunctionX output:","Okay"});
可根据实际改写为先打印错误代码,再打印内容:
void error_msg(ErrorCode e, initializer_list<string> string)
{
cout<<e.print()<<":"
for (const auto & elem:string)
cout<< elles<<" ";
cout<<endl;
}
7.2 省略符形参:varargs标准库
8.函数返回
8.1 不要返回局部对象的引用或指针
8.2 返回数组
1.声明返回数组指针的函数
int (*func(int i))[];//解引用的结果是一个10个int元素的数组
//func(int i):
//(*func(int i)):对函数调用的结果解引用
//
2.尾置返回?
auto func(int i)->int(*)[];
3.decltype返回?
int odd[]={,,,,};
int even[]={,,,,};
decltype (odd) *arrptr(int i)//decltype不会把数组转为指针
{
return (i%)?&odd:&even; //返回一个指针,该指针指向含有5个整数的数组
}
9.函数重载
9.1.不能定义两个除了返回值类型不同外,其他都相同的函数
9.2 有时候两个形参看起来类型不一样,实际上相同,也是不许的
9.3 带顶层const的形参和不带const的形参是无法区分的
bool lookUp(Phone);//
bool lookUp(const Phone);//2,与1重复。/?
bool lookUp(Phone*);//
bool lookUp(Phone* const);//4,与3重复。/? bool lookUp(Phone&);//5,作用于Phone的引用
bool lookUp(const Phone&);//6,作用于常引用,同时存在会优先选用
bool lookUp(Phone*);//7,作用于指向Phone的指针
bool lookUp(const Phone *)//8,作用于指向常量的指针,同时存在会优先选用
10.默认实参:一旦有一个参数为默认,其他必须给默认值
string screen(size_type hight=, size_type width=); window=screen();
window=screen(100,200);
11.内联函数
1.定义在头文件中(文件中多次要用)
12.constexpr函数
1. 函数的返回类型、形参类型都是字面值类型
2.函数中有且仅有一条return语句
3.定义在头文件中
constexpr int new_size()
{
return ;
} constexpr size_t scale(size_t cnt)
{
return new_sz()* cnt;
} int arr[scale()];
13.函数调用时的实参匹配
1.精确匹配
2.const转换实现匹配
3.类型提升实现匹配
4.算术类型转换(或指针转换)实现匹配
5.类类型转换实现匹配
bool lookUp(Account &);
bool lookUp(const Account &); Account b;
lookUp(b);//两个都可以调用,但是第一个优先
14.函数指针
bool lengthCompare(const string &,const string &); bool (*pf)(const string &,const string &);//pf是指向函数的指针
//bool *pf(const string &,const string &);//声明一个名为pf的函数,返回bool * pf = lengthCompare;
pf =& lengthCompare;//与上等价 bool b1=pf("hello","goodbye");
bool b2=(*pf)("hello","goodbye");
bool b3=lengCompare("hello","goodbye");//三式等价
14.1 返回指向函数的指针
14.2 auto 和decltype用于函数指针类型
C++——函数及调用的更多相关文章
- Direct3D Draw函数 异步调用原理解析
概述 在D3D10中,一个基本的渲染流程可分为以下步骤: 清理帧缓存: 执行若干次的绘制: 通过Device API创建所需Buffer: 通过Map/Unmap填充数据到Buffer中: 将Buff ...
- Entity Framework 6 Recipes 2nd Edition(11-4)译 -> 在”模型定义”函数里调用另一个”模型定义”函数
11-4.在”模型定义”函数里调用另一个”模型定义”函数 问题 想要用一个”模型定义”函数去实现另一个”模型定义”函数 解决方案 假设我们已有一个公司合伙人关系连同它们的结构模型,如Figure 11 ...
- JS中函数的调用和this的值
调用每一个函数会暂停当前函数的执行,传递控制权和参数给新函数.除了声明时定义的形式参数,每个函数还接收两个附加的参数:this 和 arguments. 参数this在面向对象编程中非常重要,他的值取 ...
- jquery ajax success 函数 异步调用方法中不能给全局变量赋值的原因及解决办法
jquery ajax success 函数 异步调用方法中不能给全局变量赋值的原因及解决办法 在调用一个jquery的ajax方法时我们有时会需要该方法返回一个值或者给某个全局变量赋值,可是我们 ...
- LR自定义函数以及调用
2.2.自定义函数以及调用 2.2.1.虚拟用户编程,使用C# 语言DLL 在VS中建立DLL类库项目,编写函数时使用public声明:实现函数后编译生成DLL: 在LR中建立 .Net Vuser脚 ...
- LR常用函数以及调用自定义函数
2.LR常用函数以及调用自定义函数 2.1.LR常用函数以及对信息的判断 2.1.1. LR内部自定义函数 在LR脚本中定义变量和编写自定义函数,需将变量的声明放在脚本其他内容的上方,否则会提示[il ...
- Spring AOP在函数接口调用性能分析及其日志处理方面的应用
面向切面编程可以实现在不修改原来代码的情况下,增加我们所需的业务处理逻辑,比如:添加日志.本文AOP实例是基于Aspect Around注解实现的,我们需要在调用API函数的时候,统计函数调用的具体信 ...
- 【C语言入门教程】5.3 函数的调用 与 参数
函数通过调用获得程序的控制权,函数的参数是调用者与函数的数据接口.函数可以定义一个或多个参数,也可以省略参数,调用时将与参数的数据类型相匹配的数据置于参数列表中,即可在函数体内使用.参数的调用有多种形 ...
- python 函数的调用 和执行 小知识
1.符号表 执行一个函数会引入一个用于函数的局部变量的新符号表. 更确切地说, 函数中的所有的赋值都是将值存储在局部符号表: 而变量引用首先查找局部符号表, 然后是上层函数的局部符号表, 然后是全局符 ...
- probe函数何时调用的
转自:http://blog.csdn.net/xiafeng1113/article/details/8030248 Linux中 probe函数何时调用的 所以的驱动教程上都说:只有设备和驱动的名 ...
随机推荐
- (转)将SVN从一台服务器迁移到另一台服务器(Windows Server VisualSVN Server)
转:http://blog.sina.com.cn/s/blog_855a24030102xp9q.html 服务器环境: Windows Server 2012 软件版本: VisualSVN-S ...
- windows7+tomcat7+nginx1.11.3 +memcached
测试的环境是windows7+tomcat7+nginx1.11.3 +memcached 安装方法网上很多就不多说了. 1.session共享需要这几个jar 包 下载地址 http://down ...
- ROS的使用
1.输入roscore时出现错误:Unable to contact my own server at 修改: 在.bashrc文件中添加以下内容: export ROS_HOSTNAME=local ...
- 个人笔记 - MATLAB
1.教程 2.基本知识 2.1 帮助文档设置成中文:链接1 2.2 多行注释: 链接1 2.3 MATLAB基本数据类型: 链接1 链接2 2.4 matlab中的 ndims(a).length( ...
- JVM(1):Java 类的加载机制
原文出处: 纯洁的微笑 java类的加载机制 1.什么是类的加载 类的加载指的是将类的.class文件中的二进制数据读入到内存中,将其放在运行时数据区的方法区内,然后在堆区创建一个java.lang. ...
- 【react】---react中使用装饰器
一.creact-react-app中使用装饰器 运行 npm run eject 可以让由create-react-app创建的项目的配置项暴露出来 此时,项目中多了一个config文件,并且各个配 ...
- mysql 个人博客应用的建表和相关查询
一.建表 用户表tb_user create table if not exists tb_user( user_id int auto_increment, ) not null, user_pas ...
- Python之字典推导式
推导式是个绝妙的东西,列表推导式一出,map.filter等函数黯然失色,自 Python2.7以后的版本,此特性扩展到了字典和集合身上,构建字典对象无需调用 dict 方法. bad numbers ...
- 视频专家之路【四】:ffmpeg简单实战之获取属性
本文是听了雷宵骅大神的课之后的总结,部分内容借用了其PPT的内容,如有侵权请告知删除. 雷宵骅大神的博客为:https://blog.csdn.net/leixiaohua1020 本节的目的正式开始 ...
- 第1篇Kubernetes介绍
一.Kubernetes 介绍: kubernetes起源 Kubernetes (K8s) 是 Google 在 2014 年发布的一个开源项目. 据说 Google 的数据中心里运行着 ...