多线程编程,如何确定线程数,依据是什么

J2EE 码拜 9年前 (2015-04-05) 1227次浏览 0个评论

Java中,多线程编程,如何确定线程数,依据什么确定启动线程数呢?
CPU的个数?还是什么,为什么?

多线程编程,如何确定线程数,依据是什么
5分
线程数量和CPU核数有关,网上有建议说线程数为核数的两倍最好。其实只要这些线程不频繁切换和竞争资源的话线程多点也可以,想要最优性能还是根据具体项目慢慢调试吧。
多线程编程,如何确定线程数,依据是什么
引用 1 楼 ghostkngiht 的回复:

线程数量和CPU核数有关,网上有建议说线程数为核数的两倍最好。其实只要这些线程不频繁切换和竞争资源的话线程多点也可以,想要最优性能还是根据具体项目慢慢调试吧。

嗯,我也听过两倍CPU核数的观点,但是不敢苟同。这个应该收到 项目中多线程这块儿比重的影响。

那么,在项目中,如何调试(工具?还是其他的什么思想思路?)性能最优,避免频繁切换线程、竞争资源呢?

多线程编程,如何确定线程数,依据是什么
10分
引用 2 楼 liu765023051 的回复:
Quote: 引用 1 楼 ghostkngiht 的回复:

线程数量和CPU核数有关,网上有建议说线程数为核数的两倍最好。其实只要这些线程不频繁切换和竞争资源的话线程多点也可以,想要最优性能还是根据具体项目慢慢调试吧。

嗯,我也听过两倍CPU核数的观点,但是不敢苟同。这个应该收到 项目中多线程这块儿比重的影响。

那么,在项目中,如何调试(工具?还是其他的什么思想思路?)性能最优,避免频繁切换线程、竞争资源呢?

CPU切不切换我们没法控制,只能提高线程优先级以获取更多的CPU时间。
CPU除了处理java还需要处理N多系统和其他线程,一般而言多线程编程中,在确保内存不溢出的情况下提升线程数是可以提高CPU中签率,也就是能提高你的程序处理数据的速度。
不过,即使没溢出,也不是线程数越大越好,线程切换毕竟需要时间,应该找到瓶颈所在。例如如果大部分线程都在等待同步模块的执行,那么瓶颈就是同步模块,这时候应该减少线程数或者优化同步模块。
调试方式可以用打时间的方式,观察线程在哪个地方执行时间最长,然后找到原因,同时能判断线程数量是大了还是小了。

多线程编程,如何确定线程数,依据是什么
4分
引用 3 楼 weinianjie1 的回复:
Quote: 引用 2 楼 liu765023051 的回复:
Quote: 引用 1 楼 ghostkngiht 的回复:

线程数量和CPU核数有关,网上有建议说线程数为核数的两倍最好。其实只要这些线程不频繁切换和竞争资源的话线程多点也可以,想要最优性能还是根据具体项目慢慢调试吧。

嗯,我也听过两倍CPU核数的观点,但是不敢苟同。这个应该收到 项目中多线程这块儿比重的影响。

那么,在项目中,如何调试(工具?还是其他的什么思想思路?)性能最优,避免频繁切换线程、竞争资源呢?

CPU切不切换我们没法控制,只能提高线程优先级以获取更多的CPU时间。
CPU除了处理java还需要处理N多系统和其他线程,一般而言多线程编程中,在确保内存不溢出的情况下提升线程数是可以提高CPU中签率,也就是能提高你的程序处理数据的速度。
不过,即使没溢出,也不是线程数越大越好,线程切换毕竟需要时间,应该找到瓶颈所在。例如如果大部分线程都在等待同步模块的执行,那么瓶颈就是同步模块,这时候应该减少线程数或者优化同步模块。
调试方式可以用打时间的方式,观察线程在哪个地方执行时间最长,然后找到原因,同时能判断线程数量是大了还是小了。

学习

