http://blog.csdn.net/leehong2005/article/details/8535306

这篇文章主要内容来自于之前我讲的一个PPT文档,现在将其整理如下。欢迎指正。以下的内容都是来自于我自身的经验,欢迎大家多提自己的建议。

1、一些概念

模式的定义:

每个模式都描述了一个在我们的环境中不断出现的问题,然后描述了该问题的解决方案的核心。通过这种方式,你可以无数次地使用那些已有的解决方案,无需在重复相同的工作。

什么是设计模式?

设计模式是在某种特别的情况下,针对某种问题的某种典型、通用的解决方法。

我们是需要适当了解并学习一些设计模式,在程序开发过程中,总是会涉及到一些框架设计,模块设计之类的东西,如果能很好理解并运行设计模式,你所设计的模块或框架将会要稳定得多,因为这些设计模式它们都是通用的解决方案,是经过实践经验了的。

比如说,在程序里,可能会有通知模块,A模块的数据发生变化,B模块需要得到通知,对于这样的需要,你可能会想到用"广播","消息"或者"回调"的方式来解决,的确,刚才我所说的那三种也能解决,但是,这三种都是存在一些缺点,比如说广播,用Intent来传输数据很困难,对于"消息",无法很好的跟踪,对于"回调",有可能你A与B模块根本不可相互访问。此时,如果你会用观察者模式的问题,这种问题可以很轻松解决。

当然,这里是需要具体问题具体分析的,我主要的意思就是说,要适当利用模式,我们不能为了用模式而去用模式,我们是要用模式来解决我们实际的问题。

概念完整性

关于概念完整性,在《人月神话》一书在有大量的阐述,这里,我把我的理解写出来,与大家分享。

1)概念完整性是系统设计中最重要的考虑因素。当你的系统规模越大,这一点体现得越明显。

2)为了获取概念的完整性,设计必须由一个人或者具有共识的小型团队来完成。这一点很好理解,关于设计,可以让所有的人参与,但是决定权在少数人手里,如果大家都想参与设计,这是根本没有办法保证系统设计是统一完整的。

3)要获得概念上的完整性,就必须有人控制这些概念,类似于贵族的专制统治。这里,对于团队中的项目经理或架构师必须对项目有绝对的权威,不然,这个项目里面的就无法统一号令。

4)概念完整性表现有:

- 开发过程中,需求、设计、编码的一致性
    - 整个程序具有统一的风格,比如对话框样式,按钮风格,色调等UI元素
    - 整个程序具体统一的结构,比如不同模块访问网络,它们的调用方式一致,例如异步访问都用回调方式通知结果,相同的功能应该提取成共通模块。
    - 开发人员能很好的执行需求人员和设计人员的意图。
    - 有完整的文档,需求文档,设计文档,测试文档,处理流程的文档等。

如何保持概念完整性

- 在制度上给予保证,产品的负责人必须建立技术上的绝对权威
    - 技术负责人员(SE,SL)必须严格执行项目的需求,设计,必须深入到编码细节
    - 在不同阶段,保持与所有人员的持续沟通,鼓励开发人员提意见。
    - 让开发人员参与设计,但不决定设计
    - 通过持续的反馈和沟通来实现模块重用

2、设计之前应该做什么

2.1 共通类的设计

2.1.1 Widget设计

为什么要提供这些共通控件?

2.1.2 Adapter Items

数据驱动

下面代码示例了Adapter#getView()方法的实现,它返回BookView,BookView提供方法来接收数据,至于BookView的显示,则根据设置的数据来显示,这就是数据驱动UI。

[java] view plaincopyprint?
  1. @Override
  2. public View getView(int position, View convertView, ViewGroup parent) {
  3. if (null == convertView) {
  4. convertView = new BookView(getContext());
  5. convertView.setLayoutParameter(new AbsListView.LayoutParameter(150, 150));
  6. }
  7. Book book = m_bookList.get(position);
  8. BookView bookView = (BookView)convertView;
  9. bookView.setBook(book);
  10. return convertView;
  11. }
@Override
public View getView(int position, View convertView, ViewGroup parent) {if (null == convertView) {convertView = new BookView(getContext());convertView.setLayoutParameter(new AbsListView.LayoutParameter(150, 150));}Book book = m_bookList.get(position);BookView bookView = (BookView)convertView;bookView.setBook(book);return convertView;
}

2.1.3 Dialog

  • 扩展于Dialog类
  • 提供Dialog关闭的事件
  • Dialog的高度随内容的变化而变化
  • 可以设置按钮的文字,可见性,字体等方法
  • 设置按钮点击事件的listener
  • 要考虑对话框的三个属性:Title, Content area, Action buttons

