1、面试的时候问这个问题:

在ListView 的item小程序。很多不同的显示风格。或者是,为了更好地维护,不同的样式,应该怎么做?

我一下就想到的是工厂的模式,利用project,编写ViewFactory,方法中有getView()的方法,以后须要时。加入对应的參数,并编写不同的实现类。也就是不相同式的视图。

可是这种答案,似乎没有让面试官惬意;

他的意思是。书写不同的Adapter ,通过适配器中的getView()获取不同的View,即:一个样式的视图,相应一个Adapter。即在listView中一个Adapter,这个Adapter中拥有非常多不相同式的Adapter。这样初始化,编写的时候,listView的Adapter就不须要改动了,这样仅仅须要,加入以后须要的那个视图样式的adapter 就能够了。

回想设计模式的时候。突然想到这种问题,便写了下来,

想到的是,事实上面试的时候,我这种回答是能够解决这个问题的,仅仅是曾经学的时候,没有考虑到简单工厂模式的缺点。

如今须要学习的就是这个了;

言归正传

Android设计模式--简单工厂模式

1、 定义:

属于创建型模式。又叫做静态工厂方法(Static Factory Method)模式,但不属于23种GOF设计模式之中的一个。

2、实质:

实质是由一个工厂类依据传入的參数,动态决定应该创建哪一个产品类;

3、 工厂角色:

这是简单工厂模式的核心。由它负责创建全部的类的内部逻辑。

4、长处:

不必管这些对象到底怎样创建及怎样组织的.明白了各自的职责和权利,有利于整个软件体系结构的优化。

5、缺点:

5.1、工厂类所能创建的类仅仅能是事先考虑到的。假设须要加入新的类,则就须要改变工厂类了;

5.2、工厂类集中了全部实例的创建逻,当对象越来越多时,工厂类对系统的维护和扩展很不利。

5.3、简单工厂模式违背了“开放封闭原则”,就是违背了“系统对扩展开放,对改动关闭”的原则,违反了高内聚责任分配原则;

5.4、当须要加入产品类时,工厂类内部的逻辑须要修改非常多非常多;

6、虽然面试也是失败了。可是学习还是不能停啊,

写了一个简单的demo:

接口类:

package com.example.demo.SimpleFactory;
/**
* 统一的彩票接口
* @author qubian
* @data 2015年6月4日
* @email naibbian@163.com
*
*/
public interface Lottery { public String getLotteryName();
}

详细的实现:

package com.example.demo.SimpleFactory;
/**
* 双色球 处理
*
* @author qubian
* @data 2015年6月4日
* @email naibbian@163.com
*
*/
public class SSQLottery implements Lottery{ @Override
public String getLotteryName() { return "双色球";
} }
package com.example.demo.SimpleFactory;

/**
* 大乐透处理
* @author qubian
* @data 2015年6月4日
* @email naibbian@163.com
*
*/
public class DLTLottery implements Lottery{ @Override
public String getLotteryName() { return "大乐透";
} }

核心工厂类:

package com.example.demo.SimpleFactory;

/**
* 彩票彩种工厂处理
* @author qubian
* @data 2015年6月4日
* @email naibbian@163.com
*
*/
public class LotteryFactory { public enum LotteryEnum {
SSQ, DLT, QLC,FC3D,FJ115;
}
private static Lottery lottery =null; public static Lottery getLottery(LotteryEnum e)
{
if (e ==LotteryEnum.SSQ) {
lottery= new SSQLottery();
}else if (e ==LotteryEnum.SSQ) {
lottery= new DLTLottery();
}
return lottery;
} public static String getLotteryName(LotteryEnum e)
{ return getLottery(e).getLotteryName();
} }

使用:

package com.example.demo.SimpleFactory;

import com.example.demo.SimpleFactory.LotteryFactory.LotteryEnum;
import android.util.Log;
/**
* 使用
* @author qubian
* @data 2015年6月4日
* @email naibbian@163.com
*
*/
public class UseSimpleFactory {
private static final String TAG="UseSimpleFactory";
public void use()
{
Log.i(TAG, LotteryFactory.getLotteryName(LotteryEnum.SSQ));
}
}

当然。简单工厂在Android 源代码中有典型的运用:BitmapFactory

