进程与线程的区别
进程是系统进行资源分配和调度的一个独立单位,线程是进程的一个实体,是CPU调度和分派的基本单位。
进程间如何通信
无名管道通信;高级管道通信;有名管道通信;消息队列通信;信号量通信;信号;共享内存通信;套接字通信
线程间如何通信
线程间的通信目的主要是用于线程同步,所以线程没有像进程通信中的用于数据交换的通信机制。方式有:锁机制、信号量机制、信号机制。
Java的线程状态
新生、可运行、运行、等待/阻塞/睡眠、死亡
HashMap的数据机构是什么
哈希表:一种通过数组以及链表的结构。默认数据长度是16,加载因子0.6
HashMap、HashTable、ConcurrentHashMap的区别
1、HashMap是非线程安全的,HashTable是线程安全的。
2、HashMap的键和值都允许有null值存在,而HashTable则不行。
3、因为线程安全的问题,HashMap效率比HashTable的要高。
ConcurrentHashMap基于concurrentLevel划分出了多个Segment来对key-value进行存储,从而避免每次锁定整个数组
ArrayList如何实现扩容
ArrayLisk维护一个数组以及ArrayList的长度信息。当调用添加元素时,判断数据长度与ArrayList的添加后的长度比较,如果小于,则需要进行扩容,数据拷贝。
线程阻塞和等待的区别
线程阻塞是由于线程同步导致,线程等待是由于线程主动导致。