Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Pointers with two dimensional array

Please consider the following piece of code

#include <stdio.h>
#define ROW_SIZE 2
#define COL_SIZE 2

int main()
{
   int a[ROW_SIZE][COL_SIZE]={{1,2},{3,4}};

   // Base address:Pointer to the first element a 1D array
   printf("Base address of array:%p\n",a);

   //The value at the base address: should be the address of 1st 1D array
   printf("Value at the Base address:%p\n",*a);

   return 0;
}

Output obtained:

Sample Output:
Base address of array:0xbff77434
Value at the Base address:0xbff77434

Somehow, I am failing to understand the concept of the base address of a 2D array and the value at the base address which is inturn an address to a 1D array being same. Please explain.

like image 415
Vivek Maran Avatar asked Dec 08 '22 20:12

Vivek Maran


2 Answers

Arrays aren't pointers, and in C, a multidimensional array is just an array of arrays. In many contexts, using the name of an array "decays" into a pointer to the first element of that array. That's what happens in both of your print statements. In the first case:

printf("Base address of array:%p\n",a);

a becomes a pointer to the first element of the array - that is, a pointer to the first row of your array. In your case, that means you get a pointer of type int (*)[2].

In the second case:

printf("Value at the Base address:%p\n",*a);

The same decaying happens, but then you dereference that pointer. That means you dereferenced that int (*)[2] pointer to the first row, leaving you with an array again (the first row). That array itself decays into a pointer to its first element, giving you a resulting int * pointer (to the first element of the first row).

In both cases the address is the same, since that's how the array is laid out in memory. If we said your 2D array started at address 0, it would look like this (assuming a 4 byte int type):

 Address       Value
    0            1
    4            2
    8            3
   12            4

The address of the first row and the address of the first element of the first row are both 0.

like image 191
Carl Norum Avatar answered Dec 26 '22 17:12

Carl Norum


Re-structuring the diagram in the question and consolidating the information from previous answers, I am creating the following answer.

Arrays and pointers

One dimensional array

  • Consider an array a of 4 integers as a[4]
  • Basic rule is both a and &a will point to same location.But they aren't pointing to the same type.
  • &a will point to the entire array which is an int[]. The pointer type is int(*)[]
  • a, when it decays to a pointer, will point to the first element of the array which is an int. The pointer type is int *

Two dimensional array

  • Consider an array containing two 1D arrays, with each of them having two elements ;a[2][2].
  • Since the number of dimensions increases, we have one more level of hierarchy i.e. &a,a and *a will point to same location, but they aren't pointing to the same type.
  • &a will point to the entire array which is int[][]. The pointer type is int(*)[][].
  • a, when it decays to a pointer, will point to the first element of the 2D array which is an int[]. The pointer type is int(*)[]
  • By using *a, we are de-referencing the pointer to a 1D array. Hence we will have a int * pointing to the first integer value of the 2D array.
like image 43
Vivek Maran Avatar answered Dec 26 '22 16:12

Vivek Maran