函数是一组一起执行一个任务的语句.docx

上传人:b****8 文档编号:11457445 上传时间:2023-03-01 格式:DOCX 页数:11 大小:36.28KB
下载 相关 举报
函数是一组一起执行一个任务的语句.docx_第1页
第1页 / 共11页
函数是一组一起执行一个任务的语句.docx_第2页
第2页 / 共11页
函数是一组一起执行一个任务的语句.docx_第3页
第3页 / 共11页
函数是一组一起执行一个任务的语句.docx_第4页
第4页 / 共11页
函数是一组一起执行一个任务的语句.docx_第5页
第5页 / 共11页
点击查看更多>>
下载资源
资源描述

函数是一组一起执行一个任务的语句.docx

《函数是一组一起执行一个任务的语句.docx》由会员分享,可在线阅读,更多相关《函数是一组一起执行一个任务的语句.docx(11页珍藏版)》请在冰豆网上搜索。

函数是一组一起执行一个任务的语句.docx

函数是一组一起执行一个任务的语句

函数是一组一起执行一个任务的语句。

每个C++程序都至少有一个函数,即主函数 main() ,所有简单的程序都可以定义其他额外的函数。

您可以把代码划分到不同的函数中。

如何划分代码到不同的函数中是由您来决定的,但在逻辑上,划分通常是根据每个函数执行一个特定的任务来进行的。

函数声明告诉编译器函数的名称、返回类型和参数。

函数定义提供了函数的实际主体。

C++标准库提供了大量的程序可以调用的内置函数。

例如,函数 strcat() 用来连接两个字符串,函数 memcpy() 用来复制内存到另一个位置。

函数还有很多叫法,比如方法、子例程或程序,等等。

定义函数

C++中的函数定义的一般形式如下:

return_typefunction_name(parameterlist){bodyofthefunction}

在C++中,函数由一个函数头和一个函数主体组成。

下面列出一个函数的所有组成部分:

∙返回类型:

一个函数可以返回一个值。

return_type 是函数返回的值的数据类型。

有些函数执行所需的操作而不返回值,在这种情况下,return_type是关键字 void。

∙函数名称:

这是函数的实际名称。

函数名和参数列表一起构成了函数签名。

∙参数:

参数就像是占位符。

当函数被调用时,您向参数传递一个值,这个值被称为实际参数。

参数列表包括函数参数的类型、顺序、数量。

参数是可选的,也就是说,函数可能不包含参数。

∙函数主体:

函数主体包含一组定义函数执行任务的语句。

实例

以下是 max() 函数的源代码。

该函数有两个参数num1和num2,会返回这两个数中较大的那个数:

//函数返回两个数中较大的那个数intmax(intnum1,intnum2){//局部变量声明intresult;if(num1>num2)result=num1;elseresult=num2;returnresult;}

函数声明

函数声明会告诉编译器函数名称及如何调用函数。

函数的实际主体可以单独定义。

函数声明包括以下几个部分:

return_typefunction_name(parameterlist);

针对上面定义的函数max(),以下是函数声明:

intmax(intnum1,intnum2);

在函数声明中,参数的名称并不重要,只有参数的类型是必需的,因此下面也是有效的声明:

intmax(int,int);

当您在一个源文件中定义函数且在另一个文件中调用函数时,函数声明是必需的。

在这种情况下,您应该在调用函数的文件顶部声明函数。

调用函数

创建C++函数时,会定义函数做什么,然后通过调用函数来完成已定义的任务。

当程序调用函数时,程序控制权会转移给被调用的函数。

被调用的函数执行已定义的任务,当函数的返回语句被执行时,或到达函数的结束括号时,会把程序控制权交还给主程序。

调用函数时,传递所需参数,如果函数返回一个值,则可以存储返回值。

例如:

实例

#includeusingnamespacestd;//函数声明intmax(intnum1,intnum2);intmain(){//局部变量声明inta=100;intb=200;intret;//调用函数来获取最大值ret=max(a,b);cout<<"Maxvalueis:

"<num2)result=num1;elseresult=num2;returnresult;}

把max()函数和main()函数放一块,编译源代码。

当运行最后的可执行文件时,会产生下列结果:

Maxvalueis:

200

函数参数

如果函数要使用参数,则必须声明接受参数值的变量。

这些变量称为函数的形式参数。

形式参数就像函数内的其他局部变量,在进入函数时被创建,退出函数时被销毁。

当调用函数时,有两种向函数传递参数的方式:

调用类型

描述

传值调用

该方法把参数的实际值复制给函数的形式参数。

在这种情况下,修改函数内的形式参数对实际参数没有影响。

指针调用

该方法把参数的地址复制给形式参数。

在函数内,该地址用于访问调用中要用到的实际参数。

