Skip to main content

Pointers in C programming


            A pointer is a variable that stores a memory address of a variable. Pointer can have any name that is legal for other variable and it is declared in the same fashion like other variables but is always preceded by ‘ *’ ( asterisk) operator.

Applications of a pointer:
     There are a number of reasons for using pointers. Some of them are:
1)      Pointers can be used to pass information back and forth between a function and its reference point.
2)      Pointers provide a way to return multiple data items from a function via function arguments.
3)      Pointers provide an alternative way to access individual array elements. 
4)      They increase the execution speed as they refer address.

Pointer declaration
   Pointer variables can be declared as follows:
            Syntax:
                   data-type  *  variable_name;
            Examples:
               int *x; float *f; char *y;
  
          In the first statement, ‘x’ is an integer pointer and it tells to the compiler that it holds the address of any integer variable. In the same way ‘f’ is a float pointer which stores the address of any float variable and ‘y’ is a character pointer that stores the address of any character variable.
                Here * is called pointer or indirection operator. Normal variable provides direct access to their own values whereas a pointer provides indirect access to the values of the variable whose address it stores. The indirection operator (*) is used in two distinct ways with pointers, declaration and dereference. When the pointer is declared, the star indicates that it is a pointer, not a normal variable. When the pointer is dereferenced, the indirection operator indicates that the value at that memory location stored in the pointer is to be accessed rather than the address itself. Also note that * is the same operator that can be used as the multiplication operator. The compiler knows which operator to call, based on the context. An example
     void main( )
           {
      int v=10, *p; // Here, * indicates p as pointer
      p=&v;
      printf(“\n address of v=%u”,p);
      printf(“\n value of v=%d”,*p); // Here, * indicates value at address pointed by p
      printf(“\n address of p=%u”,&p);
       }

Output:
address of v=65524
 value of v=10
 address of p=65522

It can be illustrated as

                 Here v is an integer variable and its value is 10. The variable p is declared as pointer variable. The statement p=&v assigns address of ‘v’ to ‘p’ i.e. ‘p’ is the pointer to variable ‘v’. To access the address and value of ‘v’ pointer ‘p’ can be used. The value of ‘p’ is nothing but address of the variable ‘v’. To display the value stored at that location *p is used. The address of the pointer variable can be accessed using ‘&’ operator. Pointer variable can also be initialized at the time of declaration. It is done as follw.
           int a;

           int *p=&a;

Comments

Popular posts from this blog

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...

CPU (Central Processing Unit)

PGA reffered as pin grid array in which pins of CPU are lined up in a straight format. SPGA referred as staggered pin grid array. in which pins of CPU are arranged staggered format. LGA reffered to as Land Grid Array in which pins are available within inside the socket but not in the CPU in other words in line grid array, in CPU ther are no pinsbut insteadpins areattached with in a socket which contact with with the CPU. for e.g. LGA775 socket(no pins on cpu) has better cooling system. better contact and better locking(climbing). LGA1155: Letest generation I socket, also reffered as sandy bridge, Turbo boost overclocking. More resent than LGA 1156 socket. LGA1156: ability to north bridge Doul channel DDR3 optional integreted graphics PCI express LGA1366: hi end core i series socket integreted tiple channal memmory controller external control bridge(HUB) Upgrading CPU: need to check its core suppert check multiprocessor supports or not check on the ...

Recursive Function in C programming

             If a statement within the body of a function calls the same function, the function is called recursive function. Actually, recursion is a process by which a function calls itself repeatedly until some specified condition has been satisfied. This process is used for repetitive computations in which each action is stated in term of previous result. Many iterative or repetitive problems can be written in this form.                To solve a problem using recursive method, two conditions must be satisfied. They are: 1)       Problem could be written or defined in term of its previous result. 2)       Problem statement must include a stopping condition. /*   An example of recursive function to calculate factorial of a number.*/    #include<stdio.h>    #include<conio.h...