看看现在网上的有些文章 (包括一些所谓的面试宝典,文字简短但是害人不浅),随便截一些图:
然后类似的例子 演示大致如下 ,写了个卖瓜例子:
咋一看好像确实是资源不共享 。
真的吗,显然是代码写的问题。
1、 private int watermelon=10; 瓜 数 是类的 一个 私有变量 。
2、 new了 两个 卖瓜的摊子, 每个摊子 都有 自己的10个瓜 。
new TestThread().start();
new TestThread().start();
每个线程自己卖自己的瓜, 本来就是 每个摊子 10个瓜 ,这是超卖? 这是资源不共享问题?
这么写,明摆着不就是不同资源不同执行么,何来所谓的资源共享问题?
现在看看,我把调用的实现代码写成这样:
TestThread testThread=new TestThread();
new Thread(testThread).start();
new Thread(testThread).start();
运行结果,是不是就共享了 :
这样存在的问题就是 ,需要考虑线程并发带来的 数据同步问题 :
多运行几次,可以看到出现了一些 坏现象
这时候,简单的解决这个同步的问题,那就是使用 synchronized 了** :**
把涉及到数量的变化的代码块,我们使用 synchronized 给它锁起来 :
这样一来,尽管多个线程同时进行,操作同个资源 ,也不会出现 坏现象 ,谁能抢到资源,谁执行,但是执行时,别的都需要耐心等 :
继承Thread类 实现多线程 和 实现 Runnable接口 实现多线程
也可以点进去看看 Thread 的源码 ,其实就是实现了Runable ,我们在了解 继承Thread类 和 实现 Runnable接口 这两种方式实现多线程, 我们一定要保持清醒:
就到这吧。
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://blog.csdn.net/qq_35387940/article/details/121282438
内容来源于网络,如有侵权,请联系作者删除!