Functions in C++
Functions are used to provide modularity to a program. Creating an application using function makes it easier to understand, edit, and check errors.
Basic Syntax for using Functions in C++
Here is how you define a function in C++,
return-type function-name(parameter1, parameter2, ...)
{
}
- return-type: suggests what the function will return. It can be int, char, some pointer or even a class object. There can be functions which does not return anything, they are mentioned with void.
- Function Name: is the name of the function, using the function name it is called.
- Parameters: are variables to hold values of arguments passed while function is called. A function may or may not contain parameter list.
void sum(int x, int y)
{
int z;
z = x + y;
cout << z;
}
int main()
{
int a = 10;
int b = 20;
sum (a, b);
}
Here, a
and b
are two variables which are sent as arguments to the function sum
, and x
and y
are parameters which will hold values of a
and b
to perform the required operation inside the function.
- Function body: is the part where the code statements are written.
Declaring, Defining and Calling a Function
Function declaration, is done to tell the compiler about the existence of the function. Function's return type, its name & parameter list is mentioned. Function body is written in its definition. Lets understand this with help of an example.
#include < iostream>
using namespace std;
int sum (int x, int y);
int main()
{
int a = 10;
int b = 20;
int c = sum (a, b);
cout << c;
}
int sum (int x, int y)
{
return (x + y);
}
Here, initially the function is declared, without body. Then inside main()
function it is called, as the function returns sumation of two values, and variable c
is there to store the result. Then, at last, function is defined, where the body of function is specified. We can also, declare & define the function together, but then it should be done before it is called.
Calling a Function
Functions are called by their names. If the function is without argument, it can be called directly using its name. But for functions with arguments, we have two ways to call them,
- Call by Value
- Call by Reference
Call by Value
In this calling technique we pass the values of arguments which are stored or copied into the formal parameters of functions. Hence, the original values are unchanged only the parameters inside function changes.
void calc(int x);
int main()
{
int x = 10;
calc(x);
printf("%d", x);
}
void calc(int x)
{
x = x + 10 ;
}
10
In this case the actual variable x
is not changed, because we pass argument by value, hence a copy of x is passed, which is changed, and that copied value is destroyed as the function ends(goes out of scope). So the variable x inside main() still has a value 10.
But we can change this program to modify the original x, by making the function calc() return a value, and storing that value in x.
int calc(int x);
int main()
{
int x = 10;
x = calc(x);
printf("%d", x);
}
int calc(int x)
{
x = x + 10 ;
return x;
}
20
Call by Reference
In this we pass the address of the variable as arguments. In this case the formal parameter can be taken as a reference or a pointer, in both the case they will change the values of the original variable.
void calc(int *p);
int main()
{
int x = 10;
calc(&x);
printf("%d", x);
}
void calc(int *p)
{
*p = *p + 10;
}
20
Homework: Create a program (using user-defined functions) that accepts two values, performs the additions, subtraction, multiplication and division of the values, and outputs the results.
DUE DAY 10