java中的多线程面试问题,java多线程高并发面试题

  java中的多线程面试问题,java多线程高并发面试题

  00-1010A线程正在对象中执行同步方法。线程B可以同时在同一个对象中执行一个异步方法吗?

  是的,两个线程运行需要不同的资源,所以不需要抢占。

  一个案子,

  包多贤成2;/* * * @ AuthorYeqv * @ program a2 * @ class name ms1 * @ date 2022/2/7 19336008 * @ Email w16638771062@163.com */public class ms1 {//线程正在对象中执行同步方法。线程B可以同时在同一个对象中执行一个异步方法吗?对象a=新对象();public static void main(String[]args){ var t=new Ms1();新线程(()- t.a1())。start();//一个线程新线程(()-t.a2())。start();//B thread } void A1(){ synchronized(a){ system . out . println( synchronization method );}} void a2() {System.out.println(异步方法);}}运行结果:

  00-1010同上,线程B可以同时在同一个对象中执行另一个同步方法吗?

  不是,两个线程需要一个公共资源来执行,公共资源是同步锁定的,同一时间只能被一个线程占用。

  两起案件,

  包多贤成2;导入Java . util . concurrent . time unit;/* * * @ AuthorYeqv * @ program a2 * @ class name MS2 * @ date 2022/2/7 19336025 * @ Email w16638771062@163.com */public class MS2 {//同上,线程B可以同时在同一个对象中执行另一个同步方法吗?对象a=新对象();public static void main(String[]args){ var t=new Ms2();新线程(()- t.a1())。start();//一个线程新线程(()-t.a2())。start();//B thread } void A1(){ synchronized(a){ system . out . println(输入同步方法1 );试试{ TimeUnit。SECONDS.sleep(十);} catch(interrupted exception e){ e . printstacktrace();} System.out.println(同步方法1结束);} } void a2(){ synchronized(a){ system . out . println(输入同步方法2 );试试{ TimeUnit。SECONDS.sleep(十);} catch(interrupted exception e){ e . printstacktrace();} System.out.println(同步方法2结束);}}}运行结果:

  线程A先运行,占用资源。

  线程A运行完毕释放资源后,线程B就可以进入执行了。

  线程b完成执行。

  00-1010线程抛出异常释放锁吗?

  是的,一旦线程抛出异常,资源就会被释放。

  三个案子,

  包多贤成2;导入Java . util . concurrent . time unit;/* * * * @作者yeqv * @程序A2 * @ Classname Ms3 * @日期2022/2/7

   19:41 * @Email w16638771062@163.com */public class Ms3 { //线程抛出异常会释放锁吗? Object a = new Object(); public static void main(String[] args) { var t = new Ms3(); new Thread(() -> t.a1()).start();//A线程 new Thread(() -> t.a2()).start();//B线程 } void a1() { int c = 3; int b; synchronized (a) { System.out.println("进入同步方法1"); try { b = c / 0; System.out.println(b); TimeUnit.SECONDS.sleep(10); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("同步方法1结束"); } } void a2() { synchronized (a) { System.out.println("进入同步方法2"); try { TimeUnit.SECONDS.sleep(10); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("同步方法2结束"); } }}结果: 方法一出现异常,立刻释放资源。线程二开始执行

  

 

  

问题四

写一个程序,证明AtomicInteger类比synchronized更高效

 

  synchronized更高效p>案例一

  

package duoxiancheng2;import java.util.concurrent.atomic.AtomicInteger;/** * @author yeqv * @program A2 * @Classname Ms4 * @Date 2022/2/7 20:04 * @Email w16638771062@163.com */public class Ms4 { AtomicInteger n = new AtomicInteger(10000); int num = 10000; public static void main(String[] args) { var t = new Ms4(); new Thread(t::minus, "T1").start(); new Thread(t::minus, "T2").start(); new Thread(t::minus, "T3").start(); new Thread(t::minus, "T4").start(); new Thread(t::minus, "T5").start(); new Thread(t::minus, "T6").start(); new Thread(t::minus, "T7").start(); new Thread(t::minus, "T8").start(); } void minus() { var a = System.currentTimeMillis(); while (true) { /* if (n.get() > 0) { n.decrementAndGet(); System.out.printf("%s 售出一张票,剩余%d张票。 %n", Thread.currentThread().getName(), n.get()); } else { break; }*/ synchronized (this) { if (num > 0) { num--; System.out.printf("%s 售出一张票,剩余%d张票。 %n", Thread.currentThread().getName(), num); } else { break; } } } var b = System.currentTimeMillis(); System.out.println(b - a); }}

synchronized结果:

 

  

 

  AtomicInteger结果:

  

 

  

问题五

写一个程序证明AtomXXX类的多个方法并不构成原子性

 

  

package demo16;import java.util.ArrayList;import java.util.List;import java.util.concurrent.atomic.AtomicInteger;/** * 写一个程序证明AtomXXX类的多个方法并不构成原子性 */public class T { AtomicInteger count = new AtomicInteger(0); void m() { for (int i = 0; i < 10000; i++) { if (count.get() < 100 && count.get() >= 0) { //如果未加锁,之间还会有其他线程插进来 count.incrementAndGet(); } } } public static void main(String[] args) { T t = new T(); List<Thread> threads = new ArrayList<>(); for (int i = 0; i < 10; i++) { threads.add(new Thread(t::m, "thread" + i)); } threads.forEach(Thread::start); threads.forEach((o) -> { try { //join()方法阻塞调用此方法的线程,直到线程t完成,此线程再继续。通常用于在main()主线程内,等待其它线程完成再结束main()主线程。 o.join(); //相当于在main线程中同步o线程,o执行完了,main线程才有执行的机会 } catch (InterruptedException e) { e.printStackTrace(); } }); System.out.println(t.count); }}

问题六

写一个程序,在main线程中启动100个线程,100个线程完成后,主线程打印完成

 

  

package cn.thread;import java.util.concurrent.CountDownLatch;/** * 写一个程序,在main线程中启动100个线程,100个线程完成后,主线程打印“完成” * * @author webrx [webrx@126.com] * @version 1.0 * @since 16 */public class T12 { public static void main(String[] args) { CountDownLatch latch = new CountDownLatch(100); for (int i = 0; i < 100; i++) { new Thread(() -> { String tn = Thread.currentThread().getName(); System.out.printf("%s : 开始执行...%n", tn); System.out.printf("%s : 执行完成,程序结束。%n", tn); latch.countDown(); }, "T" + i).start(); } try { latch.await(); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("---------------------------------------"); System.out.println("100个线程执行完了。"); String tn = Thread.currentThread().getName(); System.out.printf("%s : 执行完成,程序结束。%n", tn); }}

到此这篇关于高价值Java多线程面试题分析的文章就介绍到这了,更多相关Java 多线程内容请搜索盛行IT以前的文章或继续浏览下面的相关文章希望大家以后多多支持盛行IT!

 

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

留言与评论(共有 条评论)
   
验证码: