【软件工程实践】Pig项目12-Data目录源码分析-其他元组2

本文主要分析Pig项目中不同类型的元组,包括AppendableSchemaTuple、SchemaTuple、BinSedesTuple、NonWritableTuple、TargetedTuple和TimestampedTuple。每个元组都有其特定的用途,如AppendableSchemaTuple用于动态扩展,SchemaTuple是类型感知的快速元组,BinSedesTuple优化序列化,NonWritableTuple是不可写元组,TargetedTuple存储运算符,TimestampedTuple带有时间戳信息。这些元组在Pig Latin的实现中扮演重要角色。
摘要由CSDN通过智能技术生成

2021SC@SDUSC 

 上篇我们讲解了AmendableTuple,本篇继续讲解其他元组

其他元组

AppendableSahemaTuple

ApendableSachemaTuples是一个抽象类,其UML如下

 继承关系

public abstract class AppendableSchemaTuple<T extends AppendableSchemaTuple<T>> extends SchemaTuple<T>

 继承自SchemaTuple这个也没有接触过,并且该类也没有任何注释,也没有测试函数,由于是抽象类甚至没有构造函数,于是只能大致看一下public的方法

@Override
public void append(Object val) {
   
if (appendedFields == null) {
        appendedFields = mTupleFactory.newTuple();
    }

    appendedFields.append(val);
}

public SchemaTuple<T> set(List<Object> l) throws ExecException {
   
int listSize = l.size();
   
int schemaSize = schemaSize();

   
if (listSize < schemaSize) {
       
throw new ExecException("Given list of objects has too few fields ("+l.size()+" vs "+schemaSize()+")");
    }

    Iterator<Object> it = l.iterator();

    generatedCodeSetIterator(it);

    resetAppendedFields();

   
while (it.hasNext()) {
        append(it.next());
    }

   
return this;
}

public void set(int fieldNum, Object val) throws ExecException {
   
int diff = fieldNum - schemaSize();
   
if (diff >= 0 && diff < appendedFieldsSize()) {
        setAppendedField(diff, val);
    }
else {
       
super.set(fieldNum, val);
    }
}

set函数将 ObjectList里的数据加入到了Tuple中

接下来看看它的父类

SchemaTuple

继承关系

public abstract class SchemaTuple<T extends SchemaTuple<T>> extends AbstractTuple implements TypeAwareTuple {  

UML

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值