多线程编程,如何确定线程数,依据是什么
引用 3 楼 weinianjie1 的回复:
Quote: 引用 2 楼 liu765023051 的回复:
Quote: 引用 1 楼 ghostkngiht 的回复:

线程数量和CPU核数有关,网上有建议说线程数为核数的两倍最好。其实只要这些线程不频繁切换和竞争资源的话线程多点也可以,想要最优性能还是根据具体项目慢慢调试吧。

嗯,我也听过两倍CPU核数的观点,但是不敢苟同。这个应该收到 项目中多线程这块儿比重的影响。

那么,在项目中,如何调试(工具?还是其他的什么思想思路?)性能最优,避免频繁切换线程、竞争资源呢?

CPU切不切换我们没法控制,只能提高线程优先级以获取更多的CPU时间。
CPU除了处理java还需要处理N多系统和其他线程,一般而言多线程编程中,在确保内存不溢出的情况下提升线程数是可以提高CPU中签率,也就是能提高你的程序处理数据的速度。
不过,即使没溢出,也不是线程数越大越好,线程切换毕竟需要时间,应该找到瓶颈所在。例如如果大部分线程都在等待同步模块的执行,那么瓶颈就是同步模块,这时候应该减少线程数或者优化同步模块。
调试方式可以用打时间的方式,观察线程在哪个地方执行时间最长,然后找到原因,同时能判断线程数量是大了还是小了。

您的讲解让我很受益,我想问的是,
这种监控线程执行时间长短,使用什么工具呢?JMeter?还是JavaMoledy?

多线程编程,如何确定线程数,依据是什么
10分
如果你想要固定有多少个线程,建议你用线程池,这个可以避免线程过多导致程序负担加大。。。。API中有方法可以获取当前线程的,可以查查
多线程编程,如何确定线程数,依据是什么
引用 6 楼 hl1990712 的回复:

如果你想要固定有多少个线程,建议你用线程池,这个可以避免线程过多导致程序负担加大。。。。API中有方法可以获取当前线程的,可以查查

嗯,线程池,也需要设置一个大小,是吧。我现在就是比较迷惑,这个大小确定,可以依靠什么工具,或者思想。

多线程编程,如何确定线程数,依据是什么
20分
1.确定最佳线程数量
首先确定应用是CPU密集型 (例如分词,加密等),还是耗时io( 网络,文件操作等)
CPU密集型:: 最佳线程数等于cpu核心数或稍微小于cpu核心数。。。具体数值要以jvm图形线程监控显示繁忙情况为依据。。

耗时io型:: 最佳线程数一般会大于cpu核心数很多倍。。一般是io设备延时除以cpu处理延时,得到一个倍数,我的经验数值是20–50倍*cpu核心数,,具体数值也是要以jvm图形线程监控显示繁忙情况为依据。。保证线程空闲可以衔接上。。。

最佳线程数量也与机器配置(内存,磁盘速度)有关,如果cpu,内存,磁盘任何一个达到顶点,就需要适当减少线程数。。

2./////使用多线程的原因

1.防止界面卡死.
提高用户的用户体验
对单核CPU,对客户端软件,采用多线程,主要是 创建多线程将一些计算放在后台执行,而不影响用户交互操作。(用户界面 & 其他计算 并行进行)提高用户的操作性能!

2.耗时的操作(io,网络io等)使用线程,提高cpu使用率..
I/O操作不仅包括了直接的文件、网络的读写,还包括数据库操作、Web Service、HttpRequest以及.net Remoting等跨进程的调用。
要是不使用多线程,你回发现cpu使用率很空闲..

3.多CPU(核心)中,使用线程提高CPU利用率
?使多CPU系统更加有效
操作系统会保证当线程数不大于CPU数目时,不同的线程运行于不同的CPU上。
要是不使用多线程,你回发现仅仅一个cpu很忙碌的,其他cpu使用率很空闲..

3.////////////不适用多线程的情况,

