Reputation: 7844
I was revisiting pointers when I had this doubt.
int *ptr;
int arr[5] = {10,20,30,40,50};
ptr = &arr[0];
Now printf("Value: %d",*ptr);
would print 10
if I do:
ptr++;
printf("Value: %d",*ptr);
the result would be: 20
Similarly if I do:
*ptr++;
printf("Value: %d",*ptr);
the result is: 30
But
printf("Value: %d",++*ptr);
gives me 31
I thought since ptr
is of type int
when I increment it, it would jump 4 bytes to the next memory location. But why does it show the same behavior for *ptr++
and ptr++
and not for ++*ptr
?
Upvotes: 0
Views: 14600
Reputation:
The trick to this is that whenever both are unary operators, then associativity is from right to left.
*ptr++ --> first increment pointer to next location and then dereference the value at that location.
Similarly *++ptr -->first increment pointer and then dereference.
++*ptr --> first dereference value at ptr and then increment the value.
Upvotes: 1
Reputation: 172
The order of C Precedence from high priority:
()
++
* & for pointers
* /
+ -
so,
*ptr++ equivlant to *(ptr++)
++*ptr equivlant to ++(*ptr)
and for this line *ptr++; it will only increment the ptr pointer.
Upvotes: 1
Reputation: 612
When you do * ptr++
, you are actually doing * (ptr++)
, so the pointer get incremented, not the variable it points to
When ++ *ptr
, it's actually ++(* ptr)
, so it increments the value returned by the pointer
Upvotes: 3
Reputation: 126927
The first snippet is obvious: it prints what ptr
points to, i.e. 10.
The second one, moves the pointer forward of one element, which then points to the next element, i.e. 20.
The third snippet is exactly the same as the previous one, because its first instruction increments the pointer and returns the unincremented value, which is dereferenced, but its result is discarded; what is dereferenced in the printf
is the incremented pointer, which now points to 30.
The last snippet is different: ++*ptr
is ++(*ptr)
; *ptr
dereferences ptr
(which already points to 30
), yielding 30, and ++
increments such value, which becomes 31.
Upvotes: 2
Reputation: 272707
Because of precedence.
*ptr++
is the same as *(ptr++)
, the pointer is incremented, but its previous value is dereferenced.ptr++
is the same as, well, ptr++
.++*ptr
is the same as ++(*ptr)
, i.e. it increments the thing being pointed to, not the pointer.Upvotes: 8