【软件工程实践】Pig项目13-Data目录源码分析-工厂类

2021SC@SDUSC  

 上篇我们结束了各种元组的讲解,本篇我们来着重讲解一下pig数据结构中出现的工厂类

工厂类 

工厂这一概念来源于面向对象设计里面的工厂模式,是一种基于面向对象思想的抽象方法,简单来说,调用者只关心数据结构的创建创建而不关心数据结构的内部实现,于是抽象出创建数据结构的工厂,Pig中有很多利用工厂模式的案例

BagFactory

包 工厂 ,外部宜当调用此类来创建包

这个工厂类是抽象的

注释:

/**
 *
制造不同类型袋子的工厂。
 
* 这个类是抽象的,因此如果用户希望提供自己的返回他们的包实现的包工厂,他们可以覆盖包工厂。
 
* 如果属性 pig.data.bag.factory.name 设置为类名
 
* 并且 pig.data.bag.factory.jar 设置为指向包含上述命名类的 jar URL
 
* getInstance() 将创建使用指定 jar 的命名类的实例。
 
* 否则,它将创建 DefaultBagFactory 的一个实例。
 
*/

构造函数

protected BagFactory() {
    gMemMgr = SpillableMemoryManager.getInstance();
}

获取实例

/**
 *
获取对单例工厂的引用。
 
* @return BagFactory
 */

public static BagFactory getInstance() {
   
if (gSelf == null) {
        String factoryName =
            System.getProperty(
"pig.data.bag.factory.name");
        String factoryJar =
            System.getProperty(
"pig.data.bag.factory.jar");
       
if (factoryName != null && factoryJar != null) {
           
try {
                URL[] urls =
new URL[1];
                urls[
0] = new URL(factoryJar);
                ClassLoader loader =
new URLClassLoader(urls,
                    BagFactory.
class.getClassLoader());
                Class c = Class.forName(factoryName,
true, loader);
                Object o = c.newInstance();
               
if (!(o instanceof BagFactory)) {
                   
throw new RuntimeException("Provided factory " +
                        factoryName +
" does not extend BagFactory!");
                }
                gSelf = (BagFactory)o;
            }
catch (Exception e) {
               
if (e instanceof RuntimeException) {
                   
// We just threw this
                   
RuntimeException re = (RuntimeException)e;
                   
throw re;
                }
               
throw new RuntimeException("Unable to instantiate "
                   
+ "bag factory " + factoryName, e);
            }
        }
else {
            gSelf =
new

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值