Вы находитесь на странице: 1из 36

# Chapter 6 Functions

Opening Problem
Find the sum of integers from 1 to 10, from 20 to 37, and
from 35 to 49, respectively.

Problem
int sum = 0;
for (int i = 1; i <= 10; i++)
sum += i;
cout << "Sum from 1 to 10 is " << sum << endl;
sum = 0;
for (int i = 20; i <= 37; i++)
sum += i;
cout << "Sum from 20 to 37 is " << sum << endl;
sum = 0;
for (int i = 35; i <= 49; i++)
sum += i;
cout << "Sum from 35 to 49 is " << sum << endl;

Problem
int sum = 0;
for (int i = 1; i <= 10; i++)
sum += i;
cout << "Sum from 1 to 10 is " << sum << endl;
sum = 0;
for (int i = 20; i <= 37; i++)
sum += i;
cout << "Sum from 20 to 37 is " << sum << endl;
sum = 0;
for (int i = 35; i <= 49; i++)
sum += i;
cout << "Sum from 35 to 49 is " << sum << endl;

Solution
int sum(int i1, int i2)
{
int sum = 0;
for (int i = i1; i <= i2; i++)
sum += i;
return sum;
}
int main()
{
cout << "Sum from 1 to 10 is " << sum(1, 10) << endl;
cout << "Sum from 1 to 10 is " << sum(20, 37) << endl;
cout << "Sum from 1 to 10 is " << sum(35, 49) << endl;
return 0;
}

Defining a Function
A function is a collection of statements that are
grouped together to perform an operation.
Invoke a funciton

Define a function
return value type
function

method name

formal parameters

{

function
body

int result;
if (num1 > num2)
result = num1;
else
result = num2;
}

return result;

## int z = max(x, y);

parameter list

actual parameters
(arguments)

function
signature
return value

## Defining Functions, cont.

Function signature is the combination of the
function name and the parameter list.
The variables defined in the function header are
known as formal parameters.
When a function is invoked, you pass a value to
the parameter. This value is referred to as actual
parameter or argument.

## Defining Functions, cont.

A Function may return a value. The
returnValueType is the data type of the value the
function returns. If the function does not return a
value, the returnValueType is the keyword void.

Calling a Function
Listing 6.1 Testing the max Function
This program demonstrates calling a Function
max to return the largest of the int values

TestMax

Run

animation

## pass the value i

