本文主要是介绍java4Android(17)(18) 多线程两种实现方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
如何定义一个线程类,进入到线程等待状态
例子:
class FirstThread extends Thread
{public void run(){for(int i = 0; i < 100;i++){System.out.println("FirstThread" + i); }}
}
class test
{public static void main(String args[]){//创建线程FirstThread ft = new FirstThread();//start后进入到等待状态ft.start();//千万不能这样写ft.run();这样是一个线程一个线程执行的,先是FirstThread从0-99然后main线程0-99for(int i = 0;i<100;i++){System.out.println("main" + i);}}
}
第二种实现多线程的方法,此种方法更常用
class ThreadImp implements Runnable
{public void run(){for(int i = 0;i<100 ; i++){System.out.println("Runnable -> " + i);}}
}
class test
{public static void main(String[] args){//生成一个runnable 接口实现类的对象//生成一个Thread类的对象并将Runnable接口实现类的对象作为参数传递给该Thread对象。//通知Trhead对象执行start();ThreadImp ti = new ThreadImp();Thread t = new Thread(ti);t.start();}
}
终端线程:
Thread.sleep();线程体执行这个后就释放cpu,休眠指定参数的毫秒数,当休眠到了,该线程处于就绪状态,而不是说它立刻又拥有cpu资源了,因为cpu不是为某一个特定线程而准备的。
Thread.yield();让当前执行到此处的线程释放cpu,看起来具有雷锋精神,实则不然,它意味着多个线程再次重新抢占资源,也就是说并不是该线程不会再次拥有cpu去执行。
当线程公用统一线程体共享数据时会出现安全问题
Thread t = new Thread(ti);
。需要用线程锁。
这篇关于java4Android(17)(18) 多线程两种实现方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!