As I mentioned in an earlier post, I have been working on both iPhone and Android platforms simultaneously. While the road has been bumpy, it has also been a lot of fun. I think I know enough of both the platforms to give my opinion on development on iPhone and Android.
Apple officially announced an iPhone SDK sometime in March 2008. The SDK contains an iPhone version of the Cocoa libraries called 'Cocoa Touch'. The SDK itself is a free download, but you will have to cough up $99.00 (registration fee for the iPhone developer program) if you want to run the apps you are developing on an iPhone. That is a lot when you compare it with Android, where you have to pay just $25.00 to be a registered Android developer.
The latest version of the SDK is a whopping 1.7 GB and contains the entire iPhone development toolchain including XCode, Interface Builder, Instruments, the simulator and APIs including Cocoa and Cocoa Touch. The SDK can be used to develop applications for both iPhone and Mac OSX. Android SDK on the other hand is a much more reasonable ~80 MB. Andorid SDK contains the Android API, the Android tool chain, Android simulator and Eclipse plugin called ADT.
Android Development Tools or ADT is an eclipse plugin that makes it really easy to create, build and debug Android applications.
One of the biggest drawbacks in developing for iPhone is that it can only be done on a Mac OS X machine. There is no support for Windows (which is good) or Linux (which is bad). Android SDK on the other hand is multi-platform and gives more or less the same user experience on all the supported platforms.
Disclaimer: I am not an Eclipse or an XCode expert and my comments are based on my experience (or lack thereof).
I love and hate developing on both platforms. There are certain great features which each one offers and there are features which both can improve on.
IDE:
XCode is definitely the winner here. It is very stable and takes up a lot less memory than Eclipse. The 'Interface Builder' is an awesome tool, but more about it later.
Not so easy on ADT/Eclipse. While not really an Android issue, using Eclipse slows down my machine. Once it was taking up more than 75% of the physical memory on my machine. I know, I don't have to use Eclipse. But being inherently lethargic and lazy, I never really bothered to figure out how each of the tools works.
I also find Eclipse 'auto-compile/let me display the squiggly line before you finish typing' feature very distracting and annoying. I am sure there is a way to disable it, but could never find it.
UI development Tools:
Getting the UI right for a mobile application is the key. It makes or breaks the app. I feel it is important to spend a good amount of the development time to get the UI right.
UI design on iPhone is very easy. and lets folks like me who are 'UI Design Challenged' an easy way out. You just drag and drop the components, connect the outlets and actions and you are done.
The UI design tool in ADT is useless. DroidDraw is definitely a better alternative but cannot match 'Interface Builder'. The recommended way for creating Android UI is through what are called 'layout files'. Layouts are XML files where you define the hierarchy for your UI. While the learning curve is very small, getting the elements to be at the right place drove me nuts!! There are attributes like 'weight', 'gravity', 'orientation' ... aaarrrrggggghhhh!!! There were times where I spent 30 mins writing the functionality but 3 hrs trying to get an element where I want it.
Debuggers and other tools:
Debuggers on both environments are pretty decent and I really have no complaints there.
The iPhone SDK also has 'Instruments', an instrumentation tools, that is extremely helpful in analyzing performance of the app.
Android SDK comes with Android Debug Bridge (adb) and Dalvik Debug Monitor Service or DDMS which provides a bunch of services like port-forwarding , screen capture on the device, thread and heap information on the device, logs, process information and some really funky features like spoofing incoming calls, location data and SMS.
I must admit that my knowledge of both Instruments and DDMS is very limited. I just understood enough of each to get out of some tight spots.
The Code:
Android is clearly the winner here. The API is really rich. There are things you can do which you cannot really dream of on iPhone (at least not without jailbreaking). The features I really like the best are Intents (Intents are very difficult to explain, but pretty simple to use/abuse and I recommend having a look a the documentation to really understand it). Android API also allows creating of background services opening up more creative avenues for the developer. iPhone API does not support background services yet and does not allow for more than one third-party app to run in the background.
Android API is in Java which means the learning curve is much less steep (for someone who knows Java). Not so easy for iPhone. iPhone API is in Objective-C which while being extremely feature rich is also very, for a lack of a better word, non-traditional. I found the syntax a bit weird at fast, but got over it very fast. Objective-C uses named arguments. For example, a Java method looks like:
This can make method names pretty long. For example:
Conclusion:
My goal here was not to do a feature by feature comparison, I neither have the experience or the expertise to do so. I feel that developing on both platforms have their own issues and I accept that some of these issues are probably because I did not take time to understand a feature or an API before using them.
Having said that, both Android and iPhone APIs make mobile development really a fun experience and I would find it very difficult to choose my favorite platform among the two.
I recommend this book for Android and this one and this one for iPhone.
Apple officially announced an iPhone SDK sometime in March 2008. The SDK contains an iPhone version of the Cocoa libraries called 'Cocoa Touch'. The SDK itself is a free download, but you will have to cough up $99.00 (registration fee for the iPhone developer program) if you want to run the apps you are developing on an iPhone. That is a lot when you compare it with Android, where you have to pay just $25.00 to be a registered Android developer.
The latest version of the SDK is a whopping 1.7 GB and contains the entire iPhone development toolchain including XCode, Interface Builder, Instruments, the simulator and APIs including Cocoa and Cocoa Touch. The SDK can be used to develop applications for both iPhone and Mac OSX. Android SDK on the other hand is a much more reasonable ~80 MB. Andorid SDK contains the Android API, the Android tool chain, Android simulator and Eclipse plugin called ADT.
Android Development Tools or ADT is an eclipse plugin that makes it really easy to create, build and debug Android applications.
One of the biggest drawbacks in developing for iPhone is that it can only be done on a Mac OS X machine. There is no support for Windows (which is good) or Linux (which is bad). Android SDK on the other hand is multi-platform and gives more or less the same user experience on all the supported platforms.
Disclaimer: I am not an Eclipse or an XCode expert and my comments are based on my experience (or lack thereof).
I love and hate developing on both platforms. There are certain great features which each one offers and there are features which both can improve on.
IDE:
XCode is definitely the winner here. It is very stable and takes up a lot less memory than Eclipse. The 'Interface Builder' is an awesome tool, but more about it later.
Not so easy on ADT/Eclipse. While not really an Android issue, using Eclipse slows down my machine. Once it was taking up more than 75% of the physical memory on my machine. I know, I don't have to use Eclipse. But being inherently lethargic and lazy, I never really bothered to figure out how each of the tools works.
I also find Eclipse 'auto-compile/let me display the squiggly line before you finish typing' feature very distracting and annoying. I am sure there is a way to disable it, but could never find it.
UI development Tools:
Getting the UI right for a mobile application is the key. It makes or breaks the app. I feel it is important to spend a good amount of the development time to get the UI right.
UI design on iPhone is very easy. and lets folks like me who are 'UI Design Challenged' an easy way out. You just drag and drop the components, connect the outlets and actions and you are done.
The UI design tool in ADT is useless. DroidDraw is definitely a better alternative but cannot match 'Interface Builder'. The recommended way for creating Android UI is through what are called 'layout files'. Layouts are XML files where you define the hierarchy for your UI. While the learning curve is very small, getting the elements to be at the right place drove me nuts!! There are attributes like 'weight', 'gravity', 'orientation' ... aaarrrrggggghhhh!!! There were times where I spent 30 mins writing the functionality but 3 hrs trying to get an element where I want it.
Debuggers and other tools:
Debuggers on both environments are pretty decent and I really have no complaints there.
The iPhone SDK also has 'Instruments', an instrumentation tools, that is extremely helpful in analyzing performance of the app.
Android SDK comes with Android Debug Bridge (adb) and Dalvik Debug Monitor Service or DDMS which provides a bunch of services like port-forwarding , screen capture on the device, thread and heap information on the device, logs, process information and some really funky features like spoofing incoming calls, location data and SMS.
I must admit that my knowledge of both Instruments and DDMS is very limited. I just understood enough of each to get out of some tight spots.
The Code:
Android is clearly the winner here. The API is really rich. There are things you can do which you cannot really dream of on iPhone (at least not without jailbreaking). The features I really like the best are Intents (Intents are very difficult to explain, but pretty simple to use/abuse and I recommend having a look a the documentation to really understand it). Android API also allows creating of background services opening up more creative avenues for the developer. iPhone API does not support background services yet and does not allow for more than one third-party app to run in the background.
Android API is in Java which means the learning curve is much less steep (for someone who knows Java). Not so easy for iPhone. iPhone API is in Objective-C which while being extremely feature rich is also very, for a lack of a better word, non-traditional. I found the syntax a bit weird at fast, but got over it very fast. Objective-C uses named arguments. For example, a Java method looks like:
someObject.someMethod(someParameter, someOtherParameter);An Obj-C method on the other hand looks like:
[someObject someMethod:someParameter withSomeOtherParaMether:someOtherParameter];
This can make method names pretty long. For example:
- (void)loadData:(NSData *)data MIMEType:(NSString *)MIMEType textEncodingName:(NSString *)textEncodingName baseURL:(NSURL *)baseURL;Memory management is another issue. Android supports garbage collection while iPhone does not. So, keep track of object allocations and releasing them when not required is a big task on iPhone.
Conclusion:
My goal here was not to do a feature by feature comparison, I neither have the experience or the expertise to do so. I feel that developing on both platforms have their own issues and I accept that some of these issues are probably because I did not take time to understand a feature or an API before using them.
Having said that, both Android and iPhone APIs make mobile development really a fun experience and I would find it very difficult to choose my favorite platform among the two.
I recommend this book for Android and this one and this one for iPhone.
1 comment:
Thanks for a nice article. I plan to start mobile development and any information on android vs. Iphone helps.
Post a Comment