这意味着,修改形式参数会影响实际参数。

引用调用

该方法把参数的引用复制给形式参数。

在函数内,该引用用于访问调用中要用到的实际参数。

这意味着,修改形式参数会影响实际参数。

默认情况下,C++使用传值调用来传递参数。

一般来说,这意味着函数内的代码不能改变用于调用函数的参数。

之前提到的实例,调用max()函数时,使用了相同的方法。

参数的默认值

当您定义一个函数,您可以为参数列表中后边的每一个参数指定默认值。

当调用函数时,如果实际参数的值留空,则使用这个默认值。

这是通过在函数定义中使用赋值运算符来为参数赋值的。

调用函数时,如果未传递参数的值,则会使用默认值,如果指定了值,则会忽略默认值,使用传递的值。

请看下面的实例:

实例

#includeusingnamespacestd;intsum(inta,intb=20){intresult;result=a+b;return(result);}intmain(){//局部变量声明inta=100;intb=200;intresult;//调用函数来添加值result=sum(a,b);cout<<"Totalvalueis:

"<

"<

当上面的代码被编译和执行时,它会产生下列结果:

Totalvalueis:

300Totalvalueis:

120

Lambda函数与表达式

C++11提供了对匿名函数的支持,称为Lambda函数(也叫Lambda表达式)。

Lambda表达式把函数看作对象。

Lambda表达式可以像对象一样使用,比如可以将它们赋给变量和作为参数传递,还可以像函数一样对其求值。

Lambda表达式本质上与函数声明非常类似。

Lambda表达式具体形式如下:

[capture](parameters)->return-type{body}

例如:

