Java Runnable线程如何才能更好的适应目前的编程环境呢?下面我们就看看如何才能更好的进行相关环境希望下面的文章对大家有所帮助Java Runnable线程接口只有一个方法run()我们声明自己的类实现Runnable接口并提供这一方法
将我们的线程代码写入其中就完成了这一部分 的任务但是Runnable接口并没有任何对线程的支持我们还必须创建Thread类的实例这一点通过Thread类的构造函 数 public Thread(Runnable target);来实现
下面是一个例子
public class MyThread implements Runnable
{
int count= number;
public MyThread(int num)
{
numnumber = num;
Systemoutprintln(创建线程 + number);
}
public void run()
{
while(true)
{
Systemoutprintln
(线程 + number + :计数 + count);
if(++count== ) return;
}
}
public static void main(String args[])
{
for(int i = ; i 〈 ;
i++) new Thread(new MyThread(i+))start();
}
}
严格地说创建Thread子类的实例也是可行的但是必须注意的是该子类必须没有覆盖 Thread 类的 run 方法否则该线程执行的将是子类的 run 方法而不是我们用以实现Java Runnable线程接口的类的 run 方法对此大家不妨试验一下
使用 Runnable 接口来实现多线程使得我们能够在一个类中包容所有的代码有利于封装它的缺点在于我们只能使用一套代码若想创建多个线程 并使各个线程执行不同的代码则仍必须额外创建类如果这样的话在大多数情况下也许还不如直接用多个类分别继承 Thread 来得紧凑
综上所述两种方法各有千秋大家可以灵活运用下面让我们一起来研究一下多线程使用中的一些问题
Java Runnable线程的四种状态
新状态线程已被创建但尚未执行(start() 尚未被调用)
可执行状态线程可以执行虽然不一定正在执行CPU 时间随时可能被分配给该线程从而使得它执行
死亡状态正常情况下 run() 返回使得线程死亡调用 stop()或 destroy() 亦有同样效果但是不被推荐前者会产生异常后者是强制终止不会释放锁
阻塞状态线程不会被分配 CPU 时间无法执行