public class BitmapFactory {
private static final int DECODE_BUFFER_SIZE = 16 * 1024; public static class Options {
/**
* Create a default Options object, which if left unchanged will give
* the same result from the decoder as if null were passed.
*/
public Options() {
inDither = false;
inScaled = true;
inPremultiplied = true;
}
/**
* Decode a file path into a bitmap. If the specified file name is null,
* or cannot be decoded into a bitmap, the function returns null.
*
* @param pathName complete path name for the file to be decoded.
* @param opts null-ok; Options that control downsampling and whether the
* image should be completely decoded, or just is size returned.
* @return The decoded bitmap, or null if the image data could not be
* decoded, or, if opts is non-null, if opts requested only the
* size be returned (in opts.outWidth and opts.outHeight)
*/
public static Bitmap decodeFile(String pathName, Options opts) {
Bitmap bm = null;
InputStream stream = null;
try {
stream = new FileInputStream(pathName);
bm = decodeStream(stream, null, opts);
} catch (Exception e) {
/* do nothing.
If the exception happened on open, bm will be null.
*/
Log.e("BitmapFactory", "Unable to decode stream: " + e);
} finally {
if (stream != null) {
try {
stream.close();
} catch (IOException e) {
// do nothing here
}
}
}
return bm;
}
/**
* Decode a file path into a bitmap. If the specified file name is null,
* or cannot be decoded into a bitmap, the function returns null.
*
* @param pathName complete path name for the file to be decoded.
* @return the resulting decoded bitmap, or null if it could not be decoded.
*/
public static Bitmap decodeFile(String pathName) {
return decodeFile(pathName, null);
} /**
* Decode a new Bitmap from an InputStream. This InputStream was obtained from
* resources, which we pass to be able to scale the bitmap accordingly.
*/
public static Bitmap decodeResourceStream(Resources res, TypedValue value,
InputStream is, Rect pad, Options opts) { if (opts == null) {
opts = new Options();
} if (opts.inDensity == 0 && value != null) {
final int density = value.density;
if (density == TypedValue.DENSITY_DEFAULT) {
opts.inDensity = DisplayMetrics.DENSITY_DEFAULT;
} else if (density != TypedValue.DENSITY_NONE) {
opts.inDensity = density;
}
} if (opts.inTargetDensity == 0 && res != null) {
opts.inTargetDensity = res.getDisplayMetrics().densityDpi;
} return decodeStream(is, pad, opts);
}
/**
* Synonym for {@link #decodeResource(Resources, int, android.graphics.BitmapFactory.Options)}
* will null Options.
*
* @param res The resources object containing the image data
* @param id The resource id of the image data
* @return The decoded bitmap, or null if the image could not be decode.
*/
public static Bitmap decodeResource(Resources res, int id) {
return decodeResource(res, id, null);
} /**
* Decode an immutable bitmap from the specified byte array.
*
* @param data byte array of compressed image data
* @param offset offset into imageData for where the decoder should begin
* parsing.
* @param length the number of bytes, beginning at offset, to parse
* @param opts null-ok; Options that control downsampling and whether the
* image should be completely decoded, or just is size returned.
* @return The decoded bitmap, or null if the image data could not be
* decoded, or, if opts is non-null, if opts requested only the
* size be returned (in opts.outWidth and opts.outHeight)
*/
public static Bitmap decodeByteArray(byte[] data, int offset, int length, Options opts) {
if ((offset | length) < 0 || data.length < offset + length) {
throw new ArrayIndexOutOfBoundsException();
} Bitmap bm; Trace.traceBegin(Trace.TRACE_TAG_GRAPHICS, "decodeBitmap");
try {
bm = nativeDecodeByteArray(data, offset, length, opts); if (bm == null && opts != null && opts.inBitmap != null) {
throw new IllegalArgumentException("Problem decoding into existing bitmap");
}
setDensityFromOptions(bm, opts);
} finally {
Trace.traceEnd(Trace.TRACE_TAG_GRAPHICS);
} return bm;
}
}

Android设计模式(五岁以下儿童)--简单工厂模式的更多相关文章

  1. 学习设计模式第二十七 - GoF之外简单工厂模式

    示例代码来自<深入浅出设计模式>和<大话设计模式> 概述 简单工厂模式又被称为静态工厂模式,属于类的创建型模式.其实质是由一个工厂类根据传入的参量,动态决定应该创建出哪一个产品 ...

  2. [Python设计模式] 第1章 计算器——简单工厂模式

    github地址:https://github.com/cheesezh/python_design_patterns 写在前面的话 """ 读书的时候上过<设计模 ...

  3. Java 设计模式系列(二)简单工厂模式和工厂方法模式

