首页 | 新闻 | 新品 | 文库 | 方案 | 视频 | 下载 | 商城 | 开发板 | 数据中心 | 座谈新版 | 培训 | 工具 | 博客 | 论坛 | 百科 | GEC | 活动 | 主题月 | 电子展
返回列表 回复 发帖

Factory 模式的优点

Factory 模式的优点

望文生义对于构造函数来讲, 其名字必须和所属的类名一致. 这就往往失去了利用函数名传递更多信息的机会. 比如说我们有一个创建XML Parser 类:
1
2
3
4
5
6
7
8
9
10
public class XMLConverter() inmplements Converter {
      //创建一个缺省的 converter, Idoc Converter
    public XMLConverter () {
    …………………………….
}
//创建一个指定的 xml parser, idoc/bapi
        public XMLConverter (String xmlConverterType) {
    ………………….
        }
}




这个XMLConverter类有两个构造函数, 第一个构造函数创建一个缺省的XML converter.第二个构造函数可根据程序员的指定来创建一个                XML conveter.为了使用这个类,我们必须先读API文档,并且我们可能很难记住这两个构造函数各自的用途.                我们下面看看如何使用Factory解决这个问题:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
public class XMLConverter () {
        public Converter getIdocConverter() {
        return new XML();
}
public static Converter getBapiConverter() {
    return new XMLConverter ("bapi");
}
      //创建一个缺省的 converter, Idoc Converter
private static Converter XMLConverter () {
    …………………………….
}
//创建一个指定的 xml parser, idoc/bapi
        private XMLConverter (String xmlParserType) {
    ………………….
        }
}




这个新的XMLConverter类有着两个get函数, 它们返回两个XMLConverter型的Object. 这就是典型的Factory 模式.                这两个get函数的名字清楚地告诉了我们它们各自的用途,我们不必查API文档就能明白它们的用途.请特别注意,两个构造函数都被标明为pivate.
可控制在一个JVM所能产生某类型Object的个数大家知道生成一个数据库的Connection object 是一个非常影响程序速度的操作,所以"连接池'(connection                pooling)是一个很常使用的技巧: 程序维持一定数量的Connection object,                以便不断的重用.这样一来就大大减少了产生和销毁Connection object所需的时间.这就要求我们能够控制最多可产生个Connection                object. 下面我们看看如和用Factory 模式来解决这个问题:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
import java.sql.*;
import java.util.*;
pulbic class ConnectionPool {
    private static final int NUM_OF_CONNECTION = 50;
    private static int counter = 0;
    private Vector connectionPool = new Vector();
    private ConnectionPool(){
}
public static Connection getConnection() throws Exception{
    Connection connection = null;
    if (connectionPool.size() < NUM_OF_CONNECTION) {
            
        connection = Class.forName("my.sql.Driver").
getConnection("dbcracle:thin192.168.100.36:1521ra9i");
       connectionPool.add(connection);
} else {
if(conuter < NUM_OF_CONNECTION)
  counter++;
else counter = 0;
  connection = (Connection)connectionPool.elementAT(counter%
NUM_OF_CONNECTION );
}
return connection;
    }
}




上面这一小段程序展示了如何利用Factory 模式保持50个Connection                Object:当Connection的数量小于指定数时,我们就不断创建Connection,直到50个Connection Object 被创建。                在这之后,我们就不断的重用这些Object。
返回列表