1、Java多线程是如何实现数据共享的?
JVM把内存分成了几个区域:方法区、堆区、栈区、程序计数器
堆区就是多个线程之间共享的,只要把数据放到堆内存中,就可以让多个线程都能访问到
2、Java创建线程池的接口是什么?参数LinkedBlockingQueued的作用是森么? 创建线程池的2种方式:通过Executors工厂类创建(简易但定制能力有限) 通过ThreadPoolExecutor创建(复杂但定制能力强) LinkedBlockingQueue表示线程池的任务队列,用户通过submit/execute向这个任务队列中 添加任务,再由线程池中的工作线程来执行任务
3、Java线程共有几种状态,状态之间是怎么切换的?
- NEW:新创建的线程还没有调用start方法时(安排了工作,还未开始行动)
- RUNNABLE:可工作的,又可以分为正在工作中和即将工作开始,调用start方法后,并正在 CPU上运行/在即将准备运行的状态
- BLOCKED:使用synchronized时,若锁被占用阻塞时的状态
- WAITING:调用wait()方法会进入该状态
- TIMED_WAITING:调用sleep()方法 或 wait(超时时间)会进入该状态
- TIMEINATED:工作完成了(run()方法执行完毕之后进入该状态)
4、在多线程下,如果对一个数进行叠加咋做?
- 使用synchronized/ReentrantLock加锁
- 使用AtomicInteger原子操作
5、Servlet是否线程安全?
Servlet本身是工作在多线程环境下,若在Servlet中创建了某个成员变量,此时若有多个 请求到达服务器,服务器就会多线程进行操作,是可能出现线程不安全的情况的
6、Thread和Runnable的区别与联系
Thread类描述了一个线程;Runnable描述了一个任务
在创建线程的同时需要指定线程完成的任务,可以直接重写Thread的run()方法,也可以使 用Runnable来描述这个任务。Thread类自己就实现了Runnable接口
7、多次start()一个线程会怎么样?
第一次调用可以成功调用;后续再调用会抛出java.lang.IllegalThreadStateException异常
8、有synchronized两个方法,两个线程分别同时使用这个方法,会发生什么?
synchronized加在非静态方法上相当于针对当前对象加锁
若2个方法属于同一个实例:t1获取到锁并执行方法,t2阻塞等待;直到t1执行完毕释放锁,t2 获取到锁之后才能执行内容
若这两个方法属于不同实例:两者能并发执行,互不干扰