    Java 设计模式系列(二)简单工厂模式和工厂方法模式 实现了创建者和调用者的分离.分为:简单工厂模式.工厂方法模式.抽象工厂模式 简单工厂模式.工厂方法模式都很简单,就不详细介绍了. 一.简单工厂 ...

  4. Javascript设计模式理论与实战:简单工厂模式

    通常我们创建对象最常规的方法就是使用new关键字调用构造函数,这会导致对象之间的依赖性.工厂模式是一种有助于消除类之间依赖性的设计模式,它使用一个方法来决定要实例化哪一个类.本文详细介绍了简单工厂模式 ...

  5. 设计模式(C#)——02简单工厂模式

    推荐阅读:  我的CSDN  我的博客园  QQ群:704621321       工厂模式主要是为创建对象提供过渡接口,以便将创建对象的具体过程屏蔽隔离起来.通俗来说,你只关心怎么用,不用关心怎么做 ...

  6. 设计模式(Java语言)- 简单工厂模式

    简单工厂模式有称为静态工厂模式,属于设计模式中的创建型模式.简单工厂模式通过对外提供一个静态方法来统一为类创建实例.简单工厂模式的目的是实现类与类之间解耦,其次是客户端不需要知道这个对象是如何被穿创建 ...

  7. 设计模式(二)——Java简单工厂模式

    简单工厂模式 案例: 披萨的项目(要便于披萨种类的扩展,要便于维护) 1)披萨的种类很多(比如 GreekPizz.CheesePizz 等) 2)披萨的制作有 prepare,bake, cut, ...

  8. PYTHON设计模式,创建型之简单工厂模式

    这个系统,感觉思路清爽,,相信多练练,多思考,就会熟悉的.. http://www.jianshu.com/p/2450b785c329 #!/usr/bin/evn python #coding:u ...

  9. PHP设计模式(一):简单工厂模式

  10. 设计模式(二)简单工厂模式(Simple Factory Pattern)

    一.引言 这个系列也是自己对设计模式的一些学习笔记,希望对一些初学设计模式的人有所帮助的,在上一个专题中介绍了单例模式,在这个专题中继续为大家介绍一个比较容易理解的模式——简单工厂模式. 二.简单工厂 ...

随机推荐

  1. Spring它不支持依赖注入static静态变量

    在springframework在,我们不能@Autowired静态变量,制作spring bean,例如,没有那么: @Autowired private static YourClass your ...

  2. 【原创】纯OO:从设计到编码写一个FlappyBird (一)

    说起来,自学计算机也有2年多的时间了,自己还没有从设计到编码,完完整整的设计一个基于面向对象的软件的经历..囧 于是,就有了这个系列.首先选用的语言是Java,没别的原因,HeadFirst设计模式是 ...

  3. 【LeetCode】Triangle 解决报告

    [称号] Given a triangle, find the minimum path sum from top to bottom. Each step you may move to adjac ...

  4. MYSQL IFNULL使用功能

    稍后的MYSQL IFNULL使用此功能的特定叙事,供大家参考学习,假设你MYSQL IFNULL条款的使用功能类别遇到似问题.最好看. MYSQL IFNULL(expr1,expr2)       ...

  5. MySQL与逻辑模块

    启动MySQL 1.初始化模块运行&&存储引擎初始化运行 2.1中运行完毕后 ---->连接管理模块接手 3.连接管理模块启动处理client连接请求的监听程序(tcp/ip 网 ...

  6. C++包括头文件&lt;&gt;和&quot;&quot;差额

    #include "book.h" #include<iostream.h> 在刚開始学习都会有这样的迷惑.有的程序用<>.有的却用"" ...

  7. 这两个成员函数inline重新virtual种类

    inlineType表示在编译时扩展功能,随着在函数调用的函数体而出替换函数调用:和vitual它是c++多态的必要条件,但为了表现出多态性,您将需要等到执行,要知道什么是真正的函数调用.从表面上看这 ...

  8. css3 shadow为了实现各种漂亮的阴影效果

    <!DOCTYPE html> <head> <meta http-equiv="Content-Type" content="text/h ...

  9. RH133读书 笔记(4) - Lab 4 System Services

    Lab 4 System Services Goal: Develop skills using system administration tools and setting up and admi ...

  10. OpenGL学习日记-2015.3.13——多实例渲染

        实例化(instancing)或者多实例渲染(instancd rendering)是一种连续运行多条同样渲染命令的方法.而且每一个命令的所产生的渲染结果都会有轻微的差异. 是一种很有效的.有 ...