I have a struct str *s
;
Let var
be a variable in s
. Is &s->var
equal to &(s->var)
?
Behavior-wise, yes they are equivalent since the member access -> operator has a higher precedence than the address-of & operator.
Readibility-wise, the second one &(s->var)
is much more readable than &s->var
and should be preferred over the first form. With the second form, &(s->var)
, you won't have to second-guess what it's actually doing as you know the expression in the parentheses are always evaluated first. When in doubt, use parentheses.
Yes.
(-> is higher precedence than &. See http://cppreference.com/wiki/language/operator_precedence)