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