1. 从系统架构到Hello World

简介: Android起源与发展:   Android操作系统最初在2003年的时候由Andy Rubin开发,主要支持手机。2005年8月由Google收购注资。2007年11月,Google与84家硬件制造商、软件开发商及电信营运商组建开放手机联盟共同研发改良Android系统。

Android起源与发展:

  Android操作系统最初在2003年的时候由Andy Rubin开发,主要支持手机。2005年8月由Google收购注资。2007年11月,Google与84家硬件制造商、软件开发商及电信营运商组建开放手机联盟共同研发改良Android系统。随后Google以Apache开源许可证的授权方式,发布了Android的源代码。第一部Android智能手机发布于2008年10月。Android逐渐扩展到平板电脑及其他领域上,如电视、数码相机、游戏机等。2011年第一季度,Android在全球的市场份额首次超过塞班系统,跃居全球第一。 2013年的第四季度,Android平台手机的全球市场份额已经达到78.1%。2013年09月24日谷歌开发的操作系统Android在迎来了5岁生日,全世界采用这款系统的设备数量已经达到10亿台。

 

 

Android的系统架构:

  主要分为四层架构和五个部分

  Linux内核层:该层主要为Android系统硬件提供了底层驱动。如显示驱动、音频驱动、照相驱动、蓝牙驱动、wifi驱动、电源管理等等。

  系统运行库层:这一层通过C/C++来提供一些特性支持。如SQLite提供数据库的支持,OpenGL|EL提供了3D绘图的支持,Webkit库提供了浏览器内核的支持等等。

  应用框架层:这一层主要提供了开发者在开发应用程序的时候可能用到的API支持。Android自带的一些核心应用也是使用这些API完成的。

  应用层:几乎所有安装在手机上的程序都属于这一层。包括手机上自带的短信、联系人功能,已经在应用商店下载的程序以及自己开发的程序。

     

 

Android的四大组件:

  Activity:所有应用程序的门面,凡是在应用中看得到的东西,都是存储在Activity中的

       Service:不可见,可以在后台默默运行。即使应用程序退出,仍然可以运行。

       BroadCast Receiver: 运行应用接收来自各个地方的消息(比如电话、短信)。也可以通过该组件向其他地方发送消息。

       Content Provider: 为应用程序之间共享数据提供了可能。

 

Hello World:

  下面就开始Android之路的第一个Hello World程序。

  环境搭建的步骤大致包括下面三步:

  1. 安装jdk

·    2. 去Android开发者官网下载绑定eclipse、SDK、SDT的开发工具。

  3. 解压完2中下载的文件之后需要点击里面的SDK Manager管理工具,进行相关其他版本的Android SDK的下载,下载的文件会自动放入SDK文件夹。

       以上三步全部弄完之后打开eclipse,会发现eclipse的工具栏中增加了Android相关的图标:

                     

   图片从左到右依次是SDK Manager 和 启动Android 模拟器的图标。我们点击第二个图标创建一个android模拟器并启动,启动之后效果如图:

          

 

  这时可以在eclipse里面打开device窗口,就可以看到正在运行的设备情况,当然也可以切换到DDMS视图,能够清楚的看到设备相关更详细的情况。

 

     说了这么多开始进行第一个Hello World的程序开发:

  直接new android application 然后一路next,到需要选择Activity类型的时候选择Blank  Activity:

  

       其实Hello World已经大功告成了。运行Android Application然后选择刚刚创建的Android模拟器作为运行设备,最终出现的运行结果界面如下:

  

       感觉有点酷!下面我们就来分析代码的构成:

  

      可以看到里面有很多目录,瞬间觉得傻眼。不过不要急,其实我们需要关注的目录就那么几个:

  首先bin、lib目录可以直接跳过,这里面一般是存放jar包的。一般来说bin目录是程序在编译时自动生成的文件以及当前程序编译好可直接安装的apk包,lib目录下一般存放引入的第三方包。

  src目录下一般使我们的源代码

  gen目录下主要有一个R.java 文件,这里面我们在项目中添加的所有资源都能在这里找到对应的ID。建议千万不要手动去修改该文件。

  assets目录,这个目录用的不多,一般用来存放需要随程序打包的文件,在程序中可以动态读取这里面的内容。如果程序中使用WebView加载本地网页的话,所有网页相关的文件也需要放入到这个目录下。

  res目录,这个目录里面的文件有点多。简单的讲就是程序中用到的所有图片、布局文件、字符串等资源文件都要在这个目录下。其实R.java中自动生成的代码就是根据这里面的资源文件生成的。当然这些资源文件也有一定的放的规律:比如图片一般放到drawable子目录下,layout子目录下一般存放布局文件,values子目录下一般存放字符串文件。

  AndroidManifest.xml:整个项目的核心配置文件。前面所讲的四大组件、应用程序权限添加、指定程序运行的最低版本和兼容版本等的配置都必须在这里面进行。

  project.properties:这个文件非常简单,只是指定的项目编译的SDK版本。

 