1.你的代码是cpu密集型,在单核cpu上..
2.单核cpu上,线程的使用(滥用)会给系统带来上下文切换的额外负担。并且线程间的共享变量可能造成死锁的出现。
3.当需要执行I/O操作时,使用异步操作常常比使用线程+同步I/O操作更合适。

多线程编程,如何确定线程数,依据是什么
16分
对于耗时io型,一个简单的算法::最佳线程数==单个线程的黄色时间块长度(空闲) / 绿色时间块长度(繁忙) * cpu核心数
多线程编程,如何确定线程数,依据是什么
10分
线程图形化监控工具:: 可以用jprofile  ,,,磁盘队列图形化监控工具:::任务管理器》》资源监视器》》磁盘队列深度
多线程编程,如何确定线程数,依据是什么
楼上的哥们儿,谢了哈
多线程编程,如何确定线程数,依据是什么
15分
哥们,这个问题有点范,我按照我理解的给你答复下。JAVA语言多线程的实现方式有两种,一种是写继承Thread类的方式,一种是实现Runnable接口的方式。使用java语言编程开启几个线程可以由你自己来定义,另外主方法main是JAVA语言应用程序的入口,JVM会找到这个东西,他也是一个线程,还要附加上JVM中负责垃圾回收的线程,所以运行一个java程序,首先就已经是多线程的了,main和GC,另外定义几个线程,同时运行,就看你了。CPU原来一直是单核的,后来出了双核,现在有了四核,甚至是更多。在单核系统中,虽然实现了多线程,但是实际上还是单线程执行,CPU以极短的时间,在各个线程之间做切换,从最微观的角度来看还是单线程的执行。后来出现了双核系统,貌似是实现了多线程的实际并行,但是具体原理我没有再了解过。总之CPU多了一个核,程序执行速度快了很多。可以使用ctrl+alt+del键查看任务管理器,看一下当前系统启动了那些线程。
多线程编程,如何确定线程数,依据是什么
引用 12 楼 u011106669 的回复:

哥们,这个问题有点范,我按照我理解的给你答复下。JAVA语言多线程的实现方式有两种,一种是写继承Thread类的方式,一种是实现Runnable接口的方式。使用java语言编程开启几个线程可以由你自己来定义,另外主方法main是JAVA语言应用程序的入口,JVM会找到这个东西,他也是一个线程,还要附加上JVM中负责垃圾回收的线程,所以运行一个java程序,首先就已经是多线程的了,main和GC,另外定义几个线程,同时运行,就看你了。CPU原来一直是单核的,后来出了双核,现在有了四核,甚至是更多。在单核系统中,虽然实现了多线程,但是实际上还是单线程执行,CPU以极短的时间,在各个线程之间做切换,从最微观的角度来看还是单线程的执行。后来出现了双核系统,貌似是实现了多线程的实际并行,但是具体原理我没有再了解过。总之CPU多了一个核,程序执行速度快了很多。可以使用ctrl+alt+del键查看任务管理器,看一下当前系统启动了那些线程。

你的回复很认真,而且我也很认同你的观点,非常感谢,呵呵。
此外,我来做一下补充:在JDK、IDE里面,很多都用到了多线程。多线程编程,具体来说,应该说是对程序员的要求提高了,它要求程序员也手动编写多线程的程序。
原因很简单,信息化时代,我们要从各个方面提高程序的性能。而在一般的串行程序执行时,无论是几核处理器,串行程序都是在使用一个处理器。这违背了多核操作系统的初衷,也是对其余资源的浪费。

此外,纠正一下你最后的观点:Windows下,资源管理器查看的是的当前用户的进程,而非线程。线程的生命周期很短,我们一般只用线程处理进程中一个简单的功能。

多线程编程,如何确定线程数,依据是什么
引用 8 楼 attilax 的回复:

1.确定最佳线程数量
首先确定应用是CPU密集型 (例如分词,加密等),还是耗时io( 网络,文件操作等)
CPU密集型:: 最佳线程数等于cpu核心数或稍微小于cpu核心数。。。具体数值要以jvm图形线程监控显示繁忙情况为依据。。

