线程这个词似乎听起来并不是很好理解,但是说到进程,我想大家应该不会陌生,我们在使用windows操作系统时,每当遇到某个软件运行出现卡顿的现象,我们最经常做的就是打开我们的任务管理器来结束相关进程,如下图中映像名称列中的是我的电脑目前正在运行的一部分进程,红线框出的是firefox浏览器的进程,
如果我的浏览器出现奔溃,就可以通过强制执行该进程,对进程有了一个形象上的认识之后,接下来说一下线程,线程可以简单的看成进程中在运行的程序所做的某一件事情,反过来可以理解成一个进程中可以有多个线程同时在工作,例如我们用下载工具(迅雷,电驴等)从网络上下载资源的时候,可以同时(这里给我们同时的感觉实际上是CPU在多个线程之间做着快速的切换,我们人眼看上去好像是同时在进行下载一样,当然多核的CPU除外)下载多个资源,每个下载的资源可以看成是一个线程,正在执行下载任务的迅雷则可以看成是一个进程,二者之间的关系与区别可以参考:http://blog.csdn.net/pyjfoot/article/details/7389389
Java中的多线程可以像上面所说的那样的在一个程序中同时运行多个任务,例如我们可以一边打印一些字符串,一边计算一些数的和值,并不用等到都打印完字符串后,才来计算和值,在Java中,创建线程有2种方式
1、将类声明为 Thread
的子类。该子类应重写 Thread
类的 run
方法。例如,计算大于某一规定值的质数的线程可以写成:
class PrimeThread extends Thread { long minPrime; PrimeThread(long minPrime) { this.minPrime = minPrime; } public void run() { // compute primes larger than minPrime } }
下列代码会创建并启动一个线程:
PrimeThread p = new PrimeThread(143); p.start();
2、声明实现 Runnable
接口的类,并实现run()方法
class PrimeThread implements Runnable { long minPrime; PrimeThread(long minPrime) { this.minPrime = minPrime; } public void run() { // compute primes larger than minPrime } }
下列代码会创建并启动一个线程:
PrimeRun p = new PrimeRun(143); new Thread(p).start();
下面简单给出一个多线程的例子:
public class ThreadDemo { public static void main(String[] args) { // 创建好一个线程 Demo d = new Demo(); d.start(); //并不一定立即执行,要看此时该线程是否已经获得CPU资源,如果没有,则处于就绪状态 // d.run(); //仅仅是对象的调用方法,而线程创建了,并没有运行,相当于简单的运行了类的某个方法 for (int i = 0; i < 500; i++) { System.out.println("main --- " + i); } } } class Demo extends Thread { public void run() { for (int i = 0; i < 500; i++) System.out.println("demo run --- " + i); } }
由于结果较长,这里截取交替运行的一部分
可以看出2个线程在交替的打印信息
相关推荐
Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式...
Java多线程读大文件 java多线程写文件:多线程往队列中写入数据
java多线程PPT 多线程基本概念 创建线程的方式 线程的挂起与唤醒 多线程问题
一个java 多线程操作数据库应用程序!!!
java多线程经典案例,线程同步、线程通信、线程阻塞等经典案例
《Java多线程编程核心技术》建议猿友们读两遍,因为其写得没有那么抽象,第一遍有些概念不是很理解,可以先跳过并记录起来,第一遍阅读的目的主要是了解整个架构。第二遍再慢慢品味,并贯穿全部是指点来思考,并将...
Java多线程编程实战指南(核心篇) 高清pdf带目录 随着现代处理器的生产工艺从提升处理器主频频率转向多核化,即在一块芯片上集成多个处理器内核(Core),多核处理器(Multicore Processor)离我们越来越近了――如今...
该文档总结了Java多线程相关的知识点,分享给大家,简单易懂!
详细的讲解了java多线程的原理,并配有代码进行实战,适合java初学者和想对多线程有进一步了解的人。
一张图方便理解和掌握java 多线程之间通信的实质 java 多线程 其实就是每个线程都拥有自己的内存空间,多线程之间的通信,比例A线程修改了主内存(main方法的线程)变量,需要把A线程修改的结果同步到主线程中,...
java多线程处理数据库数据,使用并发包,无框架,可批量处数据库数据,进行增删改。。等等操作。
java多线程,对多线程,线程池进行封装,方便使用
现在的操作系统是多任务操作系统。多线程是实现多任务的一种方式。 线程是指进程中的一个执行流程,一个进程中可以运行多个线程。...本文档提供Java多线程编程经验,方便广大Java爱好者研究学习Java多线程
java多线程处理大数据,可根据配置的线程数,任务去调度处理
java多线程并发的在新窗口
Java多线程机制 9.1 Java中的线程 9.2 Thread的子类创建线程 9.3 使用Runable接口 9.4 线程的常用方法 9.5 GUI线程 9.6 线程同步 9.7 在同步方法中使用wait()、notify 和notifyAll()方法 9.8 挂起、恢复和终止线程 ...
资深Java专家10年经验总结,全程案例式讲解,首本全面介绍Java多线程编程技术的专著 结合大量实例,全面讲解Java多线程编程中的并发访问、线程间通信、锁等最难突破的核心技术与应用实践 Java多线程无处不在,如...
java多线程实现大批量数据切分成指定份数的数据,然后多线程处理入库或者导出,线程的个数和每份数据的数量都可以控制
java多线程并发查询数据库,使用线程池控制分页,并发查询。
java多线程模拟队列实现排队叫号,多线程模拟排队叫号取号 java多线程模拟队列实现排队叫号,多线程模拟排队叫号取号