从AndroidManifest.xml探究android程序是如何进行关联的:

  AndroidManifest.xml文件的源码如下:

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <manifest xmlns:android="http://schemas.android.com/apk/res/android"
 3     package="com.example.helloworld"
 4     android:versionCode="1"
 5     android:versionName="1.0" >
 6 
 7     <uses-sdk
 8         android:minSdkVersion="12"
 9         android:targetSdkVersion="14" />
10 
11     <application
12         android:allowBackup="true"
13         android:icon="@drawable/ic_launcher"
14         android:label="@string/app_name"
15         android:theme="@style/AppTheme" >
16         <activity
17             android:name="com.example.helloworld.MainActivity"
18             android:label="@string/app_name" >
19             <intent-filter>
20                 <action android:name="android.intent.action.MAIN" />
21 
22                 <category android:name="android.intent.category.LAUNCHER" />
23             </intent-filter>
24         </activity>
25     </application>
26 
27 </manifest>
AndroidManifest.xml

  可以看到里面注册了一个Activity,我们找到Activity的相关代码:

 1 package com.example.helloworld;
 2 
 3 import android.os.Bundle;
 4 import android.app.Activity;
 5 import android.view.Menu;
 6 
 7 public class MainActivity extends Activity {
 8 
 9     @Override
10     protected void onCreate(Bundle savedInstanceState) {
11         super.onCreate(savedInstanceState);
12         setContentView(R.layout.activity_main);
13     }
14 
15     @Override
16     public boolean onCreateOptionsMenu(Menu menu) {
17         // Inflate the menu; this adds items to the action bar if it is present.
18         getMenuInflater().inflate(R.menu.main, menu);
19         return true;
20     }
21 
22 }
MainActivity.xml

  前面说过Activity是一切应用程序的门面,那么在程序运行的时候是如何找到首先运行那个Activiy的就取决于AndroidManifest.xml中的intent-filter标签中的两句话。

  再继续看MainActivity的代码可以发现所有Android的Activity必须继承自Activity类。Activity类中有一个onCreate方法,该方法在Activity创建的过程中必须要被执行。

在MainActivity中通过setContentView(R.layout.activity_main); 来指定该Activity显示的布局。 这个布局其实对应的是前面所讲的res/layout目录下的activity_main.xml。

该文件的源代码如下:

 1 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 2     xmlns:tools="http://schemas.android.com/tools"
 3     android:layout_width="match_parent"
 4     android:layout_height="match_parent"
 5     android:paddingBottom="@dimen/activity_vertical_margin"
 6     android:paddingLeft="@dimen/activity_horizontal_margin"
 7     android:paddingRight="@dimen/activity_horizontal_margin"
 8     android:paddingTop="@dimen/activity_vertical_margin"
 9     tools:context=".MainActivity" >
10 
11     <TextView
12         android:layout_width="wrap_content"
13         android:layout_height="wrap_content"
14         android:text="@string/hello_world" />
15 
16 </RelativeLayout>
activity_main.xml

可以看到在该布局文件中生命了一个TextView标签,这个是Android的一种显示文本的控件,其中该控件的android:text属性指定显示的文本内容。出于国际化和可服用的考虑,我们不推荐使用硬编码字符串。所以可以看到该文件中指定的控件显示值为@string/hello_world。这其实表明这个字符串来自字符串资源文件:/values/strings.xml中的hello_world:

1 <?xml version="1.0" encoding="utf-8"?>
2 <resources>
3 
4     <string name="app_name">Hello World</string>
5     <string name="action_settings">Settings</string>
6     <string name="hello_world">Hello world!</string>
7 
8 </resources>
strings.xml

其实可以发现AndroidManifest.xml 中也有对字符串资源的引用。

  好了,至此终于了解了整个程序是整样关联运行的。简单的来说必须要有AndroidManifest.xml 文件,这个文件配置了整个项目的Activity的相关信息,而Activity和该配置文件中引用到的相关资源文件,又需要在res路径下进行配置。引用的方式:如果在java文件中通过类似R.string.hello_world的形式,而在xml中则通过 @string/hello_world 的形式进行引用。最后需要说明下res目录下以drawable开头的目录的作用,这些子文件其实对应不同的分别率,目的是为了兼容更多的设备,但有时美工可能只能提供一个版本的图片,则是后全部放到drawable-hdpi目录下即可。

 

过渡到下一个学习阶段的两点小技能:

1. 感觉第一个程序运行界面有点小丑,很重要的一个原因是因为上面还有一个标题栏,其实只要在onCreate方法的setContentView方法调用之前添加一句代码就可以去掉这影响美观的标题栏:

1 @Override
2     protected void onCreate(Bundle savedInstanceState) {
3         super.onCreate(savedInstanceState);
4         requestWindowFeature(Window.FEATURE_NO_TITLE);
5         setContentView(R.layout.activity_main);
6     }
onCreate

改动之后的运行结果如下:

 

  

 

2. 启用logCat。起这个名字的绝对对tomcat有一定的钟情。不然连记日志都要用cat。Android的日志记录工具感觉使用超方便,功能巨强大。

主要日志级别如下:

verbose:对应最低级别琐碎型的日志。

其他级别的从低到高依次是:debug--->info--->warn--->error.