2.1.4 Utility

  • Log
  • DateFormat
  • Bitmap
  • Notification
  • Shared Preference
  • Environment
  • Device
  • ...

2.2 Task管理

线程只是一种机制,保证我们要完成的任务不运行在UI线程(也就是说不阻塞UI),完成的任务才是我们关注的核心,因此,我们可以通过设计,把线程封装,让使用者根本感觉不到是线程,他只用关心他要做的事情就行了。
这里,我们可以设计一种"异步链式调用"的框架,把线程进行了封装。使用都只需要这样用:

[java] view plaincopyprint?
  1. new TaskManager()
  2. .next(task1)
  3. .next(task2)
  4. .next(task3).
  5. .execute();
new TaskManager()
.next(task1)
.next(task2)
.next(task3).
.execute();

这里,task1, task2, task3是顺序执行的,举个例子:我们要访问网络,取得一个图片,使用这个TaskManager我们需要3个task,

task1:显示一个ProgressDialog。

task2:访问网络,创建bitmap。

task3:关闭对话框,显示bitmap。

这一点,可以参考CoreLib工程中的task.TaskManager类。

关于TaskManager,有以下几点需要注意:

  • 封装了线程
  • 让调用者只关注自己的业务处理
  • 保证顺序链式地执行某一个任务
  • 上一个任务的输出,作为下一个任务的输入
  • 能暂停、恢复任何一个任务

2.3 缓存设计

  • 把内存占用量大的对象存放在缓存中,如bitmap
  • 利用了LruCache类来实现
  • 利用了AsyncTask类来加载bitmap
  • 不用再手动释放bitmap内存,该操作有风险
  • 不用再关心AbsListView的scroll状态

关于缓存的更多详细细节,请参考[ 请参考CoreLib工程中的cache包 ]。

这样做,有什么好处, 不用再手动释放bitmap内在,该操作有风险,因为该bitmap是否有View引用,如果当一个View在试图绘制一个已经回收的bitmap,这里会抛出异常。

2.4 线程管理

无消息循环的线程:

[java] view plaincopyprint?
  1. new Thread(null, new Runnable() {
  2. public void run() {
  3. // Do you works.
  4. }
  5. }, "Thread_name_xxx").start();
