1. ArrayList,Vector, LinkedList 存储性能及特点
ArrayList 和 Vector 都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便添加和插入元素,它们都同意直接按 序号索引元素。可是插入元素要涉及数组元素移动等内存操作,所以索引数据快而插入数据慢,Vector 因为使用了 synchroni zed 方法(线程安全),通常性能上较 ArrayList 差,而 LinkedList 使用双向链表实现存储,按序号索引数据须要进行前向或后
向遍历,可是插入数据时仅仅须要记录本项的前后项就可以,所以插入速度较快。
2.Collection 和 Collections 的差别
Collection 是集合类的上级接口,继承与他的接口主要有 Set 和 List. Collections 是针对集合类的一个帮助类,他提供一系列静态方法实现对各种集合的搜索、排序、线程安全化等操作。
3.HashMap 和 Hashtable 的差别
HashMap 是 Hashtable 的轻量级实现(非线程安全的实现),他们都完毕了 Map 接口,主要差别在于 HashMap 同意空(null)键值(key),因为非线程安全,效率上可能高于 Hashtable。 HashMap 同意将 null 作为一个 entry 的 key 或者 value,而 Hashtable 不同意。
HashMap 把 Hashtable 的 contains 方法去掉了,改成 containsvalue 和 containsKey。由于 contains 方法easy让人引起误解。 Hashtable 继承自 Dictionary 类,而 HashMap 是 Java1.2 引进的 Map interface 的一个实现。 最大的不同是,Hashtable 的方法是
Synchronize 的。而 HashMap 不是,在多个线程訪问 Hashtable 时,不须要自己为它的 方法实现同步,而 HashMap 就必须为之提供外同步。
Hashtable 和 HashMap 採用的 hash/rehash 算法都大概一样,所以性能不会有非常大的差异。
4.sleep() 和 wait() 有什么差别
sleep 是线程类(Thread)的方法,导致此线程暂停运行指定时间,给运行机会给其它线程,可是监控状态依旧保持,到时 后会自己主动恢复。调用 sleep 不会释放对象锁。
wait 是 Object 类的方法,对此对象调用 wait 方法导致本线程放弃对象锁,进入等待此对象的等待锁定池,仅仅有针对此对象发 出 notify 方法(或 notifyAll)后本线程才进入对象锁定池准备获得对象锁进入执行状态。
5.Overload 和 Override 的差别
Overloaded 的方法能否够改变返回值的类型?
方法的重写 Overriding 和重载 Overloading 是 Java 多态性的不同表现。
重写 Overriding 是父类与子类之间多态性的一种表现,重载 Overloading 是一个类中多态性的一种表现。假设在子类中定义某方法与其父类有同样的名称和參数。我们说该方法被重写 (Overriding)。子类的对象使用这种方法时,将调用子类中的定义。对它而言。父类中的定义如同被"屏蔽"了。假设在一个类 中定义了多个同名的方法,它们或有不同的參数个数或有不同的參数类型,则称为方法的重载(Overloading)。
Overloaded 的 方法是能够改变返回值的类型。
6.同步和异步有何异同,在什么情况下分别使用他们?
假设数据将在线程间共享。
比如正在写的数据以后可能被还有一个线程读到,或者正在读的数据可能已经被还有一个线程写过了。 那么这些数据就是共享数据,必须进行同步存取。 当应用程序在对象上调用了一个须要花费非常长时间来运行的方法,而且不希望让程序等待方法的返回时,就应该使用异步编程。 在很多情况下,它们趋向于使用异步更有效的方式。
版权声明:本文博主原创文章。博客,未经同意不得转载。