预览加载中,请您耐心等待几秒...
1/6
2/6
3/6
4/6
5/6
6/6

在线预览结束,喜欢就下载吧,查找使用更方便

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

/NUMPAGES6 常见的Java多线程面试问题及解答 解答:一个进程对应一个程序的执行,而一个线程则是进程执行过程中的一个单独的执行序列,一个进程可以包含多个线程。线程有时候也被称为轻量级进程.一个Java虚拟机的实例运行在一个单独的进程中,不同的线程共享Java虚拟机进程所属的堆内存。这也是为什么不同的线程可以访问同一个对象。线程彼此共享堆内存并保有他们自己独自的栈空间。这也是为什么当一个线程调用一个方法时,他的局部变量可以保证线程安全。但堆内存并不是线程安全的,必须通过显示的声明同步来确保线程安全。问题:列举几种不同的创建线程的方法.解答:可以通过如下几种方式:继承Thread类实现Runnable接口使用Executorframework(这会创建一个线程池)123456789101112131415classCounterextendsThread{//methodwherethethreadexecutionwillstartpublicvoidrun(){//logictoexecuteinathread}//let’sseehowtostartthethreadspublicstaticvoidmain(String[]args){Threadt1=newCounter();Threadt2=newCounter();t1.start();//startthefirstthread.Thiscallstherun()method.t2.start();//thisstartsthe2ndthread.Thiscallstherun()method.}}123456789101112131415classCounterextendsBaseimplementsRunnable{//methodwherethethreadexecutionwillstartpublicvoidrun(){//logictoexecuteinathread}//letusseehowtostartthethreadspublicstaticvoidmain(String[]args){Threadt1=newThread(newCounter());Threadt2=newThread(newCounter());t1.start();//startthefirstthread.Thiscallstherun()method.t2.start();//thisstartsthe2ndthread.Thiscallstherun()method.}}通过线程池来创建更有效率。问题:推荐通过哪种方式创建线程,为什么?解答:最好使用Runnable接口,这样你的类就不必继承Thread类,不然当你需要多重继承的时候,你将一筹莫展(我们都知道Java中的类只能继承自一个类,但可以同时实现多个接口)。在上面的例子中,因为我们要继承Base类,所以实现Runnable接口成了显而易见的选择。同时你也要注意到在不同的'例子中,线程是如何启动的。按照面向对象的方法论,你应该只在希望改变父类的行为的时候才去继承他。通过实现Runnable接口来代替继承Thread类可以告诉使用者Counter是Base类型的一个对象,并会作为线程执行。问题:简要的说明一下高级线程状态.解答:下图说明了线程的各种状态.可执行(Runnable):当调用start()方法后,一个线程变为可执行状态,但是并不意味着他会立刻开始真正地执行。而是被放入线程池,由线程调度器根据线程优先级决定何时挂起执行。12MyThreadaThread=newMyThread();aThread.start();//becomesrunnable执行中(Running):处理器已经在执行线程的代码。他会一直运行直到被阻断,或者通过静态方法Thread.yield()自行放弃执行的机会,考虑到场景切换所带来的开销,yield()方法不应该被经常调用。等待中(Waiting):线程由于等待I/O等外部进程的处理结果而处于被阻断的状态,调用currObject.wait()方法会使得当前线程进入等待状态,直到其它线程调用currObject.notify()或者currObject.notifyAll()。睡眠中(Sleeping):重载方法Thread.sleep(milliseconds),Thread.sleep(milliseconds,nanoseconds)可以迫使Java线程进入睡眠状态(挂起)。由于I/O阻塞(BlockedonI/O):当I/O条件发生变化时(例如读取了几个字节的数据)会迁移到可执行状态。由于同步阻塞中(Blockedonsynchro