Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                

C C C C C C C: Candroid Is Under Version 2 of The Apache Software

Download as docx, pdf, or txt
Download as docx, pdf, or txt
You are on page 1of 4

ANDROID OS

to advancing open standards for mobile devices. Google released most of the Android code under the

ABSTRACT:
The Android operating system (OS) is widely used within several types of embedded & mobile platforms, including mobile phones and tablets, and the industry is exploring the ability of Android within other embedded platforms, i.e., automotive or military, that require real-time guarantees and the ability to meet deadlines as a pre-requisite for reliable operation. In this paper, we present preliminary conclusions on Androids real-time behavior based on experimental measurements performed on a commercially available Android platform. Apache license, a free-software and open source license.

3. ANDROID VERSIONS:
Android version has been developed under a codename based on a dessert item. These versions have released in alphabetical order. y Beta. y Android 1.0. y Android 1.1. y 1.5 Cupcake. y 1.6 Donut. y 2.0/2.1 Eclair. y 2.2. X Froyo. y 2.3. X Gingerbread. y 3. X Honeycomb. y 4. X Ice Cream Sandwich.

KEYWORDS:
Android, Android versions, Openhandset alliance, License, Platform, Software stack, Network connectivity, Security, Security architecture, Performance, Software development, Programming language, Advantages of android os, Features of android os.

1. INTRODUCTION: 4. OPEN HANDSET ALLIANCE:


Android is a new open source software toolkit for mobile phones that was created by Google and the Open Handset Alliance. In a few years, its expected to be found in millions of cell phones and other mobile devices, making Android a major platform for application developers. Open Handset Alliance, is a consortium of several companies which include Google, HTC, Intel, Motorola, Qualcomm, T-Mobile, Sprint Nextel and NVIDIA.These companies which aim to develop technologies that will significantly lower the cost of developing and distributing mobile devices and services. The Android platform is the first step in this direction -- a fully integrated mobile "software stack" that consists of an operating system, middleware, user-friendly interface and applications.

2. ANDROID:
Android is a software platform and operating system for mobile devices, based on the Linux kernel, and developed by Google and later the Open Handset Alliance. It allows developers to write managed code in the Java language, controlling the device via Google-developed Java libraries. Applications written in C and other languages can be compiled to ARM native code and run, but this development path is not officially supported by Google. The unveiling of the Android platform on 5 November 2007 was announced with the founding of the Open Handset Alliance, a consortium of 48 hardware, software, and telecom companies devoted

5. LICENSE:
Android is under version 2 of the Apache Software License (ASL). The Apache license allows manufacturers and mobile operators to innovate using the platform without the requirement to contribute those innovations back to the open source community.

6. PLATFORM: 6.1 HARDWARE:


First and foremost, android is a software stack for mobile devices. This means that high on the list of priorities is the preservation of battery power and the efficient management of limited memory resources. There are five distinct layers to the Android system stack:

Android applications are written in the Java programming language, and you can download many more from the Android market on the fly.

6.2 SOFTWARE STACK:


High on the list of priorities is the preservation of battery power and the efficient management of limited memory resources.

The Acorn RISC Machine (ARM) Linux core forms the solid base upon which all the other layers stand. Linux is a proven technology that is highly reliable, and the ARM processor family is known for high performance on very low power requirements. The libraries provide the reusable and sharable low-level code for basic functions such as codecs software for coding and decoding digital sound and video functions for the presentation of rich graphics on a small displays, secure shell support for encrypted TCP/IP traffic into the cloud, as well as component support for Web browsing (WebKit), SQL database functionality (SQLite), and standard C library functionality you would expect in a Linux system. The Dalvik run-time byte-code interpreter, which strongly resembles the Java language byte-code interpreter, adds a few distinct features that uniquely define the security and power-preserving model of Android. Every application currently running, for example, has its own user ID and its own copy of the interpreter running to strictly separate processes for security and reliability. The Android application framework enables you to use and replace components as you see fit. These high-level Java classes are tightly integrated components that define the Android API. The Android core applications include the WebKit browser, Google calendar, Gmail, Maps application, SMS messenger, and a standard e-mail client, among others.

Fig.1 Android Architecture Android uses Linux for its device drivers, memory management, process management, and networking. However you will never be programming to this layer directly. The next level up contains the Android native libraries. They are all written in C/C++ internally, but youll be calling them through Java interfaces. In this layer you can find the Surface Manager (for compositing windows), 2D and 3D graphics, Media codecs (MPEG-4, H.264, MP3, etc.), the SQL database (SQLite), and a native web browser engine (WebKit). Next is the Android runtime, including the Dalvik Virtual Machine. Dalvik runs dex files, which are converted at compile time from standard class and jar files. Dex files are more compact and efficient than class files, an important consideration for the limited memory and battery powered devices that Android targets. The core Java libraries are also part of the Android runtime. They are written in Java, as is everything above this layer. Here, Android provides a substantial subset of the Java 5 Standard Edition packages, including Collections, I/O, and so forth.

The next level up is the Application Framework layer. Parts of this toolkit are provided by Google, and parts are extensions or services that you write. The most important component of the framework is the Activity Manager, which manages the life cycle of applications and a common back-stack for user navigation. Finally, the top layer is the Applications layer. Most of your code will live here, along side built-in applications such as the Phone and Web Browser

statically in that application, so they can be known up-front at install time and will not change after that.

