java 线程状态 java多线程为什么不推荐使用excutor执行?
java多线程为什么不推荐使用excutor执行?
Java中BlockingQueue有两种主要实现:arrayblockingqueue和linkedblockingqueue。Arrayblockingqueue是由array实现的有界阻塞队列,必须设置其容量。linkedblockingqueue是由链表实现的有界阻塞队列。容量可选择性设置。如果不设置,它将是一个无限长的阻塞队列,最大长度为Integer.MAX[value.
查看new singleexecutor的源代码,您可以发现在创建linkedblockingqueue时没有指定容量。此时,linkedblockingqueue是一个无边界队列。对于无边界队列,任务可以连续添加到队列中。在这种情况下,由于任务太多,可能会发生内存溢出。
多个线程可以读一个变量,只有一个线程可以对这个变量进行写,到底要不要加锁?
下面简要说明以下原因:
锁定是因为操作不是原子的。让我们用操作一来解释它。看下面两个图。
我这个操作需要
看上面的第二个图,你能很清楚地理解这个过程吗?
锁定是为了确保上述三个步骤是原子操作。
回到问题上来,只有一个线程要写,没有竞争,所以不需要锁定。
但是,如果你看第一张图片,因为主内存和本地内存的存在
在一个线程写入后,其他线程无法立即看到它。这就是可见性问题。
添加volatile关键字后,它将在操作后强制工作内存和主内存同步,以确保其他线程可以立即看到它。
为什么Java坚持多线程不选择协程?
Java从发明的第一天起就被定义为多线程网络编程语言。Java最大的特点不是跨平台,而是它的多线程模型(当时,C中没有线程,正如我们现在看到的,C还没有出现)。因为近二十年来软件产业的增长主要来自于网络编程。网络编程中最常见的模式是客户机/服务器(client/server,又称C/s),这种编程模式需要在服务器端同时接受客户机的请求,即具有良好的并发特性,主要依赖于多线程技术。Java的主战场是服务器端编程。因此,多线程技术对Java来说是非常重要和不可缺少的。
当我们要引入协处理时,我们要解决哪些问题。我认为这只不过是以下几点:
节省资源,重量轻,具体来说:节省内存,每个线程需要分配一段堆栈内存,内核中的一些资源,节省分配线程的开销(创建和销毁线程每次需要做一个系统调用),节省了线程切换带来的大量开销,配合NiO实现无阻塞编程,提高了系统的吞吐量,使用起来更方便。另外,async await(异步运行,但写起来感觉是同步的)我们分开来谈。
让我们从记忆开始。以javaweb编程为例,Tomcat上woker线程池的最大线程数一般配置在50到500之间(spring boot的默认值是200)。也就是说,可以同时接受的请求太多了。如果超过最大值,请求将被拒绝。如果每个线程提供128KB,则500个线程的内存消耗约为60MB。如果存在瓶颈,可能在CPU、IO、带宽、DB-CPU等方面存在瓶颈,但是对于通常为数GB的Java运行时进程来说,内存量的增加似乎不是一个大问题。
java 线程状态 java多线程实例 java线程通信的几种方式
版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。