耗时io型:: 最佳线程数一般会大于cpu核心数很多倍。。一般是io设备延时除以cpu处理延时,得到一个倍数,我的经验数值是20–50倍*cpu核心数,,具体数值也是要以jvm图形线程监控显示繁忙情况为依据。。保证线程空闲可以衔接上。。。

最佳线程数量也与机器配置(内存,磁盘速度)有关,如果cpu,内存,磁盘任何一个达到顶点,就需要适当减少线程数。。

2./////使用多线程的原因

1.防止界面卡死.
提高用户的用户体验
对单核CPU,对客户端软件,采用多线程,主要是 创建多线程将一些计算放在后台执行,而不影响用户交互操作。(用户界面 & 其他计算 并行进行)提高用户的操作性能!

2.耗时的操作(io,网络io等)使用线程,提高cpu使用率..
I/O操作不仅包括了直接的文件、网络的读写,还包括数据库操作、Web Service、HttpRequest以及.net Remoting等跨进程的调用。
要是不使用多线程,你回发现cpu使用率很空闲..

3.多CPU(核心)中,使用线程提高CPU利用率
?使多CPU系统更加有效
操作系统会保证当线程数不大于CPU数目时,不同的线程运行于不同的CPU上。
要是不使用多线程,你回发现仅仅一个cpu很忙碌的,其他cpu使用率很空闲..

3.////////////不适用多线程的情况,

1.你的代码是cpu密集型,在单核cpu上..
2.单核cpu上,线程的使用(滥用)会给系统带来上下文切换的额外负担。并且线程间的共享变量可能造成死锁的出现。
3.当需要执行I/O操作时,使用异步操作常常比使用线程+同步I/O操作更合适。

哥们儿,你的IO耗时型和CPU密集型对我启示很大,非常感谢呀!呵呵

多线程编程,如何确定线程数,依据是什么
10分
引用 5 楼 liu765023051 的回复:
Quote: 引用 3 楼 weinianjie1 的回复:
Quote: 引用 2 楼 liu765023051 的回复:
Quote: 引用 1 楼 ghostkngiht 的回复:

线程数量和CPU核数有关,网上有建议说线程数为核数的两倍最好。其实只要这些线程不频繁切换和竞争资源的话线程多点也可以,想要最优性能还是根据具体项目慢慢调试吧。

嗯,我也听过两倍CPU核数的观点,但是不敢苟同。这个应该收到 项目中多线程这块儿比重的影响。

那么,在项目中,如何调试(工具?还是其他的什么思想思路?)性能最优,避免频繁切换线程、竞争资源呢?

CPU切不切换我们没法控制,只能提高线程优先级以获取更多的CPU时间。
CPU除了处理java还需要处理N多系统和其他线程,一般而言多线程编程中,在确保内存不溢出的情况下提升线程数是可以提高CPU中签率,也就是能提高你的程序处理数据的速度。
不过,即使没溢出,也不是线程数越大越好,线程切换毕竟需要时间,应该找到瓶颈所在。例如如果大部分线程都在等待同步模块的执行,那么瓶颈就是同步模块,这时候应该减少线程数或者优化同步模块。
调试方式可以用打时间的方式,观察线程在哪个地方执行时间最长,然后找到原因,同时能判断线程数量是大了还是小了。

您的讲解让我很受益,我想问的是,
这种监控线程执行时间长短,使用什么工具呢?JMeter?还是JavaMoledy?

线程消纵即逝,用工具不容易监控,用日志反而方便,jMeter只能监控当前资源占用而已,常规工具对消逝的线程是没有记录的,你要找到好宝贝可以贴出来分享。


CodeBye 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权 , 转载请注明多线程编程,如何确定线程数,依据是什么
喜欢 (0)
[1034331897@qq.com]
分享 (0)

文章评论已关闭!