Skip to main content

Accessing a function in C programming

                  A function can be called or accessed by specifying its name, followed by a list of arguments enclosed in parentheses and separated by commas. For example, add(a,b) to call a function to add two numbers. If function call doesn’t require any arguments, any empty pair of parentheses must follow the name of function. The arguments appearing in the function call are referred as actual arguments. In function call, there will be one argument for each formal argument. The value of each argument is transferred into the function and assigned to the corresponding formal argument.
An example
/* to find the greatest number among three numbers.*/
       #include <stdio.h>
       #include<conio.h>
         int greater(int x, int y)    /* function definition*/
              {
                 if(x>y)
                        return (x);
                 else
                    return (y);               
                }

  void main()
               {
                  int a, b,c,d,e;
                  clrscr();
                  printf(“Enter three numbers”);
                  scanf(“%d%d%d”,&a,&b,&c);
                  d=greater(a,b);          /* function call*/
                  e=greater(d,c);          /* same function call again*/
                  printf(“The greatest number is%d”,e);
                  getch();                
                }

Function call by value:
             When actual value of variable is passed to the function as argument, it is known as function call by value. In this call, the value of the actual argument is copied into the function’s formal argument. Therefore, the value of the corresponding formal argument can be altered within the function. But, this will not change the value of the actual argument within the calling function.
Example:
          #include<stdio.h>
          #include<conio.h>
          void swap(int , int);
             void main()
                 {
                     int a, b;
                     a=99; b=89;
                     printf(“Before function calling, a and b are: %d\t%d”,a,b);
                     swap(a,b);
                     printf(“After function calling, a and b are: %d\t%d”,a,b);
                     getch();
                  }
                  
 void swap(int x, int y)
            {
               int temp;
               temp=x;
               x=y;
               y=temp;
               printf(“The values within functions are:%d\t%d”,x,y);
              }
      
Output:
         Before function calling, a and b are: 99            89
         The values within functions are: 89                   99
         After function calling, a and b are: 99               89
The above output shows that the actual argument’s value are not changed even the value of formal arguments are changed.

/* Program to illustrate the function with argument and return values */
int add(int, int) ;
main()
{
int a, b, sum ;
printf (“Enter two numbers : \t”) ;
scanf (“%d%d”, &a, &b) ;
sum = add(a, b) ;
printf (“ln the sum is \t%d|, sum) ;
}
int add(int a, int b)
{
int sum ;
sum = a+b ;
return sum ;
}
Output:
Enter two numbers : 4 3
The sum is 7

Function call by Reference:
                In this type of function call, the address of variable is passed to the function as argument instead of actual value of variable. For clear understanding of this, concept of pointer is necessary which we will study in next chapter.
        Example:
/*a program to swap the two variable’s values*/
          #include<stdio.h>
          #include<conio.h>
          void swap(int * , int *);
             void main()
                 {
                     int a, b;
                     a=99; b=89;
                     printf(“Before swap, a and b are: %d\t%d”,a,b);
                     swap(&a,&b);             /*  function call by reference*/
                     printf(“After swap, a and b are: %d\t%d”,a,b);
                     getch();
                  }
 void swap(int *x, int *y)
            {
               int temp;
               temp=*x;  /*  here *x represent the value at address contained in variable x */
               *x=*y;
               *y=temp;
               }
       Output:
               Before swap, a and b are: 99           89
               After swap, a and b are: 89       99

Comments

Popular posts from this blog

Object Oriented Programming

Object Oriented Programming Programming paradigm that represents the concept of "objects" that have data fields (attributes that describe the object) and associated procedures known as methods Programming methodology based on objects, instead of just functions and procedures Focuses on data rather than process As individual objects can be modified without affecting other aspects of the program, it is easier for programmers to structure and organize software programs Easier to update and change programs written in object-oriented languages Simula was the first object oriented programming language Eg: C++, Java, etc. Features of OOPS Objects Referred as instance of class Basic run-time entities in an object-oriented system a person, a place, a bank account, a table of data, etc can be an object They occupy space in memory that keeps its state  Each object contains data and code to manipulate the data  Classes Blue print or prototype  which ...

Passing arrays to functions in C programming

Like any other variables, we can also pass entire array to a function. An array name can be named as an argument for the prototype declaration and in function header. When we call the function no need to subscript or square brackets. When we pass array that pass as a call by reference because the array name is address for that array. /* Program to illustrate passing array to function */ #include<stdio.h> void display(int) ; /* function prototype */ main( ) { int num[5] = {100, 20, 40, 15, 33, i ; clrscr( ) ; printf (“\n The content of array is \n”) ; for (i=0; i<5; i++) display (num[i]) ; /*Pass array element fo fun */ getch{ } ; } void display(int n) { printf (“\t%d”, n ) ; } Output:     The content of array is 100      20       40       15 3 /* Program to read 10 numbers from keyboard to store these num into array and then c...

Software Development Life Cycle

Software Crisis In earlier days, same codes needed to be written time and again increasing the complexity and time required for development This resulted in software not being completed on time and the cost increased than expected Solution: Object Oriented Programming Software Evolution Investigation Feasibility Study Analysis Design Implementation Maintenance Investigation First step in preparation of the IS includes the preliminary study of proposed information system investigates the information needs of the users and determines the resource requirement, costs, benefits and feasibility of a proposed project 2. Feasibility Study feasibility study is an analysis of the practicality of an idea focuses on helping answer the essential question of “should we proceed with the proposed project idea?” The feasibility study is conducted in four different areas: 1. Organizational feasibility 2. Economic feasibility 3. Technical feasibility 4. Operation...