记录一些学习资料

一、Hadoop

    1、Hadoop安装教程_单机/伪分布式配置_Hadoop2.6.0+Ubuntu14.4

        http://www.powerxing.com/install-hadoop/

    2、Hadoop实例解析-原理解析

        http://www.tuicool.com/articles/aqU7Rb

    3、Hadoop >> MapReduce初级编程案例(去重,排序) -- 多博客连载

        http://www.cnblogs.com/xia520pi/archive/2012/06/04/2534533.html

二、关于静态类的属性是否会被GC回收的思考

    最近在学设计模式,当深入学习单例模式的时候,写了如下一个单例类,是资料提供者比较认可的一种线程安全的单例类。

package com.eya.designPattern.singleton;

/**
 * 单例模式
 * @author luolin
 *
 * @version $id:Singleton.java,v 0.1 2015年11月25日 上午10:05:57 luolin Exp $
 */
public class Singleton {

    private Singleton() {
    }

    
    private static class SingletonFactory {
        private static Singleton single = new Singleton();
    }

    
    public Singleton getInstance() {
        return SingletonFactory.single;
    }

}
    这里使用了一个私有静态内部类来实例化对象,这样做是借助JVM的内部机制保证对象的实例化和赋值完成。资料提供者的原话是这样的: JVM内部的机制能够保证当一个类被加载的时候,这个类的加载过程是线程互斥的。这样当我们第一次调用getInstance的时候,JVM能够帮我们保证instance只被创建一次,并且会保证把赋值给instance的内存初始化完毕。

    思考:当静态内部类在加载的时候,就会实例化单例对象,并存放于内存中,如果长时间未使用,单例类的实例是否会被GC回收呢?如果被GC回收了,那么当调用getInstance()方法的时候,就返回不正确了。

    答案:如果一个类的class文件被装载,那么它的静态成员变量便会被初始化,除非unloader这个类的class对象,他的静态成员变量是不会被gc回收的


你可能感兴趣的:(记录一些学习资料)