Is Dalvik's memory model the same as Java's? I am particularly interested in whether reads and writes of reference and non-long
/non-double
primitive variables are atomic, but I would also like to know whether there are any differences between the two platforms' memory models.
As of 4.0 (Ice Cream Sandwich), Dalvik's behavior should match up with JSR-133 (the Java Memory Model).
As of 3.0 (Honeycomb), most of the pieces were in place, but some minor things had been overlooked that would be difficult to encounter in practice (e.g. some edge cases in finalization).
As of 2.3 (Gingerbread), Dalvik was generally correct on uniprocessors, but some key features required for proper behavior on SMP hardware (e.g. proper final
field handling) was missing.
Pre-Gingerbread, there were no memory barriers at all, and basic stuff like volatile long
was broken.
There is a document in the Dalvik source which says:
From the point of view of a piece of code written in the Java programming language or targeted in the same way to .class files, the Dalvik VM aims to behave in a way that is fully consistent with the language's definition. That is, the code running in Dalvik will behave the same as it would have running in any other virtual machine.
Which should mean that the behaviour is the same as in proper Java. Whether it actually is or not, i have no idea.
The specification says that all operations on 32 bit numbers (the non-double, non-long numbers) are atomic. There is no guarantee that operations on 64 bit numbers are atomic as well.
© 2022 - 2024 — McMap. All rights reserved.