- 浏览: 1847789 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (665)
- 闲话 (17)
- ruby (1)
- javascript (40)
- linux (7)
- android (22)
- 开发过程 (11)
- 哥也读读源代码 (13)
- JVM (1)
- ant (2)
- Hibernate (3)
- jboss (3)
- web service (17)
- https (4)
- java基础 (17)
- spring (7)
- servlet (3)
- 杂记 (39)
- struts2 (10)
- logback (4)
- 多线程 (2)
- 系统诊断 (9)
- UI (4)
- json (2)
- Java EE (7)
- eclipse相关 (4)
- JMS (1)
- maven (19)
- 版本管理 (7)
- sso (1)
- ci (1)
- 设计 (18)
- 戒烟 (4)
- http (9)
- 计划 (4)
- HTML5 (3)
- chrome extensions (5)
- tomcat源码阅读 (4)
- httpd (5)
- MongoDB (3)
- node (2)
最新评论
-
levin_china:
勾选了,还是找不到
用spring annotation声明的bean,当打包在jar中时,无法被扫描到 -
GGGGeek:
我用的maven-3.5.0,还没有遇到这种情况,使用jar ...
用spring annotation声明的bean,当打包在jar中时,无法被扫描到 -
GGGGeek:
受益匪浅,从组织项目结构,到技术细节,讲的很到位,只是博主不再 ...
一个多maven项目聚合的实例 -
Aaron-Joe-William:
<?xml version="1.0" ...
hibernate逆向工程 -
li272355201:
http://archive.apache.org/dist/ ...
tomcat源码阅读(一)——环境搭建
最近2周预研做得差不多了,没什么新功能点要研究,就回头再看看android in action这本书,翻翻google的文档和API,感觉进展比之前做预研的时候慢一些,现在把这两周总结到的一些东西记一记
1. 当发生ANR时,记录会保存在data/anr/traces.txt里
2. 关于LBS(Location Based Service),基于位置的服务。关键是要获得坐标信息,然后就可以根据坐标来实现各种业务。android提供了两种基本的方式来获取坐标,一种是基于GPS,一种是基于NETWORK,包括基站定位和WIFI定位。
GPS的优点是只要有GPS传感器,就可以得到坐标,得到坐标的原理有很多,包括时间差等等。GPS定位的优势是坐标比较精确,而且即使没有网络也是可以的(当然得到坐标以后的后续处理,没网络还是不行的)。缺点是当在隧道,或者室内的时候,接收不到卫星信息,就无法得到坐标。android中对应GPS定位的provider是GPS_PROVIDER
基站定位的优点是,只要在基站的覆盖范围内(换言之,手机有信号),就可以得到cell id和LAC(Location Area Code)。然后通过将cell id和LAC发送到某个系统,这个系统就可以返回位置信息。这有个条件,就是某个系统拥有位置信息。可能是运营商提供的系统(通常要收费),也可能是免费系统(比如常用的google)。这个方式的缺点是得到的坐标可能不会很精确,在一个基站覆盖范围内的任何一点,得到的都是同样的坐标,坐标的精确度取决于基站小区的覆盖密度。另外同样的cell id和LAC,发送给不同的系统,得到的坐标也有可能是不同的。
android中对应基站定位的provider是NETWORK_PROVIDER。另外,还没看过源代码,但我猜测如果用android api来做基站定位,那应该默认是把cell id和LAC发送到google服务器上,那么就必须要求能上网了。其实如果位置信息系统提供了短信网关接口,也是可以不上网的,这样就不能用android api了,而是要获取到cell id和LAC(可能还要求别的参数,根据位置信息系统提供商提供的接口决定),然后以短信方式发送到位置信息系统,也是可以的。我们这次就打算这么做
3. 关于adapter,现在理解得多了一点。有一类View叫做AdapterView,比如ListView就是AdapterView的一种。这类的View有一个setAdapter(Adapter adapter)方法,通过这个方法,来update View。
上面的listView在初始化的时候是没有数据的,也就是没有ListItem,通过setAdapter()方法,才填充了数据。
Adapter类的作用,就是根据数据源,来返回View,每个View最终会成为AdapterView的其中一个Child View。如同其名字一样,Adapter是一个数据到视图的适配器。可以将其理解为是一个容器的处理器,它将容器内的每一项,映射成一个View并返回。数据源可以是资源文件指定的数据集合,也可以来自SQLite,也可以是内存中的自定义对象……总之是一种数据对象的集合。而将要返回的View,是由Adapter中的getView()方法创建并返回的,可以来自layout文件的设置,也可以是自定义的View对象。
搞清楚原理,就明白AdapterView和Adapter是怎样协同工作,生成页面的了。Adapter根据数据源,循环调用getView()方法,生成View对象的集合。然后AdapterView.setAdapter()方法,用前面生成的View对象集合,来给视图生成数据项。ListView只是AdapterView的一个子类,还有很多其他的AdapterView,但是原理都是相同的。有空的话可以看看ListAdapter类的getView()方法的源码,应该会对这个过程理解得更清晰一些。
4. 搞清楚了上一点,再来看ListActivity,其实ListActivity只是一个普通的Activity,只是它内置了一个ListView,以及提供了getListView()方法来获取内置的ListView;还提供了setListAdapter()方法,来给这个内置的ListView设置Adapter;以及诸如onListItemClick()等方法而已。在要使用ListActivity的地方,用普通的Activity也是完全可以的,只是要多写一些方法而已。
5. 在前面的博客里提到过,关于UI Thread有2个原则。1:不要阻塞UI Thread,2:不要在UI Thread之外操作视图组件。今天补充一点,除了进一步封装的AsyncTask类之外,android主要是通过提供Handler类来支持这一点的。
通过以上的代码结构,来遵循上述的2个原则。当然,用AsyncTask来处理,代码会更加简洁一些。不过看到比较多的源代码,还是采用这种结构来做的。其他方式都不太好,或者有阻塞UI Thread,造成ANR的问题。或者是在worker Thread中操作了View组件,可能隐藏了一些多线程情况下的BUG
Handler就是android提供的,不同线程之间通信的一种方式。用无参数构造器的方式创建Handler实例,则将其绑定到当前线程(UI Thread)的Looper中。Looper是和Handler紧密相关的一个类,开发者一般不会直接操作Looper类。这个Looper内部维护一个Message Queue,会对每条Message进行处理。没有看过源码,不过我估计这个过程应该是异步的。
6. 关于Layout布局,现在我还搞得不是太清楚,也是目前最薄弱的一块,只能先简单理解一下书上说的内容。
首先每种ViewGroup都有一个内部类LayoutParams,这个LayoutParams有一个继承体系,比如ViewGroup.LayoutParams->ViewGroup.MarginLayoutParams->LinearLayout.LayoutParams->TableLayout.LayoutParams
然后貌似每个组件的最终Layout是由其Parent决定的,而其自身的Layout又决定了它的Child的Layout布局,这是一个递归的过程。
A child View requests a size, and the parent makes a decision on how to position the child view on the screen. The child makes a request and the parent makes the decision. Child elements do keep track of what size they're initially asked to be, in case layout is recalculated when things are added or removed, but they can't force a particular size. Because of this, View elements have two sets of dimensions: the size and width they want to take up [getMeasuredWidth()] and the actual size they end up after a parent's decision [getWidth()].
暂时就知道这么多,以后再补充一点。我个人感觉这是android中比较难的一部分,可能是以前我没做过swing的开发,所以不太好类比。android布局和我熟悉的html+css布局差别还是挺大的
7. View组件还有一个focus的概念。即虽然页面上有很多组件,但同时只能有一个组件获取到焦点,来响应用户输入。用户的操作,可能导致焦点的改变。这点和html一样,很好理解。通常“下一焦点”是由android系统决定的,但是开发者也可以通过在XML中设置nextFocusDown等属性,来改变默认行为。另外View也有requestFocus()方法,来请求获取焦点。类似jquery中的$(element).focus()
8. android中的事件响应机制类似设计模式中的“观察者模式”,一个事件分2个阶段:the component raising the event and the component(or components) that respond to the event. 前者类似Button.setOnClickListener(OnClickListener listener),后者类似listener.onClick(View v)。这里要再次重申一下,由于View接口是单线程的,所以无论何时,要记得只能在UI Thread中调用View上的方法(包括更新View)
9. 程序中用到的资源,统一放在res文件夹下,res文件夹下的子目录是有命名规范的,乱命名就认不出来(也就是,无法编译,然后通过R.java来引用)。比如res/drawable下放图片,res/layout下放布局XML,res/values下放strings、colors、styles、arrays等,具体的可以看google的API文档。然后这些资源文件会由aapt工具编译成binary,之后程序中就可以通过R Class来获取这些编译后的资源
10. Resources类是所有资源的统一入口,提供了如getStringArray(int),openRawResource(int),getXml(int)等方法
1. 当发生ANR时,记录会保存在data/anr/traces.txt里
2. 关于LBS(Location Based Service),基于位置的服务。关键是要获得坐标信息,然后就可以根据坐标来实现各种业务。android提供了两种基本的方式来获取坐标,一种是基于GPS,一种是基于NETWORK,包括基站定位和WIFI定位。
GPS的优点是只要有GPS传感器,就可以得到坐标,得到坐标的原理有很多,包括时间差等等。GPS定位的优势是坐标比较精确,而且即使没有网络也是可以的(当然得到坐标以后的后续处理,没网络还是不行的)。缺点是当在隧道,或者室内的时候,接收不到卫星信息,就无法得到坐标。android中对应GPS定位的provider是GPS_PROVIDER
基站定位的优点是,只要在基站的覆盖范围内(换言之,手机有信号),就可以得到cell id和LAC(Location Area Code)。然后通过将cell id和LAC发送到某个系统,这个系统就可以返回位置信息。这有个条件,就是某个系统拥有位置信息。可能是运营商提供的系统(通常要收费),也可能是免费系统(比如常用的google)。这个方式的缺点是得到的坐标可能不会很精确,在一个基站覆盖范围内的任何一点,得到的都是同样的坐标,坐标的精确度取决于基站小区的覆盖密度。另外同样的cell id和LAC,发送给不同的系统,得到的坐标也有可能是不同的。
android中对应基站定位的provider是NETWORK_PROVIDER。另外,还没看过源代码,但我猜测如果用android api来做基站定位,那应该默认是把cell id和LAC发送到google服务器上,那么就必须要求能上网了。其实如果位置信息系统提供了短信网关接口,也是可以不上网的,这样就不能用android api了,而是要获取到cell id和LAC(可能还要求别的参数,根据位置信息系统提供商提供的接口决定),然后以短信方式发送到位置信息系统,也是可以的。我们这次就打算这么做
3. 关于adapter,现在理解得多了一点。有一类View叫做AdapterView,比如ListView就是AdapterView的一种。这类的View有一个setAdapter(Adapter adapter)方法,通过这个方法,来update View。
ListView listView = (ListView)findViewById(R.layout.list_view); listView.setAdapter(new MyAdapter(this));
上面的listView在初始化的时候是没有数据的,也就是没有ListItem,通过setAdapter()方法,才填充了数据。
Adapter类的作用,就是根据数据源,来返回View,每个View最终会成为AdapterView的其中一个Child View。如同其名字一样,Adapter是一个数据到视图的适配器。可以将其理解为是一个容器的处理器,它将容器内的每一项,映射成一个View并返回。数据源可以是资源文件指定的数据集合,也可以来自SQLite,也可以是内存中的自定义对象……总之是一种数据对象的集合。而将要返回的View,是由Adapter中的getView()方法创建并返回的,可以来自layout文件的设置,也可以是自定义的View对象。
搞清楚原理,就明白AdapterView和Adapter是怎样协同工作,生成页面的了。Adapter根据数据源,循环调用getView()方法,生成View对象的集合。然后AdapterView.setAdapter()方法,用前面生成的View对象集合,来给视图生成数据项。ListView只是AdapterView的一个子类,还有很多其他的AdapterView,但是原理都是相同的。有空的话可以看看ListAdapter类的getView()方法的源码,应该会对这个过程理解得更清晰一些。
4. 搞清楚了上一点,再来看ListActivity,其实ListActivity只是一个普通的Activity,只是它内置了一个ListView,以及提供了getListView()方法来获取内置的ListView;还提供了setListAdapter()方法,来给这个内置的ListView设置Adapter;以及诸如onListItemClick()等方法而已。在要使用ListActivity的地方,用普通的Activity也是完全可以的,只是要多写一些方法而已。
5. 在前面的博客里提到过,关于UI Thread有2个原则。1:不要阻塞UI Thread,2:不要在UI Thread之外操作视图组件。今天补充一点,除了进一步封装的AsyncTask类之外,android主要是通过提供Handler类来支持这一点的。
private final Handler handler = new Handler(){ public void handleMessage(Message msg){ doSomeThingWithView();// 在UI Thread中对视图组件做操作 } }; public void someMethod(){ new Thread(){ public void run(){ someLongTimeJob();// 在worker Thread中做一些耗时操作,以免阻塞UI thread handler.sendMessage();// 发送消息到UI Thread } }.start(); }
通过以上的代码结构,来遵循上述的2个原则。当然,用AsyncTask来处理,代码会更加简洁一些。不过看到比较多的源代码,还是采用这种结构来做的。其他方式都不太好,或者有阻塞UI Thread,造成ANR的问题。或者是在worker Thread中操作了View组件,可能隐藏了一些多线程情况下的BUG
Handler就是android提供的,不同线程之间通信的一种方式。用无参数构造器的方式创建Handler实例,则将其绑定到当前线程(UI Thread)的Looper中。Looper是和Handler紧密相关的一个类,开发者一般不会直接操作Looper类。这个Looper内部维护一个Message Queue,会对每条Message进行处理。没有看过源码,不过我估计这个过程应该是异步的。
6. 关于Layout布局,现在我还搞得不是太清楚,也是目前最薄弱的一块,只能先简单理解一下书上说的内容。
首先每种ViewGroup都有一个内部类LayoutParams,这个LayoutParams有一个继承体系,比如ViewGroup.LayoutParams->ViewGroup.MarginLayoutParams->LinearLayout.LayoutParams->TableLayout.LayoutParams
然后貌似每个组件的最终Layout是由其Parent决定的,而其自身的Layout又决定了它的Child的Layout布局,这是一个递归的过程。
A child View requests a size, and the parent makes a decision on how to position the child view on the screen. The child makes a request and the parent makes the decision. Child elements do keep track of what size they're initially asked to be, in case layout is recalculated when things are added or removed, but they can't force a particular size. Because of this, View elements have two sets of dimensions: the size and width they want to take up [getMeasuredWidth()] and the actual size they end up after a parent's decision [getWidth()].
暂时就知道这么多,以后再补充一点。我个人感觉这是android中比较难的一部分,可能是以前我没做过swing的开发,所以不太好类比。android布局和我熟悉的html+css布局差别还是挺大的
7. View组件还有一个focus的概念。即虽然页面上有很多组件,但同时只能有一个组件获取到焦点,来响应用户输入。用户的操作,可能导致焦点的改变。这点和html一样,很好理解。通常“下一焦点”是由android系统决定的,但是开发者也可以通过在XML中设置nextFocusDown等属性,来改变默认行为。另外View也有requestFocus()方法,来请求获取焦点。类似jquery中的$(element).focus()
8. android中的事件响应机制类似设计模式中的“观察者模式”,一个事件分2个阶段:the component raising the event and the component(or components) that respond to the event. 前者类似Button.setOnClickListener(OnClickListener listener),后者类似listener.onClick(View v)。这里要再次重申一下,由于View接口是单线程的,所以无论何时,要记得只能在UI Thread中调用View上的方法(包括更新View)
9. 程序中用到的资源,统一放在res文件夹下,res文件夹下的子目录是有命名规范的,乱命名就认不出来(也就是,无法编译,然后通过R.java来引用)。比如res/drawable下放图片,res/layout下放布局XML,res/values下放strings、colors、styles、arrays等,具体的可以看google的API文档。然后这些资源文件会由aapt工具编译成binary,之后程序中就可以通过R Class来获取这些编译后的资源
10. Resources类是所有资源的统一入口,提供了如getStringArray(int),openRawResource(int),getXml(int)等方法
发表评论
-
最近半个月开发小结
2011-12-05 22:16 13201、有一个方法,有一段 ... -
android培训文档提纲(四)
2011-11-27 23:28 12531、生命周期方法onSaveInstanceState()是在 ... -
Tasks and Back Stack
2011-11-22 23:47 1188Even though the activities may ... -
上周开发过程中几个简单问题的总结
2011-11-21 13:18 1370上周开发中组员遇到几个问题,都不是大问题,但都耽搁了一些时间。 ... -
android培训文档提纲(三)
2011-11-12 23:47 17741、Activity和Service组件是Context的子类 ... -
android的Log组件和logcat命令
2011-11-12 23:03 6336项目进入开发阶段了, ... -
android培训文档提纲(二)
2011-11-07 21:10 1672一、Each Activity can make an ... -
android培训文档提纲(一)
2011-10-23 14:05 1614最近项目快要进入开发 ... -
顶部有一排按钮,最底下还有FooterView的ListView页面
2011-08-13 15:46 3309先上效果图: 下面详细说说这个页面是怎么做出来的: 1、 ... -
实现屏幕下方展示的TAB分页
2011-08-09 23:22 2187这篇博客是参考helloandroid兄的腾讯微博应用,我整理 ... -
PendingIntent
2011-08-08 16:02 1566在开发SMS等应用时,有时调用相关的API会要求提供一个类型为 ... -
android数据持久化总结
2011-08-06 12:23 19251、 通过Context.getSharedPreferenc ... -
intent and service
2011-08-04 00:07 1427明天才开始讨论包需求 ... -
没有单元测试,怎能写代码
2011-07-25 17:56 1576项目前期的技术点预研完成了,最近开始做原型开发。 之前没有在 ... -
android process and thread
2011-07-18 16:31 1705前三周android预研中,把可能用到的技术点都识别了,并完成 ... -
android第三周小结
2011-07-18 10:16 13691. 系统自带的通讯录应用,联系人名单保存在data/data ... -
onPause()方法的特殊性
2011-07-15 17:11 2939onPause(), onStop(), onDestroy( ... -
activity存在的三种状态
2011-07-15 16:44 1784An activity can exist in essent ... -
android第二周小结
2011-07-14 10:50 11681. 做了短信侦听的Broadca ... -
android一周小结
2011-07-04 21:26 1240做了一周android预研,总结以下几条: 1. 用DDMS ...
相关推荐
1.通过本课程设计的实践及其前后的准备与总结,复习、领会、巩固和运用课堂上所学的Android手机应用开发知识。 2.为学生综合应用本专业所学习的多门课程知识(例如,软件工程、数据库、Java语言、Java Web开发等)...
### 总结 本流程详细介绍了腾讯手机游戏Android游戏上线的具体步骤,从最初的提交审核到最终的线上发布及收入结算,每一步都至关重要。开发者需要密切关注各个环节的要求和反馈,确保游戏能够在腾讯平台顺利上线并...
总结起来,在这两周的学习中,你将: 1. 掌握React组件化开发思想和React-Native的基础知识。 2. 熟悉JavaScript ES6语法,理解其在React开发中的应用。 3. 学习使用ESLint来提升代码质量和一致性。 4. 实践创建和...
本文档旨在记录针对“山理助手”(iSDUT ver1.0 For Android)的测试过程与结果,通过对测试过程中发现的问题进行总结与分析,为后续软件的缺陷修正和功能优化提供科学依据。 ##### 1.2 项目背景 山理助手(iSDUT)是...
总结来看,这个课题深入探讨了如何利用TC35i模块实现GSM网络下的通信功能,涉及到AT命令的使用、串口通信技术以及单片机的控制策略。通过这样的实践,学生不仅掌握了硬件知识,也深化了对无线通信协议和嵌入式系统...
君正公司能够在两周内完成Android 4.0(Ice Cream Sandwich)到基于MIPS处理器的移植工作,这在很大程度上得益于之前在Android 3.0(Honeycomb)版本移植上的经验积累。快速的操作系统适配能力是产品能够及时上市、...
1. **周期选择**:用户可以选择事件的重复周期,例如每日、每周、每两周、每月、每季度或每年。 2. **频率定制**:在某些周期内,用户还可以自定义事件发生的频率,比如每周的星期几、每月的第几个星期等。 3. **...
App开发需要针对iOS和Android两个操作系统,导致开发周期长、人力投入大,而小程序则依托于微信平台,一次开发即可适配所有机型,开发周期短、成本低。此外,小程序的上线速度远超App,通常在两周甚至更短时间内即可...
App的开发涉及iOS和Android两个平台,需要较长的周期和高昂的成本,而小程序借助微信平台,一次开发即可适配所有机型,开发周期短,成本低廉。此外,小程序的上线速度远快于App,通常可在两周内完成,甚至对于简单...
在两周的项目实践中,每个团队成员可能需要完成五个界面的开发,关键在于理解这种技术背后的原理,如内存管理、性能优化和跨语言调用的细节。同时,需要总结使用过程中遇到的问题,例如资源冲突、通信延迟等,并寻找...
作为国内知名的Android应用分发平台,应用宝在持续追求技术创新和满足用户需求的同时,面临着如何确保产品质量的挑战。为了应对这一挑战,应用宝建立了其独特的质量保证体系。本文将详细介绍这一质量保证体系的设计...
同时,为了满足不同用户群体的需求,测试团队需要准备不同操作系统版本的测试设备,如iOS、Android等,并针对特定功能进行数据支持的规划,如秒杀或优惠券使用场景。 ### 二、测试流程关键步骤 1. **UI测试**:...