一、并行和并发有什么区别?
并行是指两个或者多个事件在同一时刻发生;而并发是指两个或多个事件在同一时间间隔发生。
并行是在不同实体上的多个事件,并发是在同一实体上的多个事件。
在一台处理器上“同时”处理多个任务,在多台处理器上同时处理多个任务。如hadoop分布式集群
二、线程和进程的区别
进程是程序运行和资源分配的基本单位,一个程序至少有一个进程,一个进程至少有一个线程,进程在执行过程中拥有独立的内存单元,而多个线程共享内存资源,减少切换次数,从而效率更高。线程是进程的一个实体,是cpu调度和分配的基本单位,是比程序更小的能独立运行的基本单位。同一进程中的多个线程之间可以并发执行。
三、守护线程是什么?
守护线程(即 daemon thread)是个服务线程,准确的说就是服务其他的线程。
四、创建线程的几种方式?
1、继承thread类创建线程
2、实现Runnable接口实现线程
3、通过Callable和Future 创建线程
4、通过线程池创建线程
五、Runnable和callable 有什么区别?
Runnable接口中的run()方法的返回值是void,它做的事情只是纯粹地去执行run()方法中的代码而已。
Callable接口中的方法是有返回值的,是一个范型,和future futureTask配合可以用来异步执行的结果。
六、线程的几种状态?
Thread源码中定义了六种状态:new(新建),runnable(可执行),blocked(阻塞),waiting(等待),time waiting (定时等待)和terminated(终止)。
七、sleep和wait的区别?
1,这两个方法来自不同的类分别是Thread(自控)和Object(他控)
2,最主要是sleep方法没有释放锁,而wait方法释放了锁,使得其他线程可以使用同步控制块或者方法。
3,wait,notify和notifyAll只能在同步控制方法或者同步控制块里面使用,而sleep可以在
任何地方使用
4,sleep必须捕获异常,而wait,notify和notifyAll不需要捕获异常
八、run()和start()方法的区别?
1.run()称为线程体,start()是启动线程的方法。
2.如果直接调用run()方法,就相当于调用一个普通函数而已。
九、在java程序中怎么保证多线程的运行安全?
1.原子性:提供互斥访问,同一时刻只能有一个线程对数据进行操作。(atomic、synchronized)
2.可见性:一个线程对主内存的修改可以及时的被其他线程看到(synchronized,volatile)
3.一个线程观察其他线程中的指令执行顺序,由于指令重排序,该观察结果一般杂乱无序(happens-before 原则)
十、java线程同步的几种方法?
1.使用Synchronized关键字
2、wait和notify ;
3、使用特殊域变量valatile