Hadoop源码阅读准备

Java基础

2014-05-10到2014-05-11 (周末两天)

先了解Hadoop中使用了哪些技术,然后在理论上各个击破,最后结合Hadoop的源码来体验实际中的使用。

①.多态

多态有两种表现形式,重载和覆盖

重载(overload),指的是同一个类中,多个方法名字相同,但是参数不同

覆盖(override),指的是子类中,重新实现父类的某个方法

②.接口、抽象类

接口和抽象类之间的关系
相同点:
(1)接口和抽象类都不能被实例化(都位于继承树的顶端,用于被其他的类实现和继承)  
(2)接口和抽象类中的所有抽象方法,子类都必须实现
不同点: 
(1)接口只能包含抽象方法,不能包含已经提供实现的方法;抽象类可以包含普通方法
(2)接口不能定义静态方法;抽象类可以定义静态方法
(3)接口中只能定义静态常量Field,不能定义普通的Field;抽象类既可以定义普通的Field也能定义静态常量Field
(4)接口不能包含构造器;抽象类中可以包含构造器,抽象类中的构造器并不是用于创建对象的,而是让其子类调用这些构造器来完成抽象类的初始化操作
(5)接口不能够包含初始化块;但是抽象类里面可以包含
(6)一个类只能继承一个抽象类;但可以实现多个接口,用逗号隔开,这可以弥补Java中单继承的不足

接口(Interface),接口是定义与实现的分立,是更深层次的理解,接口本身反映了系统设计人员对系统的抽象理解。在类中实现接口时,方法名、返回值、参数必须与接口中的完全一致,并且必须实现接口中的所有方法。接口还有数据共享(里面的变量全是常量)的作用。

抽象类(Abstract Class),抽象类应当拥有尽可能多的共同代码,拥有尽可能少的数据

重难点在两者的差异上:抽象类的优点,抽象类中新添加一个方法,所有子类都自动有了这个方法,接口的子类则需要并且必须重新实现一遍。接口的优点,任何一个实现了一个Java接口所规定的方法的类都可以具有这个接口的类型,而一个类可以实现多个接口,从而这个类就有了多种类型。将两个优点结合起来就是经典的“缺省适配模式”,声明类型的工作仍然由Java接口承担,但是同时给出一个Java抽象类,且实现了这个接口,而其他同属于这个抽象类型的具体类可以选择实现这个Java接口,也可以选择继承这个抽象类,也就是说在层次结构中,Java接口在最上面,然后紧跟着抽象类。

关键字:extends是继承,implements是实现

④.Socket通信

SocketServer和Socket类

③.多线程、并发、异步调用

Thread和Runable的区别


锁(同步锁,异步锁)


⑤.序列化、反序列化

⑥.设计模式

单例模式

工厂模式
简单使用:申明类(或者先抽象出一个接口),然后直接在使用的地方实例化。
工厂模式:申明类(经常先抽象出一个接口),然后专门用一个类来进行实例化(所谓的工厂),在用的地方就调用这个工厂类,传递合适的参数来创建具体对象并使用。

⑨.异常处理

Exception

⑩.动态编程

反射、元数据编程

参考书籍:《Java编程思想》


基本语法:

static,静态修饰符,类中的静态变量和静态方法在加载类的时候就加载到内存中,可通过类名直接调用。
什么是静态呢?在程序中任何变量或者代码都是在编译时由系统自动分配内存来存储的,而所谓静态就是指在编译后所分配的内存会一直存在,直到程序退出内存才会释放这个空间。
这样做有什么意义呢? 在Java程序里面,所有的东西都是对象,而对象的抽象就是类,对于一个类而言,如果要使用他的成员,一般情况下必须先实例化对象,再通过对象的引用才能够访问这些成员。static让用户不需要实例化对象就可以引用成员,比如Integer.parseInt(),Float.parseFloat()。这样的变量和方法我们又叫做类变量和类方法。 
静态代码块在项目启动的时候就执行,这是主动执行,而静态方法需要用类名调用才会执行,这是被动执行。

注意:很多人讨论staitc和全局的关系,其实有点混淆概念了。静态和非静态,全局和局部,这是两组不同的对比系,不能放在一起来讲。只是经常看到一个变量既是static变量,又是全局变量,但并不能说明staitc和全局有什么必然联系。


进程间通信(IPC,Inter-Process Communication),指多个进程或线程间传送数据或信号的一些技术或方法。进程是计算机系统分配资源的最小单位(严格说来是线程)。每个进程都有自己的一部分独立的系统资源,彼此是隔离的。为了能使不同的进程互相访问资源并进行协调工作,才有了进程间通信。进程间通信技术包括消息传递、同步、共享内存和远程过程调用(RPC)。


this,当一个对象创建后,Java虚拟机(JVM)就会给这个对象分配一个引用自身的指针,这个指针的名字就是this。super跟this非常类似,super本质上就是一个指向父类对象的指针。


类间关系,类之间最基本的三种关系:依赖、聚合、继承

依赖,就是一个类使用另一个类(的方法),使用的关系,

聚合,就是一个类的对象含有另一个类的对象,有一个(has-a)的关系,

继承,是一种(is-a)的关系,



2014-05-22 晚23:18

最近在看Hadoop源码,看了后发现两个问题,一是我Java水平不高,需要踏踏实实的补;二是看Hadoop效率不高,可能方法不对,看了就忘了。所以就花时间总结了下我觉得怎么学习Java源码项目比较好:

1、首先是看,不能盲目的看。首先要在整体上对其有个大致的了解,整理出结构,然后再深入模块去细看。

2、其次是写,看不是真正的目的,能用起来才是真正的目的,用是检验学的最好方式,没有之一。所以试着写一个一模一样的demo,在写的过程中与源码对比,理解别人为什么那样写,那样写有什么好处,一个一个点的跟牛人对比学习,慢慢的积累多了你自然也就很牛了。

3、最后是悟,做完事需要总结反思,如果前面两点算埋头苦干的话,那这点算抬头看路。想想自己前面的做法,有什么地方做得好,有什么地方做得不好,有什么需要调整的地方,有什么需要优化的地方等等。


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值