`
zds420
  • 浏览: 197942 次
  • 性别: Icon_minigender_1
  • 来自: 合肥
社区版块
存档分类
最新评论

JAVA 多线程之Thread和Runnable

    博客分类:
  • J2SE
阅读更多

 

 

在理解Java多线程,先了解多任务,多线程,单进程,多进程。属于操作系统的范畴。是利用google技术可以搜索很多。

 

 

为什么需要使用多线程呢? 曰:计算机最大的限度最大的效率利用CPU资源。

 

总结:操作系统可以同时处理多个任务,但是CPU只能处理一件事情。

 

 

java 和多线程

 

1:使用java.lang.Thread类

2:使用java.lang.Runnable接口

 

 

package demo.com.thread;

/**
 *  
 *  Java使用线程可以使用两种方法:
 *  1)通过使用java.lang.Thread类实现
 *  2)通过使用java.lang.Runnable接口实现
 *
 */

/**
 * 本实例使用Thread类实现线程
 */
public class ThreadDemo01 extends Thread {
	
	public ThreadDemo01(){
		//System.out.println(super.getName());
	}
	
	public void run() {
		System.out.println(Thread.currentThread().getId()+"====="+this.getName()+"线程 开始="+System.currentTimeMillis());
		
		//执行线程
		 
		for(int i=0;i<50;i++) {
			System.out.println(Thread.currentThread().getName()+"==="+i);
				//Runtime.getRuntime().exit(0);	//退出线程
				//this.checkAccess();	//判断当前线程是否可以修改此线程
			try {
				this.sleep(1000);
			} catch (InterruptedException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
		}
		
		System.out.println(Thread.currentThread().getId()+"====="+this.getName()+"线程 结束="+System.currentTimeMillis());
	}
	
	public static void main(String []args) {
		
		System.out.println(Thread.currentThread().getName()+" 线程开始");
		
		ThreadDemo01 test01 = new ThreadDemo01();
		test01.start();//启动线程1
		 
		ThreadDemo01 test02 = new ThreadDemo01();
		test02.start();//启动线程2
		
		System.out.println("当前线程中活动线程的数目:"+test01.activeCount());	//3 标识主线程 ,test01,test02 3个线程
		
		System.out.println(Thread.currentThread().getName()+" 线程结束");
		
	}
}

 

 

写道
线程执行的结果:线程执行的结果是随机的


main 线程开始
8=====Thread-0线程 开始=1321953171734
Thread-0===0
当前线程中活动线程的数目:3
9=====Thread-1线程 开始=1321953171734
Thread-1===0
main 线程结束
Thread-0===1
Thread-1===1
Thread-1===2
Thread-0===2
Thread-1===3
Thread-0===3
Thread-1===4
Thread-0===4
Thread-1===5
Thread-0===5
Thread-1===6
Thread-0===6
Thread-1===7
Thread-0===7
Thread-1===8
Thread-0===8
Thread-0===9
Thread-1===9
Thread-0===10
Thread-1===10
Thread-1===11
Thread-0===11
Thread-1===12
Thread-0===12
Thread-1===13
Thread-0===13
Thread-0===14
Thread-1===14
Thread-0===15
Thread-1===15
Thread-0===16
Thread-1===16
Thread-0===17
Thread-1===17
Thread-0===18
Thread-1===18
Thread-0===19
Thread-1===19
Thread-0===20
Thread-1===20
Thread-0===21
Thread-1===21
Thread-0===22
Thread-1===22
Thread-0===23
Thread-1===23
Thread-0===24
Thread-1===24
Thread-0===25
Thread-1===25
Thread-0===26
Thread-1===26
Thread-0===27
Thread-1===27
Thread-1===28
Thread-0===28
Thread-1===29
Thread-0===29
Thread-0===30
Thread-1===30
Thread-0===31
Thread-1===31
Thread-0===32
Thread-1===32
Thread-1===33
Thread-0===33
Thread-0===34
Thread-1===34
Thread-0===35
Thread-1===35
Thread-0===36
Thread-1===36
Thread-1===37
Thread-0===37
Thread-1===38
Thread-0===38
Thread-1===39
Thread-0===39
Thread-1===40
Thread-0===40
Thread-1===41
Thread-0===41
Thread-1===42
Thread-0===42
Thread-1===43
Thread-0===43
Thread-1===44
Thread-0===44
Thread-1===45
Thread-0===45
Thread-1===46
Thread-0===46
Thread-1===47
Thread-0===47
Thread-1===48
Thread-0===48
Thread-1===49
Thread-0===49
9=====Thread-1线程 结束=1321953221734
8=====Thread-0线程 结束=1321953221750
 
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics