需求:
用多线程去获得一个网站取得的数据,网站数据分页显示,一个线程读取几页。通过构造函数把读取的开始页数赋值。
public class SelectPhone extends Thread{
int a = 0; //这里无需担心多线程安全的问题,因为这里是多实例的,在main函数
//中生成的是5个对象,而不是想Spring注入那样共用一个实例。所以每个实例的a都不同
public SelectPhone(int flag){
a = flag;
};
public static void main(String[] args){
SelectPhone s = new SelectPhone(0);
SelectPhone s1 = new SelectPhone(2);
SelectPhone s2 = new SelectPhone(5);
SelectPhone s3 = new SelectPhone(8);
SelectPhone s4 = new SelectPhone(11);
System.out.println("a="+s.a);
System.out.println("a="+s1.a);
System.out.println("a="+s2.a);
System.out.println("a="+s3.a);
System.out.println("a="+s4.a); //这里相继输出0,2,5,8,11,
s.start();
s1.start();
s2.start();
s3.start();
s4.start();
}
public void run(){
System.out.println("begin"+System.currentTimeMillis()+"~~~~"+a);
String returnStr = null;
String searchStr[] = new String[750];
System.out.println("a="+a); //最后输出的结果可能为a=2,a=0,a=8,a=11,a=5这种不按顺序的,
for(int page=a;page<a+3;page++) 因为不一定哪个线程会先执行到这里
{
................
}
}
}
另附一遍详解java多线程性能的文章
java多线程性能浅析 - 一篇把线程描述得很形象的文章
今天看见je上一帖,对于上亿数据求和的算法,采用多线程到底快还是慢,我认为需要按情况而定。 1.单核,无IO,网络等资源操作情况下 结果:多线程比单线程理论上要慢 原因:多线程启动线程需要消耗cpu资源,多线程只是把这一计算过程分片,在同一时刻只会有一个线程占有cpu,所以采用多线程不但在启动时耗费资源,在线程调度上同样也耗费时间。所以单线程比多线程理论上要快。 2.单核,有IO,网络等资源操作情况下 结果:多线程比单线程理论上要快 原因:如果这上亿数据需要从文件中或者网络的其它地方(数据库)获取,在IO和网络操作的时候,由于IO和网络操作比cpu慢的多,所以cpu等待io操作;多线程的时候,当一个线程io读取部分数据的时候,其它线程可以进行计算。而单线程需要等待文件读取完成后进行计算。所以理论上多线程要快。 3.多核,无IO,网络等资源操作情况下 结果:不确定 原因:在大部分操作系统上,一个进程的多个线程可以分配到多个cpu上并行处理所以多线程理论上比单线程快;在部分的操作系统上不支持一个进程的多个线程分配到多个cpu上并行处理,根据1的结果可以看出多线程理论上比单线程慢。 4.多核,有IO,网络等资源操作情况下 结果:多线程比单线程理论上要快 原因:如果操作系统支持一个进程的多个线程分配到多个cpu上并行处理,则多线程比单线程理论上要快。 如果操作系统不支持一个进程的多个线程分配到多个cpu上并行处理,则多线程比单线程理论上要快,根据2的结果得出。 拿je上高手们的一个例子:挖山洞,我扩展下。 单核,单线程,有IO:相当于从山的一侧进行挖掘工作,工作者需要挖5分钟,然后花费5分钟,用小车将土运出。 单核,多线程,有IO:相当于从山的一侧进行挖掘工作,工作者需要挖5分钟,然后花费5分钟,用小车将土运出,运土的时候,另一个工作者开始挖掘; 双核,单线程,有IO:相当于从山的两侧一个工作者进行挖掘工作,工作者需要挖5分钟,然后花费5分钟,用小车将土运出; 双核,多线程,有IO:相当于从山的两侧两个工作者进行挖掘工作,工作者需要挖5分钟,然后花费5分钟,用小车将土运出; 单核,单线程,无IO:相当于一个工作者从山的一侧进行挖掘工作。 单核,多线程,无IO:相当于两个工作者从山的一侧进行挖掘工作,一个挖会休息,另一个歇息。 双核,单线程,无IO:相当于从山的两侧一个工作者进行挖掘工作。 双核,多线程,无IO:相当于从山的两侧两个工作者进行挖掘工作。 当然有些工地只允许一个工作者工作。 例子虽然比较牵强,但也大致可以说出个理来。一年后在来分析下,看看能不能从更深的角度进行分析! 转自: http://www.iteye.com/topic/848486
|
分享到:
相关推荐
利用JAVA编写的多线程运行实例 压缩文件,可直接运行 ...利用JAVA编写的多线程运行实例 压缩文件,可直接运行利用JAVA编写的多线程运行实例 压缩文件,可直接运行利用JAVA编写的多线程运行实例 压缩文件,可直接运行
Java多线程是Java编程中的重要概念,尤其在并发编程领域有着广泛的...通过对"java多线程实例"的学习,开发者可以深入理解线程的工作原理,提升解决并发问题的能力,这对于开发高并发的网络服务、数据库应用等至关重要。
总结起来,"Java多线程实例图形版"是一个结合理论与实践的教学资源,通过“哲学家就餐问题”这一经典案例,帮助开发者理解多线程的基本概念、并发问题以及解决策略。通过学习这个实例,不仅可以掌握Java多线程编程的...
Java 多线程实例 Java 多线程是Java编程语言的一个重要特性,它使得程序能够在同一时间执行多个任务,从而提高系统效率和资源利用率。本文将深入探讨Java中的线程概念、创建线程的方式以及如何实现线程的并发执行。...
总的来说,这个"java多线程实例"是一个实用的学习资源,它展示了如何利用Java的多线程特性进行高效的网络下载,并通过合理的线程同步和文件操作来实现资源的合并。对于想要深入理解Java多线程和网络编程的开发者来说...
Java多线程是Java编程中的重要概念,尤其在如今的多核处理器环境下,理解并熟练掌握多线程技术对于提高程序性能和响应速度至关重要。本资料详细讲解了Java多线程的原理,并提供了丰富的实战代码,非常适合Java初学者...
在Java编程语言中,多线程是核心特性之一,它允许程序同时执行多个任务,从而提高了应用程序的效率和响应...文档“java多线程实例.docx”可能包含具体的示例代码和详细解释,建议参考学习,以加深对Java多线程的理解。
《哲学家就餐:Java多线程实例图形版》是一个经典的多线程问题,它通过模拟哲学家们在用餐时可能出现的饥饿情况,来探讨和解决并发编程中的资源竞争问题。这个例子源自计算机科学家Edsger W. Dijkstra,他提出了这个...
根据提供的文件信息,我们可以归纳出以下关于Java多线程的经典示例中的关键知识点: ### Java多线程实现方式 在Java中,实现多线程有两种主要的方法:通过继承`Thread`类或者实现`Runnable`接口。 #### 继承...
Java多线程是Java编程中的重要概念,它允许程序同时执行多个任务,提高了程序的效率和响应性。在Java中,实现多线程有两种主要方式:通过继承`Thread`类和实现`Runnable`接口。 1. 继承Thread类: 当你需要创建一...
java多线程例子(1).pdf java多线程例子(1).pdf java多线程例子(1).pdf
Java多线程是Java编程中的重要概念,它允许程序同时执行多个任务,提高了程序的效率和响应性。在Java中,实现多线程有两种主要方式:通过实现`Runnable`接口或者继承`Thread`类。 首先,让我们从创建线程开始。当你...
java多线程实例下载,直接导入到eclipse即可java多线程实例下载,直接导入到eclipse即可java多线程实例下载,直接导入到eclipse即可java多线程实例下载,直接导入到eclipse即可
本文将基于"java 多线程并发实例"这个主题,深入探讨Java中的多线程并发概念及其应用。 首先,我们要了解Java中的线程。线程是程序执行的基本单元,每个线程都有自己的程序计数器、虚拟机栈、本地方法栈,而共享堆...
在Java多线程编程中,理解如何创建和...总的来说,这个例子展示了Java多线程的基本操作,包括创建、启动、管理和通信。理解和掌握这些概念对于进行并发编程是至关重要的,可以帮助开发者构建高效、稳定的多线程应用。