[](intx,inty){returnx

如果没有返回值可以表示为:

[capture](parameters){body}

例如:

[]{++global_x;}

在一个更为复杂的例子中,返回类型可以被明确的指定如下:

[](intx,inty)->int{intz=x+y;returnz+x;}

本例中,一个临时的参数z被创建用来存储中间结果。

如同一般的函数,z的值不会保留到下一次该不具名函数再次被调用时。

如果lambda函数没有传回值(例如void),其返回类型可被完全忽略。

在Lambda表达式内可以访问当前作用域的变量,这是Lambda表达式的闭包(Closure)行为。

与JavaScript闭包不同,C++变量传递有传值和传引用的区别。

可以通过前面的[]来指定:

[]//沒有定义任何变量。

使用未定义变量会引发错误。

[x,&y]//x以传值方式传入(默认),y以引用方式传入。

[&]//任何被使用到的外部变量都隐式地以引用方式加以引用。

[=]//任何被使用到的外部变量都隐式地以传值方式加以引用。

[&,x]//x显式地以传值方式加以引用。

其余变量以引用方式加以引用。

[=,&z]//z显式地以引用方式加以引用。

其余变量以传值方式加以引用。

另外有一点需要注意。

对于[=]或[&]的形式,lambda表达式可以直接使用this指针。

但是,对于[]的形式,如果要使用this指针,必须显式传入:

C++ 数组

C++支持数组数据结构,它可以存储一个固定大小的相同类型元素的顺序集合。

数组是用来存储一系列数据,但它往往被认为是一系列相同类型的变量。

数组的声明并不是声明一个个单独的变量,比如number0、number1、...、number99,而是声明一个数组变量,比如numbers,然后使用numbers[0]、numbers[1]、...、numbers[99]来代表一个个单独的变量。

数组中的特定元素可以通过索引访问。

所有的数组都是由连续的内存位置组成。

最低的地址对应第一个元素,最高的地址对应最后一个元素。

声明数组

在C++中要声明一个数组,需要指定元素的类型和元素的数量,如下所示:

typearrayName[arraySize];

这叫做一维数组。

arraySize 必须是一个大于零的整数常量,type 可以是任意有效的C++数据类型。

例如,要声明一个类型为double的包含10个元素的数组 balance,声明语句如下:

doublebalance[10];

现在 balance 是一个可用的数组,可以容纳10个类型为double的数字。

初始化数组

在C++中,您可以逐个初始化数组,也可以使用一个初始化语句,如下所示:

doublebalance[5]={1000.0,2.0,3.4,7.0,50.0};

大括号{}之间的值的数目不能大于我们在数组声明时在方括号[]中指定的元素数目。

如果您省略掉了数组的大小,数组的大小则为初始化时元素的个数。

因此,如果:

doublebalance[]={1000.0,2.0,3.4,7.0,50.0};

您将创建一个数组,它与前一个实例中所创建的数组是完全相同的。

下面是一个为数组中某个元素赋值的实例:

balance[4]=50.0;

上述的语句把数组中第五个元素的值赋为50.0。

所有的数组都是以0作为它们第一个元素的索引,也被称为基索引,数组的最后一个索引是数组的总大小减去1。

以下是上面所讨论的数组的的图形表示:

访问数组元素

数组元素可以通过数组名称加索引进行访问。

元素的索引是放在方括号内,跟在数组名称的后边。

例如:

doublesalary=balance[9];

上面的语句将把数组中第10个元素的值赋给salary变量。

下面的实例使用了上述的三个概念,即,声明数组、数组赋值、访问数组:

实例

#includeusingnamespacestd;#includeusingstd:

:

setw;intmain(){intn[10];//n是一个包含10个整数的数组//初始化数组元素for(inti=0;i<10;i++){n[i]=i+100;//设置元素i为i+100}cout<<"Element"<

上面的程序使用了 setw() 函数来格式化输出。

当上面的代码被编译和执行时,它会产生下列结果:

ElementValue

0100

1101

2102

3103

4104

5105

6106

7107

8108

9109

C++中数组详解

在C++中,数组是非常重要的,我们需要了解更多有关数组的细节。

下面列出了C++程序员必须清楚的一些与数组相关的重要概念:

概念

描述

多维数组

C++支持多维数组。

多维数组最简单的形式是二维数组。

指向数组的指针

您可以通过指定不带索引的数组名称来生成一个指向数组中第一个元素的指针。

传递数组给函数

您可以通过指定不带索引的数组名称来给函数传递一个指向数组的指针。

从函数返回数组

C++允许从函数返回数组。

C++ 字符串

C++提供了以下两种类型的字符串表示形式:

∙C风格字符串

∙C++引入的string类类型

C风格字符串

C 风格的字符串起源于C 语言,并在C++中继续得到支持。

字符串实际上是使用 null 字符'\0'终止的一维字符数组。

因此,一个以null结尾的字符串,包含了组成字符串的字符。

下面的声明和初始化创建了一个"Hello"字符串。

由于在数组的末尾存储了空字符,所以字符数组的大小比单词"Hello"的字符数多一个。

chargreeting[6]={'H','e','l','l','o','\0'};

依据数组初始化规则,您可以把上面的语句写成以下语句:

chargreeting[]="Hello";

以下是C/C++中定义的字符串的内存表示:

其实,您不需要把 null 字符放在字符串常量的末尾。

C++编译器会在初始化数组时,自动把'\0'放在字符串的末尾。

让我们尝试输出上面的字符串:

实例

#includeusingnamespacestd;intmain(){chargreeting[6]={'H','e','l','l','o','\0'};cout<<"Greetingmessage:

";cout<

当上面的代码被编译和执行时,它会产生下列结果:

Greetingmessage:

Hello

C++中有大量的函数用来操作以null结尾的字符串:

supportsawiderangeoffunctionsthatmanipulatenull-terminatedstrings:

序号

函数&目的

1

strcpy(s1,s2);

复制字符串s2到字符串s1。

2

strcat(s1,s2);

连接字符串s2到字符串s1的末尾。

3

strlen(s1);

返回字符串s1的长度。

4

strcmp(s1,s2);

如果s1和s2是相同的,则返回0;如果s1s2则返回值大于0。

5

strchr(s1,ch);

返回一个指针,指向字符串s1中字符ch的第一次出现的位置。

6

strstr(s1,s2);

返回一个指针,指向字符串s1中字符串s2的第一次出现的位置。

下面的实例使用了上述的一些函数:

实例

#include#includeusingnamespacestd;intmain(){charstr1[11]="Hello";charstr2[11]="World";charstr3[11];intlen;//复制str1到str3strcpy(str3,str1);cout<<"strcpy(str3,str1):

"<

"<

"<

当上面的代码被编译和执行时,它会产生下列结果:

strcpy(str3,str1):

Hello

strcat(str1,str2):

HelloWorld

strlen(str1):

10

C++中的String类

C++标准库提供了 string 类类型,支持上述所有的操作,另外还增加了其他更多的功能。

我们将学习C++标准库中的这个类,现在让我们先来看看下面这个实例:

现在您可能还无法透彻地理解这个实例,因为到目前为止我们还没有讨论类和对象。

所以现在您可以只是粗略地看下这个实例,等理解了面向对象的概念之后再回头来理解这个实例。

实例

#include#includeusingnamespacestd;intmain(){stringstr1="Hello";stringstr2="World";stringstr3;intlen;//复制str1到str3str3=str1;cout<<"str3:

"<

"<

"<

当上面的代码被编译和执行时,它会产生下列结果:

str3:

Hello

str1+str2:

HelloWorld

str3.size():

10

 

THANKS!

!

!

 

致力为企业和个人提供合同协议,策划案计划书,学习课件等等

打造全网一站式需求

欢迎您的下载,资料仅供参考

 

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 解决方案 > 学习计划

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1