A Pointer Is a Variable That Is Used to Store a Memory Address (Of Variable, Array, Function

A Pointer Is a Variable That Is Used to Store a Memory Address (Of Variable, Array, Function

<p> Pointer</p><p>A pointer is a variable that is used to store a memory address (of variable, array, function, class object etc.).</p><p>Recall that we use memory bins to store any type of data. And the size of the bin (in terms of bits or bytes) depend on the type of data. When we declare a variable of a particular type (say double length), it reserves a memory bin of that type and assigns the variable name to that bin. A memory bin has an address and is usually expressed in hexadecimal. We can store the address of a memory bin (i.e. of a variable name) in a pointer. Then we can access that bin by the pointer as well as by the variable name.</p><p> num reserves a memory bin of type int int num; and assign its name as num 0012FF7C</p><p>Address of the memeory bin</p><p>Declaring a pointer </p><p> long* pnumber; //declares pnumber of type pointer to long long *pnumber; int *pa, *pb; double *pmark;</p><p>Note : The asterisk may be attached to either type name or variable name.</p><p> int* pnumber, number; //declare pnumber as pointer to int and number as int </p><p>Indirection operator *</p><p>When we put * immediately before a pointer, it refers to the contents of the memory bin pointed to by the pointer variable. Thus if px is a pointer then *px (in statements other then declaration) means the value stored in the address referred to by px. Note : By now it can be noticed that the same symbol * has different meaning. It is used as multiplication operator, as indirection operator and also to declare a pointer. The compiler is able to distinguish the meaning by the context. The address of operator & </p><p>The address-of operator ‘&’ is a unary operator that obtains the address of a variable in the memory. int *pnumber; pnumber=&number; //&number means the address of number and it is stored in pnumber. // Program - P41 y #include<iostream> x using namespace std; 0012AA14 00FFAB1A void main( ){ int x, y; px int *px; py int *py; x x=10; 10 px=&x; 0012AA14 px py=&y; 00FFAB1A py y=*px; cout<<" x ="<<x<<" y ="<<y<<endl; cout<<"\n *px ="<<*px<<" py ="<<*py<<endl; }</p><p>// Program - P40 #include<iostream> using namespace std; void main( ){ int number; cin>>number; cout<<"&number = "<<&number<<endl; int* pnumber; pnumber=&number; cout<<"pnumber = "<<pnumber<<endl; }</p><p>Why use pointers? There are several reasons some of which are :  pointers can be used to operate on data stored in an array which often executes faster than if array notation is used.  pointers can be used to access within a function blocks of data such as array which is defined outside the function.  space for new variables can be allocated dynamically (i.e. during the program execution) by use of pointers.</p><p>Initializing pointers</p><p>It is a good practice to initialize pointers (initializing variables also).</p><p>It is easy to initialize a pointer to the address of a variable. However, the variable must have to be declared prior to the pointer declaration. int age = 0; // initialized integer variable int* page = &age; // initialized pointer </p><p>We can also initialize a pointer as below int* pnum=0; // pointer not pointing to anything</p><p>A pointer initialized in this way is called a null pointer.</p><p>Array and pointers</p><p>The array name and a pointer has similarity in that both contains an address. We have seen it before (when we studied array and function, Program P37b) that an array name contains the address of the first element of the array. However, most significant difference between a pointer and an array name is that you can modify the address stored in a pointer, while the address the array name refers to is fixed.</p><p> double value[5]; double* pvalue = value; // stores the address of the array values in pvalues</p><p>Now pvalue+1 will mean the address of value[1] pvalue+2 will mean the address of value[2] pvalue+3 will mean the address of value[3] pvalue+4 will mean the address of value[4]</p><p> pvalue++; or pvalue+=1; are also valid statements.</p><p>This is demonstrated by program P43. We have seen by program P03 that memory bins of type double are 8 byte. So if the address of value[0] is 00FF1258 then the address of value[1] will be 00FF1258+8=0012FF1260 value[2] will be 00FF1260+8=0012FF1268 value[3] will be 00FF1268+8=0012FF1270 value[4] will be 00FF1270+8=0012FF1278 that’s what we have got in the output of P43. // Program - P43 #include<iostream> using namespace std; void main( ) { double value[5], *pvalue; pvalue=value; cout<<"\n pvalue = "<<pvalue; cout<<"\n value[0]="<<&value[0]; cout<<"\n pvalue+1 ="<<pvalue+1; cout<<"\n value[1]="<<&value[1]; cout<<"\n pvalue+2 ="<<pvalue+2; cout<<"\n value[2]="<<&value[2]; cout<<"\n pvalue+3 ="<<pvalue+3; cout<<"\n value[3]="<<&value[3]; cout<<"\n pvalue+4 ="<<pvalue+4; cout<<"\n value[4]="<<&value[4]; cout<<endl; }</p><p> double value[5];</p><p> value[0] value[1] value[2] value[3] value[4]</p><p>0012FF58 0012FF60 0012FF60 0012FF60 0012FF60 address We can also use the name of an array as though it was a pointer. We can address the elements of an array (declared above).</p><p>*(value+i) refers to value[i] of the array</p><p>// Program - P44 /* Program to find average of a set of numbers in an array */ #include<iostream> #include<iomanip> using namespace std; void main( ){ double number[10], sum=0.0; int n; cout<<" How many numbers (max 10)? "; cin>>n; cout<<" Input the numbers\n "; for(int i=0; i<n; i++){cin>>number[i];} for(i=0; i<n; i++){sum += *(number+i);} // for(i=0; i<n; i++){sum += number[i];} cout<<"Average = "<<sum/n<<endl; } for a two dimensional array value[ ][ ], *(*(value+i)+j) refers to value[i][j]; This can be explained as below value refers to the address of the first row of the array value+i refer to the address of row i of the array *(value+i) refer to the address of the first element of row i *(value+i)+j refer to the address of offset j at row i *(*(value+i)+j) refer to the // Program - P45 #include<iostream> #include<iomanip> using namespace std; void main( ){ double value[10][10]; int m,n; cout<<" No. of rows (max 10)? "; cin>>m; cout<<" No. of columns (max 10)? "; cin>>n; cout<<" Input the elements of the matrix (row wise)\n "; int i,j; for(i=0; i<m; i++){ for(j=0; j<n; j++)cin>>value[i][j]; } for(i=0; i<m; i++){ for(j=0; j<n; j++)cout<<setw(7)<<value[i][j]; cout<<endl; } cout<<"value[1][2] = "<<value[1][2]<<endl; cout<<"*(*(value+1)+2)= "<<*(*(value+1)+2)<<endl; } The above usages of pointer are not necessary. Major and effective use of pointer is for dynamic memory allocation which is shown below.</p><p>Dynamic memory allocation</p><p>When we declare a variable or an array in the source code in the form int salary; float area; string address; double ce206[50]; the corresponding memory requirement is decided at compile time. All of this amount of memory will be allocated, at execution of the program, whether we need them or not.</p><p>// Program - P44a /* Program to find average of a set of numbers in an array */ #include<iostream> #include<iomanip> using namespace std; void main( ){ double number[10], sum=0.0; int n; cout<<" How many numbers (max 10)? "; cin>>n; cout<<" Input the numbers\n "; for(int i=0; i<n; i++){cin>>number[i];} for(i=0; i<n; i++){sum += number[i];} cout<<"Average = "<<sum/n<<endl; }</p><p>In a program P44a we have set the dimension of array number to 10. Now if we prepare the .exe file we won’t be able to process more than 10 numbers. We may think that, we will prepare the software with a higher array dimension say 100000. But now, when this program is invoked it will occupy higher amount of memory. (it can be checked invoking windows taskmanager and running P44a with different dimension) And this same higher memory will be occupied even when you process 2 numbers as well as when you process 100000 numbers. In a large program, where there will be many such arrays, it may so happen that for some arrays the memory is allocated needlessly whereas for some other arrays, there is not enough memory. Such a situation can be avoided by using dynamic memory allocation. Dynamic memory allocation means that the amount of memory to be allocated will be decided at run time.</p><p>By definition, dynamically allocated variables cannot be declared at compile time and so they cannot be named in the source code.</p><p>When we run programs, there may be unused memory, in the computer. This unused memory is called free store or heap. We can allocate space within this free store for a new variable by using a special c++ operator new. Also we can de-allocate a previously allocated memory by the operator delete.</p><p> remember that it is a good idea to initialize a double *pvalue; pointer (same is true for a variable or array) such pvalue = new double; as double *pvalue = 0;</p><p>The first line above is a pointer declaration. The second line of code will allocate a memory bin of type double in the free store and store its address in pointer pvalue. Now we can use this memory bin by statements (using the indirection operator) such as </p><p>*pvalue = 20.5;</p><p>When this memory is not required we can de-allocate this memory by delete pvalue; double *pnum; More examples int max; ...... char *pstring; cin>>max; ...... pstring = new char[20]; pnum = new num[max]; ...... delete [ ] pstring; delete [ ] pnum; Warning : Memory once allocated by the new operator won’t be available (even if it is not required any more) for other variables unless it is de-allocated by delete operator.</p><p>Program P46 shows the use of dynamic memory allocation.</p><p>// Program - P46 /* Program to find average of a set of numbers in an array using free store */ #include<iostream> #include<iomanip> using namespace std; void main( ){ int n; cout<<" How many numbers? "; cin>>n; double *number= new double[n]; double sum=0.0; cout<<" Input the numbers\n "; for(int i=0; i<n; i++){cin>>*(number+i);} for(i=0; i<n; i++){sum += *(number+i);} cout<<"Average = "<<sum/n<<endl; delete [] number; }</p><p>Variable of type long</p><p>1000 1004 1008 15467 </p><p>1000 A pointer Variable</p>

View Full Text

Details

  • File Type
    pdf
  • Upload Time
    -
  • Content Languages
    English
  • Upload User
    Anonymous/Not logged-in
  • File Pages
    10 Page
  • File Size
    -

Download

Channel Download Status
Express Download Enable

Copyright

We respect the copyrights and intellectual property rights of all users. All uploaded documents are either original works of the uploader or authorized works of the rightful owners.

  • Not to be reproduced or distributed without explicit permission.
  • Not used for commercial purposes outside of approved use cases.
  • Not used to infringe on the rights of the original creators.
  • If you believe any content infringes your copyright, please contact us immediately.

Support

For help with questions, suggestions, or problems, please contact us