而android的日志使用方式简单粗暴,记录日志的方法都是静态方法,方法的名称取不同日志级别的第一个字母(刚好都不一样)。传入的参数第一个是tag,第二个是具体日志信息。eg:

Log.v("HelloWorld", "This is verbose log of MainActivity!"); 

当然android还有一个很方便的打印出改行日志处的调用堆栈信息的方法wtf(what the fAck?),这个方法感觉功能异常强大。

如果仅仅是能打印日志的话,还不能说对以后代码的调试有多少作用,不过eclipse里面可是集成了一个很牛的android日志查看神器,就是前面所说的需要打开的logCat窗口:

 

 在这里可以自定义过滤器,以及根据级别过滤等等。以后查看日志就能更加有针对性了。

 

好了,Android之路的第一步结束!

   

 

黎明前最黑暗,成功前最绝望!
相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
消息中间件 Cloud Native 架构师
|
Java 微服务 Spring
微服务,微架构[一]之springboot[helloWorld]
一、介绍:         springboot是由Pivotal团队开发,其设计目的就是尽可能的简化spring搭建框架和启动过程,或者说所有的配置都是一种开关模式配置,需要就配置不需要就可以不配置,极大的简化配置方面复杂内容,springboot目前的市场占有率非常高 二、特点:         1、快速搭建  web服务         2、无需打包war包,即可运行服务,内
2060 0
|
C++
1 游戏逻辑架构,Cocos2d-x游戏项目创建,HelloWorld项目创建,HelloWorld程序分析,(CCApplicationProtocol,CCApplication,AppDeleg
 1 游戏逻辑架构 详细介绍 A 一个导演同一时间只能运行一个场景,场景当中,可以同时加载多个层,一个层可以可载多个精灵。层中亦可以加层。 B  场景切换 sceneàaddChild(layer); layeràaddChild(sprite);
1303 0
|
12天前
|
API 数据库 开发者
构建高效可靠的微服务架构:后端开发的新范式
【4月更文挑战第8天】 随着现代软件开发的复杂性日益增加,传统的单体应用架构面临着可扩展性、维护性和敏捷性的挑战。为了解决这些问题,微服务架构应运而生,并迅速成为后端开发领域的一股清流。本文将深入探讨微服务架构的设计原则、实施策略及其带来的优势与挑战,为后端开发者提供一种全新视角,以实现更加灵活、高效和稳定的系统构建。
18 0
|
10天前
|
Kubernetes 安全 Java
构建高效微服务架构:从理论到实践
【4月更文挑战第9天】 在当今快速迭代与竞争激烈的软件市场中,微服务架构以其灵活性、可扩展性及容错性,成为众多企业转型的首选。本文将深入探讨如何从零开始构建一个高效的微服务系统,覆盖从概念理解、设计原则、技术选型到部署维护的各个阶段。通过实际案例分析与最佳实践分享,旨在为后端工程师提供一套全面的微服务构建指南,帮助读者在面对复杂系统设计时能够做出明智的决策,并提升系统的可靠性与维护效率。
|
21天前
|
存储 监控 Kubernetes
探索微服务架构下的系统监控策略
在当今软件开发领域,微服务架构因其灵活性、可扩展性和容错性而日益受到青睐。然而,这种架构的复杂性也为系统监控带来了新的挑战。本文旨在探讨在微服务环境下实现有效系统监控的策略,以及如何利用这些策略来确保系统的健壮性和性能。我们将从监控的关键指标入手,讨论分布式追踪的重要性,并分析不同的监控工具和技术如何协同工作以提供全面的系统视图。
|
21天前
|
监控 Java 开发者
构建高效微服务架构:后端开发的新范式
在数字化转型的浪潮中,微服务架构以其灵活性、可扩展性和容错性成为企业技术战略的关键组成部分。本文深入探讨了微服务的核心概念,包括其设计原则、技术栈选择以及与容器化和编排技术的融合。通过实际案例分析,展示了如何利用微服务架构提升系统性能,实现快速迭代部署,并通过服务的解耦来提高整体系统的可靠性。
|
2天前
|
机器学习/深度学习 运维 Prometheus
探索微服务架构下的系统监控策略
【4月更文挑战第18天】在当今快速迭代和持续部署盛行的软件工程实践中,微服务架构因其灵活性和可扩展性受到企业青睐。然而,随着服务的细粒度拆分和网络通信的增加,传统的监控手段已不再适用。本文将探讨在微服务环境中实施有效系统监控的策略,包括日志聚合、性能指标收集、分布式追踪以及异常检测等关键技术实践,旨在为读者提供构建稳定、可靠且易于维护的微服务系统的参考指南。
7 0
|
2天前
|
监控 持续交付 开发者
构建高效微服务架构:后端开发的新趋势
【4月更文挑战第18天】在数字化转型的浪潮中,微服务架构已成为企业提升系统灵活性、加速产品迭代的关键。此文深入探讨了构建高效微服务架构的实践方法,包括服务划分原则、容器化部署、持续集成/持续部署(CI/CD)流程以及监控与日志管理等关键技术点。通过分析具体案例,揭示了微服务在提高开发效率、降低维护成本及促进团队协作方面的显著优势。