Skip to main content

Arrays and static Memory allocation in C

In this post we will be talking about array, their usage and importance in C.

Array

Array in simple world is a collection/container of elements of  same type. Array of any type is possible but the elements in array cannot be of multiple types.

  • We can have array of int type.
  • But not a array with 5 element of int and other element of other types .

Why Array?

Imagine a problem where you want to input the marks of 10 student in a subject  from the user and display the marks in descending number.
Our major problem above will be to store the number input by the user.
Here we have two options :
  • Either construct 10 variables for storing marks of 10 student .(A trash Idea)
  • Or Construct a container (Array of integers in this case) which can store all the marks of student .

First Glance of an Array

As mentioned earlier array is a nothing else than a collection for us.


int marks[10= {'1','2','3','4','5'};


This is what an array looks like ( A declaration of array).
Here int refers to the type of element the array is storing.
marks is the name given to our collection(array). It is an collection of integers marks.Let's get bit more technical here It is an array of marks in integer. 

We can also see [10] .This is what we call index/subscript/dimension  of an  array. It indicates the maximum number of element of that can be stored in our array.

Declaration and initialization of Array

We have already seen how an array can be initialized however there are other ways too.

int score[10]; //array of ints
char name[20]; //array of chars
int marks[] = {'1','2','3','4','5'};

Something has changed? Our third array doesn't have any index on it . Yeah that's possible but only when we initialize the members of array.


int marks[]; //error

 The above declaration is invalid. The compiler needs to know the dimension of array for some reason which we will discuss later.

Accessing Array Elements

As we have learnt about initializing and declaring an array .Let us see how can we access the elements of an array.

Before this let's learn a very basic but an important thing about array.

Arrays always start with 0.
What it mean is The first element of an array is in Zero position,the second on first and so on.

Okay let's now access our array elements.


int marks[] = {'1','2','3','4','5'};

We should always keep in mind that an Array always starts from 0.
marks[0]; //equal to 1
marks[1];//equal to 2
marks[2];//equal to 3
marks[3]; //equal to 4

So let's write a program where we'll implement what we have learnt so far.

A program to Print out all the elements of array.

#include<stdio.h>

int main()
{
    int store[5]={1,2,3,4,5};
printf("The numbers are \n");
    for(int i = 0i < 5 ; i++)
    {
        printf("%d ",store[i]);
    }
    return 0;
}

Here inside our main function we have initialized an integer array store which can store maximum of 5 integers.

As we already learnt that

store[0] refers to the first element of array. (1 in this case)
store[4] refers to the last element of the array.(5 in this case) So the output will be

1 2 3 4 5

We are using the similar concept but using the for loop .

When i =0 store[0] = 1
          i=1 store[1]  = 2
and soon.You know a for loop well .I believe.

Entering Data into an Array

Entering data into an array is as similar as entering a value into our variables . 

Let's grow our above program in such a way that it asks the user to input 5 numbers which we'll store in an array and display them.

#include<stdio.h>

int main()
{
    int store[5];
    for(int i =0;i<5;i++)
    {
      printf("Enter the element no %d ",i+1);
      scanf("%d",&store[i]);
    }
    printf("The numbers are \n");
    for(int i = 0i < 5 ; i++)
    {
        printf("%d ",store[i]);
    }
    return 0;
}

The output will be 

Enter the element no 1 1
Enter the element no 2 2
Enter the element no 3 3
Enter the element no 4 4
Enter the element no 5 5
The numbers are 
1 2 3 4 5
 
Here we used the &(address of operator) to store the value.

Memory Allocation in Array

Let's now learn whats going behind the scene with arrays.

Whenever we make an array declaration like:

float arr[5]; //array of float

20 (4 byte for a float so 20 byte for 5 int)bytes of memory will be immediately reserved for us.
Although the array is not being initialized garbage value or 0 (depends on the storage class or scope of declaration)is stored in that particular memory 


Here 1024 ,1028 are imaginary memory address of the variable but the allocated memory address is always contiguous (continuous) .We can clearly see our first element is at address 1024 while second element at 1028 ,third at 1032 and so on .

The contiguous memory location of an array can be demonstrated with the following program below.

#include<stdio.h>

int main()
{
    int store[5];
    for(int i =0;i<5;i++)
    {
       printf("Enter the element no %d ",i+1);
       scanf("%d",&store[i]);
    }
    printf("The numbers are \n");
    for(int i = 0i < 5 ; i++)
    {
     printf("The memory address of store[%d]\n
is %u and value at %u is %d\n",
i,&store[i],&store[i],store[i]);
    }
    return 0;
}

The output is 

Enter the element no 1 1
Enter the element no 2 2
Enter the element no 3 3
Enter the element no 4 4
Enter the element no 5 5
The numbers are 
The memory address of store[0]
is 6422276 and value at 6422276 is 1
The memory address of store[1
is 6422280 and value at 6422280 is 2
The memory address of store[2
is 6422284 and value at 6422284 is 3
The memory address of store[3
is 6422288 and value at 6422288 is 4
The memory address of store[4
is 6422292 and value at 6422292 is 5





Comments

Post a Comment

Popular posts from this blog

Making your own version of string handling function in C

 In the previous post we discussed about  string handling functions in C . In this post we'll be defining our own version for those function. Let's see how. xstrlen As the name suggests xstrlen will be function performing same functions as strlen function which returns the length of the string. # include < stdio.h > int   xstrlen ( char   * ); int   main () { char   name [] = " Abhilekh " ; printf ( " length is  %d " , xstrlen ( name )) ; return   0 ; } int   xstrlen ( char   * a) {      int   length   =   0 ;      while ( * a != ' \0 ' )     {        length ++ ;       a ++ ;     }      return   length ; } Look at the function prototype. int   xstrlen ( char   * ); It is very clear that the function is expecting a character pointer as a parameter and the function will be returning a integer value. Let us now see how we are calling the function, xstrlen ( name ) We are passing the name_of_array as a parameter. It should be noted that the name of

What is this Pointer in C++?

 Pointers are always headache for Programmers. However C++ have a special pointer which is referred as ' this '. The this pointer is one of the important concept in C++ and can be really confusing too. So in this article I will be discussing about the this pointer and its role in C++. The this Pointer Let us see an example first. # include < iostream > using   namespace  std; class   A { int   a ; public: // constructor A ( int   x   =   0 ): a ( x ){} void   display ()  const {      cout << a << ' \n ' ; } }; int   main (){ A   objA ( 10 ); A   objB ( 11 ); objA . display (); objB . display (); return   0 ; } It is very clear that the output will be 10 11 The program looks very simple, But do you know whats going on, under the Hood? How does the function remember, which object is invoking it? This is where the this pointer comes in action. Actually, the Compiler is secretly passing a constant pointer pointing to the object

File Handling and Various File Opening Modes in C

Every programs we were doing before were using Memory for storage and all those memory would wipe out once the program is terminated.But sometime the case is different,what if we need all those data again,We need to re-enter all those bulky data again,which will again be wiped out once the program is terminated. So we need to store the data in such a place such that it can be retrieved and displayed again and again.This is why we need files.The place about which we previously talked is the file on the disk.So we need File Handling to work with files. Let us see how a file can be handled. Various Operations in Files Creating a File Opening a File Reading from a File Writing to a File Closing a File File Opening Modes in C Before performing any operations in files,we must create/open the file . Here are the various File opening modes in C. "r" : It searches the file.If the file opens up successfully,the function fopen() loads the file from disk to memory and sets a pointer

What is Storage class and What are their types in C

 Variable declaration is not complete until we mention its storage class( there are some default conditions as well). Yeah you got it right ,Variables not only have data types they have storage class too. Why storage class? They tell us about The scope of the variable. Life time of the variable. Initial value of the the variable, if left unassigned. We have four storage class in C Automatic storage class External storage class Static storage class Register storage class Let us look at them one by one. Automatic Storage Class Scope : Local to the block where it is defined. Life Time : Until the control remains in the block. Initial value : A garbage value, one cannot predict. We use the keyword auto to declare a variable of automatic storage class. Demonstration of  Automatic storage class # include < stdio.h > void   myFunc (); int   main () {     auto  int   x   =   5 ;      printf ( " %d " , x ) ;      myFunc () ;      return   0 ; } void   myFunc () { int x;  

What is Structure and why do we need them in C

 In one of our previous post we dealt with Array .Here in this post we'll be dealing with structure which  I prefer to call 'The advanced version of arrays'. Structure Similar to an array, A structure is a collection, however of a dissimilar data types. Take an example of an office, Where the Manager wants to keep  the records of his/her employees.The record may include employees' name, address, department, pay scale , age and so on.So, why not create a variable with all those features in it. So when we want an entity with multiple features in it we can go with structures. First Glance of Structure struct   student {      int   rollNo , intake Year;      char   name [ 20 ], address [ 20 ]; }; Above is a structure student with some of the features of the student like:Roll number, intake year, their name and address. The keyword struct is used to define a structure. Structure definition always ends with a semicolon. The general form of Structure definition is struct   <

Working with String Handling Functions in C

 C provides large set of string handling library function under string.h header. Few of them are discussed below. Strlen This function returns the length of the given string which is an integer value. Syntax strlen (name_of_array); The actual parameter for the function is the address of the first character of the array. Usage # include < stdio.h > # include < string.h > int   main () { char   name [] = " Abhilekh " ; printf ( " length is  %d " , strlen ( name )) ; return   0 ; } The output is: The  length  of the string is  8 Strcpy It should be noted that a string cannot be assigned to another string using a assignment operator(=). This is where we use this library function. It copies one string to another. Syntax strcpy (string1,string2); It copies the string from string2 to string1. Usage # include < stdio.h > # include < string.h > int   main () {   char   name [] = " Abhilekh " ;   char   copyName [ 8 ];   strcpy ( copyName , n

What is Operator Overloading in c++

  Who doesnot love syntactic sugar ? After all they make our code look more beautiful. So let us discuss how to  overload operators in C++ How to Overload Operators in C++ What if I tell you ,You can use most of the operator in C++ not only with built in type but with the  type you defined yourself (Classes are user defined type) .Yes you got it right , operator overloading lets you define the meaning of  an operator when used to operands of user defined type(classes) Overloaded operator are nothing else than a function (however a special one) with a special keyword operator followed by the symbol for the operator to be overloaded. As I already mentioned that overloaded opeartors are a function so they definetly have a return type,parameter(s) and a body. It should look something like this: returnType operator Symbol(){} As an example:   int   operator  +(){ // body } Let us now overload   plus operator (+) for our class . 1.# include < iostream > 2.using   namespace  std; 3. 4

What is Dynamic Memory Allocation in C

Under stdlib header C provides us 4 four special function which helps in allocating memory dynamically and freeing it. malloc() calloc() realloc() free() The first three function's are used in allocation of memory while the last one frees the allocated memory. The Malloc function Syntax malloc ( number_of_bytes ); The malloc function  allocates contiguous memory location for the required   number_of_bytes, returns a void pointer pointing to the base address of that allocated memory. A malloc returns a void pointer,why?because malloc does not know for what we allocated the memory ( malloc does not know whether we are allocating memory for ints , floats or chars ). Usage example int   * a = ( int * )  malloc (5 *sizeof ( int )); The (int*) is done for typecasting, it converts the void pointer returned by malloc function to a integer pointer (int*) . We are then assigning the returned(and type casted) pointer to a integer point a. So a is now pointing to the base address of allocated