博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java Thread 的使用
阅读量:7116 次
发布时间:2019-06-28

本文共 2375 字,大约阅读时间需要 7 分钟。

写俄罗斯方块游戏的时候用线程遇到一点问题。

如果一个类继承Thread,则不适合资源共享。但是如果实现了Runable接口的话,则很容易的实现资源共享。

实现Runnable接口比继承Thread类所具有的优势:

1):适合多个相同的程序代码的线程去处理同一个资源

2):可以避免java中的单继承的限制

3):增加程序的健壮性,代码可以被多个线程共享,代码和数据独立

(附)start 和 run 方法解释:   

1) start:
  用start方法来启动线程,真正实现了多线程运行,这时无需等待run方法体代码执行完毕而直接继续执行下面的代码。通过调用Thread类的start()方法来启动一个线程,这时此线程处于就绪(可运行)状态,并没有运行,一旦得到cpu时间片,就开始执行run()方法,这里方法 run()称为线程体,它包含了要执行的这个线程的内容,Run方法运行结束,此线程随即终止。
2) run:
  run()方法只是类的一个普通方法而已,如果直接调用Run方法,程序中依然只有主线程这一个线程,其程序执行路径还是只有一条,还是要顺序执行,还是要等待run方法体执行完毕后才可继续执行下面的代码,这样就没有达到写线程的目的。总结:调用start方法方可启动线程,而run方法只是thread的一个普通方法调用,还是在主线程里执行。这两个方法应该都比较熟悉,把需要并行处理的代码放在run()方法中,start()方法启动线程将自动调用 run()方法,这是由jvm的内存机制规定的。并且run()方法必须是public访问权限,返回值类型为void。

直接看代码:

1、继承Thread的demo

package com.multithread.learning;/** *多线程学习,继承Thread,资源不能共享 *@author */class Thread1 extends Thread{	private int count=5;	private String name;    public Thread1(String name) {       this.name=name;    }	public void run() {        for (int i = 0; i < 5; i++) {            System.out.println(name + "运行  count= " + count--);            try {                sleep((int) Math.random() * 10);            } catch (InterruptedException e) {                e.printStackTrace();            }        }       	}}public class Main {	public static void main(String[] args) {		Thread1 mTh1=new Thread1("A");		Thread1 mTh2=new Thread1("B");		mTh1.start();		mTh2.start();	}} 2、实现Runnable的demo
/** *多线程学习 实现runnable,资源能共享 *@author  */package com.multithread.runnable;class Thread2 implements Runnable{    private int count=15;	@Override	public void run() {		  for (int i = 0; i < 5; i++) {			  System.out.println(Thread.currentThread().getName() + "运行  count= " + count--);	            try {	            	Thread.sleep((int) Math.random() * 10);	            } catch (InterruptedException e) {	                e.printStackTrace();	            }	        }	}	}public class Main {	public static void main(String[] args) {		Thread2 mTh = new Thread2();	        new Thread(mTh, "C").start();//同一个mTh,但是在Thread中就不可以,如果用同一个实例化对象mt,就会出现异常   	        new Thread(mTh, "D").start();	        new Thread(mTh, "E").start();	}}
//这里要注意每个线程都是用同一个实例化对象,如果不是同一个,效果就和上面的一样了!

提醒一下大家:main方法其实也是一个线程。在java中所有的线程都是同时启动的,至于什么时候,哪个先执行,完全看谁先得到CPU的资源。

在java中,每次程序运行至少启动2个线程。一个是main线程,一个是垃圾收集线程。因为每当使用java命令执行一个类的时候,实际上都会启动一个jvm,每一个jvm实际上就是在操作系统中启动了一个进程。

转载于:https://www.cnblogs.com/enjong/articles/8479213.html

你可能感兴趣的文章
数据事物嵌套实验和结论
查看>>
linux LVS
查看>>
LAMP平台部署及应用(二) -- 构建Discuz!论坛服务器
查看>>
反向代理负载均衡模块详述
查看>>
Shell脚本--监控mysql的队列,队列超过300告警
查看>>
HttpClient4.x send request over SSL
查看>>
天益SSL /IPSEC ×××网关设备
查看>>
Ubuntu Server 18.04 通过 nvm 安装 node
查看>>
NSArray数组
查看>>
Apache2.0x 开启gzip压缩
查看>>
关于驰骋表单设计器导入导出问题解决方案
查看>>
利用 XNA 实现 Windows Phone 7 上的电流效果
查看>>
phpcms学习
查看>>
Ubuntu13.10更新源
查看>>
我的友情链接
查看>>
java设计模式-工厂方法模式
查看>>
Java反射机制
查看>>
oVirt 杰云J60使用测试记录
查看>>
【OAuth2学习之路】Spring Security OAuth官网文档翻译
查看>>
Toad for DB2设置
查看>>