pass the value j
int main()
{
int i = 5;
int j = 2;
int k = max(i, j);

## cout << "The maximum between "

<< i << " and " + j + " is "
<< k;
return 0;

{
int result;
if (num1 > num2)
result = num1;
else
result = num2;
}

return result;

10

animation

i is now 5

## pass the value i

pass the value j
int main()
{
int i = 5;
int j = 2;
int k = max(i, j);

## cout << "The maximum between "

<< i << " and " + j + " is "
<< k;
return 0;

{
int result;
if (num1 > num2)
result = num1;
else
result = num2;
}

return result;

11

animation

j is now 2

## pass the value i

pass the value j
int main()
{
int i = 5;
int j = 2;
int k = max(i, j);

## cout << "The maximum between "

<< i << " and " + j + " is "
<< k;
return 0;

{
int result;
if (num1 > num2)
result = num1;
else
result = num2;
}

return result;

12

animation

invoke max(i, j)

## pass the value i

pass the value j
int main()
{
int i = 5;
int j = 2;
int k = max(i, j);

## cout << "The maximum between "

<< i << " and " + j + " is "
<< k;
return 0;

{
int result;
if (num1 > num2)
result = num1;
else
result = num2;
}

return result;

13

animation

## Trace Function Invocation

invoke max(i, j)
Pass the value of i to num1
Pass the value of j to num2

## pass the value i

pass the value j
int main()
{
int i = 5;
int j = 2;
int k = max(i, j);

## cout << "The maximum between "

<< i << " and " + j + " is "
<< k;
return 0;

{
int result;
if (num1 > num2)
result = num1;
else
result = num2;
}

return result;

14

animation

## Trace Function Invocation

declare variable result

## pass the value i

pass the value j
int main()
{
int i = 5;
int j = 2;
int k = max(i, j);

## cout << "The maximum between "

<< i << " and " + j + " is "
<< k;
return 0;

{
int result;
if (num1 > num2)
result = num1;
else
result = num2;
}

return result;

15

animation

## Trace Function Invocation

(num1 > num2) is true since
num1 is 5 and num2 is 2

## pass the value i

pass the value j
int main()
{
int i = 5;
int j = 2;
int k = max(i, j);

## cout << "The maximum between "

<< i << " and " + j + " is "
<< k;
return 0;

{
int result;
if (num1 > num2)
result = num1;
else
result = num2;
}

return result;

16

animation

result is now 5

## pass the value i

pass the value j
int main()
{
int i = 5;
int j = 2;
int k = max(i, j);

## cout << "The maximum between "

<< i << " and " + j + " is "
<< k;
return 0;

{
int result;
if (num1 > num2)
result = num1;
else
result = num2;
}

return result;

17

animation

## Trace Function Invocation

return result, which is 5

## pass the value i

pass the value j
int main()
{
int i = 5;
int j = 2;
int k = max(i, j);

## cout << "The maximum between "

<< i << " and " + j + " is "
<< k;
return 0;

{
int result;
if (num1 > num2)
result = num1;
else
result = num2;
}

return result;

18

animation

## Trace Function Invocation

return max(i, j) and assign the
return value to k

## pass the value i

pass the value j
int main()
{
int i = 5;
int j = 2;
int k = max(i, j);

## cout << "The maximum between "

<< i << " and " + j + " is "
<< k;
return 0;

{
int result;
if (num1 > num2)
result = num1;
else
result = num2;
}

return result;

19

animation

## Trace Function Invocation

Execute the print statement

## pass the value i

pass the value j
int main()
{
int i = 5;
int j = 2;
int k = max(i, j);

{
int result;

## cout << "The maximum between "

<< i << " and " + j + " is "
<< k;
return 0;

## if (num1 > num2)

result = num1;
else
result = num2;
}

return result;

20

void Functions
The preceding section gives an example of a
nonvoid function. This section shows how to
declare and invoke a void function. Listing 6.2
gives a program that declares a function named
given score.
TestVoidFunction

Run

Run

21

## Passing Arguments by Value

By default, the arguments are passed by value to
parameters when invoking a function.
The power of a function is its ability to work with
parameters. You can use max to find the maximum
between any two int values. When calling a
function, you need to provide arguments, which
must be given in the same order as their respective
parameters in the function signature. This is known
as parameter order association. For example, the
following function prints a character n times.

22

Modularizing Code
Methods can be used to reduce redundant coding and
enable code reuse. Methods can also be used to
modularize code and improve the quality of the
program.
GreatestCommonDivisorFunction
Run
Run

23

The max function that was used earlier works only
with the int data type. But what if you need to find
which of two floating-point numbers has the
maximum value? The solution is to create another
function with the same name but different
parameters, as shown in the following code:

Run
24

Ambiguous Invocation
Sometimes there may be two or more
possible matches for an invocation of a
function, but the compiler cannot determine
the most specific match. This is referred to
as ambiguous invocation. Ambiguous
invocation is a compilation error.

25

Ambiguous Invocation
#include <iostream>
using namespace std;
int maxNumber(int num1, double num2)
{
if (num1 > num2)
return num1;
else
return num2;
}
double maxNumber(double num1, int num2)
{
if (num1 > num2)
return num1;
else
return num2;
}
int main()
{
cout << maxNumber(1, 2) << endl;
return 0;
}

26

Function Prototypes
Before a function is called, it must be declared first.
One way to ensure it is to place the declaration
before all function calls. Another way to approach
it is to declare a function prototype before the
function is called. A function prototype is a function
declaration without implementation. The
implementation can be given later in the program.

TestFunctionPrototype

Run
27

Default Arguments
C++ allows you to declare functions with default
argument values. The default values are passed to
the parameters when a function is invoked without
the arguments.

DefaultArgumentDemo

Run
28

Inline Functions
Implementing a program using functions makes the program easy to
(i.e., pushing arguments and CPU registers into the stack and
transferring control to and from a function). C++ provides inline
functions to avoid function calls. Inline functions are not called; rather,
the compiler copies the function code in line at the point of each
invocation. To specify an inline function, precede the function
declaration with the inline keyword, as shown in Listing 6.18.
InlineDemo

Run

InlineExpandedDemo

29

Short Functions
Not for long Functions
Compiler Decision
Inline functions are desirable for short functions, but not
suitable for long functions that are called in multiple
places in a program, because long inline functions will
dramatically increase the executable code size when it is
copied in multiple places. For this reason, C++ allows the
compilers to ignore the inline keyword if the function is
too long. So, the inline keyword is merely a request to the
compiler, and it is up for the compiler to make the
decision whether to honor it or ignore it.

30

Scope of Variables
A local variable: a variable defined inside a
function.
Scope: the part of the program where the
variable can be referenced.
The scope of a variable starts from its
declaration and continues to the end of the
block that contains the variable.

31

## Scope of Local Variables, cont.

You can declare a local variable with the
same name in different blocks.

32

## Scope of Local Variables, cont.

A variable declared in the initial action part of a for loop
header has its scope in the entire loop. But a variable
declared inside a for loop body has its scope limited in the
loop body from its declaration and to the end of the block
that contains the variable.

The scope of i
The scope of j

void method1() {
.
.
for (int i = 1; i < 10; i++)
{
.
int j;
.
.
.
}
}

33

## Scope of Local Variables, cont.

It is fine to declare i in two
non-nesting blocks
void function1()
{
int x = 1;
int y = 1;

It is wrong to
declare i in two nesting blocks
void function2()
{
int i = 1;
int sum = 0;

{
x += i;
}

{
sum += i;
}

{
y += i;
}

## cout << i << endl;

cout << sum << endl;
}

34

Global Variables
C++ also allows you to use global variables. They
are declared outside all functions and are
accessible to all functions in its scope. Local
variables do not have default values, but global
variables are defaulted to zero.

VariableScopeDemo

Run
35

## Unary Scope Resolution

If a local variable name is the same as a global variable
name, you can access the global variable using
::globalVariable. The :: operator is known as the unary
scope resolution. For example, the following code:
#include <iostream>
using namespace std;
int v1 = 10;
int main()
{
int v1 = 5;
cout << "local variable v1 is " << v1 << endl;
cout << "global variable v1 is " << ::v1 << endl;
return 0;
}