What is the technical reason for ARC to be supported by iOS 4.0 and above only?
It is my understanding that it is a compiler feature, which merely inserts memory management related code automatically instead of requiring the developer to do so. From what I read the calls themselves remain the same – at least that’s what Apples Transitioning to ARC Guide implies.
As such, it should not involve features that have not been present in previous versions of iOS, and indeed ARC does work with iOS 4.0 despite having been introduced later.
I’m asking this question out of curiosity and don’t actually need to make ARC work with iOS 3.x.
It is for the same reason that automatic reference counting only supports 64-bit Snow Leopard as a minimum deployment target: ARC support requires certain features present only in a new enough version of the modern runtime. That modern runtime was introduced with iOS 4.0, so older iOS versions lack the runtime capable of handling some of the things required technically by ARC. If it were just keyed to OS versions, 32-bit Snow Leopard applications would be supported as well, but only the 64-bit runtime is the modern one there.
If you watch Apple’s presentations from WWDC 2011, particularly the “Objective-C Advancements In-Depth,” you’ll see that a number of under-the-hood improvements have been made to speed up the retain / release process, as well as things like the faster
@autoreleasepool. There’s an entire section on runtime support in the LLVM ARC specification. These improvements require more than just compiler support.We already had to use the modern runtime for features like automatic synthesis of instance variables (as explained in Apple’s documentation), so this isn’t a terrible surprise.
Even iOS 4.0 as a target lacks support for weak references, so there are clearly technical issues at play here. This isn’t just a marketing strategy to drive developers to the newer versions, as has been asserted by others.