Logic differences in C and Java
Compile and run this code in C
#include <stdio.h>
int main()
{
int a[] = {10, 20, 30, 40, 50};
int index = 2;
int i;
a[index++] = index = index + 2;
for(i = 0; i <= 4; i++)
printf("%d\n", a[i]);
}
Output : 10 20 4 40 50
Now fo开发者_StackOverflowr the same logic in Java
class Check
{
public static void main(String[] ar)
{
int a[] = {10, 20, 30, 40, 50};
int index = 2;
a[index++] = index = index + 2;
for(int i = 0; i <= 4; i++)
System.out.println(a[i]);
}
}
Output : 10 20 5 40 50
Why is there output difference in both languages, output is understandable for Java
but I cannot understand output in C
One more thing, if we apply the prefix ++
operator, we get the same result in both languages, why?
That is because a[index++] = index = index + 2;
invokes Undefined Behavior in C.
Have a look at this
From the link:
..the second sentence says: if an object is written to within a full expression, any and all accesses to it within the same expression must be directly involved in the computation of the value to be written. This rule effectively constrains legal expressions to those in which the accesses demonstrably precede the modification. For example, the old standby i = i + 1 is allowed, because the access of i is used to determine i's final value. The example
a[i] = i++
is disallowed because one of the accesses of i (the one in a[i]) has nothing to do with the value which ends up being stored in i (which happens over in i++), and so there's no good way to define--either for our understanding or the compiler's--whether the access should take place before or after the incremented value is stored. Since there's no good way to define it, the Standard declares that it is undefined, and that portable programs simply must not use such constructs. Similar to
a[i++]=i
(which invokes UB) your expression too invokes UB.
Your expression also has a similar behavior.
The behavior is well defined in Java
.
精彩评论