new Thread(null, new Runnable() {public void run() {// Do you works.}}, "Thread_name_xxx").start();

什么情况下使用这种线程:

  • 做完一件事情就结束,这件事发生频率不高,比如从SD card中读取图片数据
  • 不需要复用线程

在使用线程,最好给线程加上名字,这样利用高度与跟踪。

有消息循环的线程:

这样的线程拥有消息循环,当消息队列中没有消息时,这个线程会被挂起。我们要做一件事情时,只需要给它发送一个消息就行了。

这种情况通常是为了复用线程,不用频繁创建线程,比如音乐播放器程序,专门启动一个有消息循环的线程来获得音乐的专辑图片。

我们通常还要创建一个与这个线程的消息循环(Looper)相关联的Handler,由它来处理消息,注意,这做的事情是运行在后台线程的。

3,程序框架如何设计

Android程序的结构

  • UI层

    • 数据展示与管理
    • 用户交互
    • 绘制
    • Adapter
  • 业务逻辑层
    • 持久化数据(内存中,相当于全局数据)
    • 数据加式(数据层的数据有时候需要进行加工成UI层需要的数据)
    • 数据变化的通知机制
  • 数据层
    • 数据访问(DB,文件,网络等)
    • 缓存(图片,文件等)
    • 配置文件(shared perference)

下面,我试着画了一个Android程序的结构,如果有不好的地方,欢迎指正。

4,一些基本原则

下面列出一些通常的原则,我们应当在开发过程中遵循,欢迎补充与指正。

4.1 提供initialize()方法

在Activity.onCreate()或者View的构造方法中调用,在以后看代码时,人们通常首先会去找initialize()这样的方法。

4.2 封装点击事件

把View的点击事件,提成方法,这样在listener处只是一个方法调用者,一般的事件封装为:onXXXClick(View v)。

4.3 设计一个BaseActivity类

让所有的Activity都继承自BaseActivity类,这样,我们可以做很多有用的事情

4.4 设计Application类

4.5 异常处理

4.6 标注的使用

4.7 注册与反注册

4.8 封装Bitmap操作

我们应当把Bitmap操作封装起来,比如从文件加载,保存,网络下载,动态计算sample size等。有了封装后,我们可以对其集中优化。

4.9 绘制处理

一定要注意绘制方面的东西,不要在onDraw()/onTouchEvent()中创建新对象。

Android 程序框架设计相关推荐

  1. Android程序框架设计

    1.一些概念 模式的定义: 每个模式都描述了一个在我们的环境中不断出现的问题,然后描述了该问题的解决方案的核心.通过这种方式,你可以无数次地使用那些已有的解决方案,无需在重复相同的工作. 什么是设计模 ...

  2. Android通用框架设计与完整电商APP开发系列文章

    作者|傅猿猿 责编|Javen205 有福利 有福利 有福利 鸣谢 感谢@傅猿猿 邀请写此系列文章 Android通用框架设计与完整电商APP开发 课程介绍 [[导学视频](http://szv1.m ...

  3. android怎么做ab测试工具,开发必读:网易专家解读Android ABTest 框架设计

    应用中不同的场景.设计方案,不经过测试,你永远不知道消费者会更偏好哪一种.面对随时可能变更的产品需求,开发人员如何才能在保证测试进程的同时,让工作也变得高效.省力? 本章内容,网易严选Android资 ...

  4. 基于单片机的嵌入式系统的典型的应用程序框架设计

    在单片机应用程序中,最常用.也是最简单的一种典型框架就是前后台系统,这种框架通常是由主函数里的大循环和一个或几个中断服务程序组成,本文主要讲这种典型框架设计问题. 前后台系统适用于一些程序流程简单.实 ...

  5. 百问网七天物联网课程学习笔记——程序框架设计

    以前我一直觉得只有做纯软件的程序员才需要注意程序框架的设计,上了韦东山老师的课之后才觉得做单片机的程序开发注意框架设计也是很必要的事情.要在单片机开发的过程中引入面向对象的思想,这样的代码更容易扩展, ...

  6. 2021金九银十面试讴歌系列,Android面试不可不看的经验,android网络层框架设计实战

    技术博客或者github主页没有什么内容也写到简历里.记住技术博客或者github主页这一类的,本来都属于加分项,可有可无的,但是如果你写了,面试官誓必会满怀期待地点进去看,如果这个时候呈现给他的却是 ...

  7. Android程序设计基础-设计布局之伪今日头条主界面

    一. 实验目的 (1) 掌握Andriod Studio的基本使用方法: (2) 掌握Andriod Studio中常用的控件及其使用方法: 二.实验内容 (1)使用Android Studio编写任 ...

  8. 【- Flutter Web篇 -】 FlutterUnit web版闪亮登场 ,android网络层框架设计实战

    由于我的小破站是在太慢了,使以放在gitee Page 部署,文中也会介绍部署流程. 网站是: http://toly1994328.gitee.io/flutter_web ,点击这里跳转 来一张F ...

  9. WinForm应用程序框架设计之WinAction(一:显示列表窗体)

    我们来先看看WinAction的显示列表窗体的流程: 具体代码参考:         public void InitListForm(Form listForm, object entity)    ...

最新文章

  1. 我必须得告诉大家的MySQL优化原理
  2. 用g++编译C++ 的流程示例如下
  3. tensoflow_yolov3 计算平均识别个数(平均识别数)
  4. 多表更新,用一个表更新另外一个表
  5. Linux基本操作(6)——Linux 重写rm 命令 实现回收站功能
  6. php和python-Python与PHP的一些区别
  7. 通过hsv筛选颜色 python_OpenCV-Python 光流介绍(附代码)
  8. C++并发与多线程(五)互斥量,atomic、与线程池
  9. garbor 特征 matlab,Gabor小波滤波用于纹理特征提取
  10. 怎样用python获取财经网新闻
  11. 使用BouncyCastle 实现RSA常用方法
  12. srv.exe蠕虫病毒~
  13. OpenVINO-yolov5推理代码
  14. SQL 合并两个字段的数据 或者合并时添加符号 如:括号 等
  15. Android 解析软件包时出现问题 -- Error staging apk from content URI
  16. java计算机毕业设计飞机航班信息查询系统源码+mysql数据库+系统+lw文档+部署
  17. 什么是高度塌陷 以及高度塌陷的解决办法
  18. 中国节日主题网站设计 红色建军节HTML+CSS 红色中国文化主题网站设计 HTML学生作业网页
  19. 22个值得收藏的android开源代码-UI篇,kotlin类型转换
  20. 如果要设计个分布式文件系统,该从哪些方面考虑?

热门文章

  1. excel切片器显示错误_带切片器的Excel弹出选择器工具
  2. [概率统计]—中心极限定理
  3. js 对象的解构赋值
  4. 第五章.系统安全分析与设计
  5. LVGL 8.0 lv_demo_widgets的学习
  6. gvim 二进制_GVim配置文件_vimrc
  7. 7_使用OGR模块操作矢量数据
  8. 抗混叠滤波器 - 原理
  9. 抗混叠滤波matlab实现,关于设计抗混叠滤波器的三大注意事项
  10. 计算机操作系统——LINUX的C语言编程与shell编程