大数据开发面试题-企业面试真题【连载】

单例

5种写法,1、懒汉2、恶汉3、静态内部类4、枚举5、双重校验锁

1、

classLazySingleton{

    privatestaticLazySingleton singleton;

    privateLazySingleton(){

    }

    publicstaticLazySingleton getInstance(){

        if(singleton==null){

            singleton=newLazySingleton();

        }

        returnsingleton;

    }  

}

 

2、

classHungrySingleton{

    privatestaticHungrySingleton singleton=newHungrySingleton();

    privateHungrySingleton(){}

    publicstaticHungrySingleton getInstance(){

        returnsingleton;

    }

}

 

3、

classInternalSingleton{

    privatestaticclassSingletonHolder{

        privatefinalstatic  InternalSingleton INSTANCE=newInternalSingleton();

    }  

    privateInternalSingleton(){}

    publicstaticInternalSingleton getInstance(){

        returnSingletonHolder.INSTANCE;

    }

}

 

4、

enumEnumSingleton{

    INSTANCE;

    publicvoiddoSomeThing(){

    }

}

 

5、

class LockSingleton{

   private volatile static LockSingleton singleton;

   private LockSingleton(){}

    

   //详见:http://www.ibm.com/developerworks/cn/java/j-dcl.html

   public static LockSingleton getInstance(){

       if(singleton==null){

           synchronized(LockSingleton.class){

                if(singleton==null){

                    singleton=newLockSingleton();

                }

           }

       }

       return singleton;

    }

    

}

2.   Linkedlist和ArrayList的区别

 ArrayList是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,允许直接按序号索引元素,但是插入元素要涉及数组元素移动等内存操作,所以索引数据快而插入数据慢。LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记录本项的前后项即可,所以插入速度较快。

 

3.http安全问题

         1)重要信息:MD5,AES加密

         2)不太重要的数据:用签名

         3)登录态:

4.sparkStreaming和storm的区别

 

5.gc

自动监测对象是否超过作用域从而达到自动回收内存的机制,Java语言没有提供

释放已分配内存的显式操作方法。


 

你可能感兴趣的:(大数据开发面试题-企业面试真题【连载】)