9. PERFORMANCE:
Devices hosting Android applications have limited capabilities. That's why code should be efficient, avoid all unnecessary memory allocations, method calls (it takes a lot of time) and so on. In order to make our applications working fast on a mobile device we need to leave back some habits, good from OOP point of view.

7. NETWORK CONNECTIVITY:
It supports wireless communications using: y y y y GSM mobile-phone technology 3G Edge 802.11 Wi-Fi networks

9.1 Avoid object instantiation - create objects


only if it is really necessary, because it costs time and memory. More instances means more-frequent garbage collection what lowers user-experience (freezes).

9.2 Use native built-in methods - they're written


in C/C++ what makes them faster about 10-100 times than implemented JAVA code (loops etc.). However note that calling native method is more expensive then calling implemented one.

8. SECURITY:
Android is a multi-process system, in which each application (and parts of the system) runs in its own process. Most security between applications and the system is enforced at the process level through standard Linux facilities, such as user and group IDs that are assigned to applications. Additional finergrained security features are provided through a "permission" mechanism that enforces restrictions on the specific operations that a particular process can perform, and per-URI permissions for granting adhoc access to specific pieces of data.

9.3 Virtual over interface - in conventional


programming it is usual to declare variables as interfaces, i.e.: Map myMap1 = new HashMap(); It is not good for embedded applications. Calling a method from interfaces takes 2 times more time than in normal way: HashMap myMap2 = new HashMap();

9.4 Static over virtual - declare methods static if


they do not need access to the object's fields. It can be called faster, because it doesn't require a virtual method table indirection. It's also good practice, because you can tell from the method signature that calling the method can't alter the object's state.

8.1 SECURITY ARCHITECTURE:


A central design point of the Android security architecture is that no application, by default, has permission to perform any operations that would adversely impact other applications, the operating system, or the user. This includes reading or writing the user's private data (such as contacts or e-mails), reading or writing another application's files, performing network access, keeping the device awake, etc. An application's process is a secure sandbox. It can't disrupt other applications, except by explicitly declaring the permissions it needs for additional capabilities not provided by the basic sandbox. These permissions it requests can be handled by the operating in various ways, typically by automatically allowing or disallowing based on certificates or by prompting the user. The permissions required by an application are declared

9.5 Cache field lookups, because accessing object


fields is lower than local variables. The same situation is with methods - i.e. by for-statements, you should cache size () method if it is possible.

10. SOFTWARE DEVELOPMENT:


10.1 DEVELOPMENT REQUIREMENTS:
Developing an application on the Android platform requires the following: y Knowledge of programming in Java.

y y y

Knowledge of recommended).

XML

(optional

but

provide users with any information they might be in need of. y This information could include knowing the location of a nearby convenience store or filling station. In addition the entertainment functionalities will be taken a notch higher by Google Android being able to offer online real time multiplayer games.

Android SDK (requires x86 OS like Windows, Linux, Mac; JDK version >=5). Eclipse IDE (at least version 3.3) with Android Development Tools (ADT) plug-in (optional but recommended). Android powered Smartphone (optional for testing purposes).

13. FEATURES OF ANDROID OS: 11. PROGRAMMING LANGUAGE:


The officially supported programming language on the Android platform is Java. It is also recommended to have some knowledge of XML as the descriptor file as well as the user interface of an application is based on that. As the Linux kernel of the Android platform is based upon an ARM processor architecture it would also be possible to write code in C or other languages and compile it to ARM native code. y y y y RISC Machine. Libraries provide the reusable and sharable low-level code. Dalvik run-time byte-code interpreter. Android core applications.

CONCLUSION:
Android has been criticized for not being all opensource software despite what was announced by Google. Parts of the SDK are proprietary and closed source, and some believe this is so that Google can control the platform. Software installed by end-users must be written in Java, and will not have access to lower level device APIs. This provides end-users with less control over their phone's functionality than other free and open source phone platforms. With all upcoming applications and mobile services Google Android is stepping into the next level of Mobile Internet. Android participates in many of the successful open source projects. That is, architect the solution for participation and the developers will not only come but will play well together. This is notable contrast with Apple and other companies, where such architecture of participation is clearly belated. We can only hope that the next versions of Android have overcome the actual limitations and that the future possibilities became a reality.

12. ADVANTAGES OF ANDROID OS:


There are a host of advantages that Googles Android will derive from being an open source software. Some of the advantages include: y The ability for anyone to customize the Google Android platform will open up the applications playing field to small and new players who lack the financial muscle to negotiate with wireless carriers like AT&T and Orange. The consumer will benefit from having a wide range of mobile applications to choose from since the monopoly will be broken by Google Android. Although this will depend on the carrier, one will be able to customize a mobile phones using Google Android platform like never before, right down to the screen. Features like weather details, opening screen, live RSS feeds and even the icons on the opening screen will be able to be customized. In addition, as a result of many mobile phones carrying Google Android, companies will come up with such innovative products like the location aware services that will

REFERENCES:
1. http://www.android.com - Android Official Webpage 2. http://code.google.com/android/ - Official Android Google Code Webpage 3. http://www.openhandsetalliance.com/ - Open Handset Alliance Webpage 4. http://www.androidwiki.com/Android Wiki 5. http://en.wikipedia.org/wiki/WebKit 6.http://en.wikipedia.org/wiki/Android

You might also like