- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Hadoop 序列化中的工厂设计模式
最近学习《 Hadoop 技术内幕》,简单研究了部分 Hadoop 源码。综合以前了解的一些开 源项目,发现高端代码乍一看上去有一个共同特性:到处都是泛型,到处都是反射。直接打 开一个方法的定义, 基本找不到它的实现逻辑, 只能找到接口。 后来结合书上的介绍稍作了 解,出现这种现象,说明源码很多都用到了抽象工厂模式。故再次查阅了抽象工厂的定义。 相信这对于今后开发中定义一个优秀的架构是很有帮助的。
抛出问题: Hadoop 的序列化
在 Hadoop 中有序列化的概念。简单搞清楚序列化:
1, 序列化是什么?就是把对象转化成二进制的流。 反序列化就是把二进制流转化成对
象。
2, 为什么要序列化?三点:持久化格式用于存储;通信数据格式用于传输;对象深拷 贝; Hadoop 中主要用前两点。
3,为什么不用Java内建的序列化? Java序列化非常强大。序列化的时候把什么类描述, 各种版本号,父类的信息都写到流中。一个简单的类能写出一大推数据来,对于强 烈需要减少传输量提高效率的分布式计算就不适应。故 Hadoop 自己搞了一套。
搞清楚了序列化的概念,然后再说一下有哪些东西需要序列化:
Java中不是有个 Serializable接口吗?同样:在hadoop中有 Writable接口,实现 Writable 的类都是要序列化的类。简单举例几个: IntWritable, LongWritable, Text。在java中就是
int, Long, String ,只是在hadoop要适应新的序列化给改了。
好了,那么 Hadoop 既然是 java 写的,不可能原来的序列化完全抛开不用了吧,所以原 来的实现 Serializable 的也要序列化
然后,序列化系列操作肯定有两个方法是相互依赖不可分割的:序列化和反序列化。 那么总结一下:
操作有两种:序列化和反序列化
操作对象分两类:实现了 Serializable 的对象和实现了 Writable 的对象
工厂系列的模式是干什么的?
工厂类的模式, 说穿了: 调用一个工厂的工厂方法,可以产生诸多相互关联的对象。程 序员灵活的选择创建哪个对象, 这样就避免的在程序中反复创建各种对象, 使创建对象和业 务解耦,增加了程序的可扩展性。
工厂系列模式的简单总结
工厂系列的模式有:
1, 简单工厂;
2, 工厂方法;
hadoop 中抽象 自己加了一点说明,3, 抽象工厂; 应该说:越往下,越抽象,越解耦。简单总结下各工厂的实现,重点说 工厂。 为了使文档完整, 对于 1、2
hadoop 中抽象 自己加了一点说明,
简单工厂 有三个元素:
1, 工厂类角色:具体类实现,用于判断要创建哪个产品对象
2, 抽象产品角色:一个抽象类或接口,为一系列相关产品的父类
3, 具体产品角色:一个或多个实现或继承抽象产品的具有共性的类 简单例子:
//抽象产品角色
public interface Car{
public void drive();
}
//具体产品角色
public class Benz implements Car{ public void drive() {
System.out.println(Driving Benz );
}
}
public class Bmw implements Car{ public void drive() {
System.out.println(Driving Bmw );
}
}
//工厂类角色 public class Driver{
//工厂方法
//注意 返回类型为抽象产品角色
public static Car driverCar(String s)throws Exception { // 判断逻辑,返回具体的产品角色给 Client if(s.equalsIgnoreCase(Benz))
return new Benz();
else if(s.equalsIgnoreCase(Bmw)) return new Bmw();
else throw new Exception();
//欢迎暴发户出场
public class Magnate{
public static void main(String[] args){ try{
//告诉司机我今天坐奔驰
Car car = Driver.driverCar(benz);
//下命令:开车
car.drive();
这个例子我从网上抓下来的, 先搞清楚什么是简单工厂模式, 这里, 他的缺点很明显: 虽然业务与对象创建解耦了, 但是具体工厂里涉及到了一部分业务, 万一这部分判断比较复 杂,这不仅写起来复杂麻烦,可扩展性还非常差,不实用
文档评论(0)