线程/Handle详解

2017-06-03  本文已影响118人  提升即效率

线程(Thread)简介

run()// 包含线程运行时所执行的代码
start()// 用于启动线程
sleep()/sleep(long millis)// 线程休眠,交出CPU,让CPU去执行其他的任务,然后线程进入阻塞状态,sleep方法不会释放锁
yield()// 使当前线程交出CPU,让CPU去执行其他的任务,但不会是线程进入阻塞状态,而是重置为就绪状态,yield方法不会释放锁
join()/join(long millis)/join(long millis,int nanoseconds)// 等待线程终止,直白的说 就是发起该子线程的线程 只有等待该子线程运行结束才能继续往下运行
wait()// 交出cpu,让CPU去执行其他的任务,让线程进入阻塞状态,同时也会释放锁
interrupt()// 中断线程,自stop函数过时之后,我们通过interrupt方法和isInterrupted()方法来停止正在运行的线程,注意只能中断已经处于阻塞的线程
getId()// 获取当前线程的ID
getName()/setName()// 获取和设置线程的名字
getPriority()/setPriority()// 获取和这是线程的优先级 一般property用1-10的整数表示,默认优先级是5,优先级最高是10,优先级高的线程被执行的机率高
setDaemon()/isDaemo()// 设置和判断是否是守护线程
currentThread()// 静态函数获取当前线程

Handle 简介

Handle内部解析

实际用法

1,首先第一种启用方法是通过继承Thread类,并改写run方法来实现一个线程

public classMyThreadextendsThread {

//继承Thread类,并改写其run方法

private final staticStringTAG="My Thread ===> ";

public voidrun(){

Log.d(TAG,"run");

for(inti =0; i<100; i++)

{

Log.e(TAG, Thread.currentThread().getName() +"i =  "+ i);

}

}

}

启动

newMyThread().start();

2,第二种启用方式创建一个Runnable对象

public classMyRunnableimplementsRunnable{

private final staticStringTAG="My Runnable ===> ";

@Override

public voidrun() {

//TODO Auto-generated method stub

Log.d(TAG,"run");

for(inti =0; i<1000; i++)

{

Log.e(TAG, Thread.currentThread().getName() +"i =  "+ i);

}

}

}

启动

newThread(new MyRunnable()).start();

3, 第三种启用方式通过Handler启动线程

public classMainActivityextendsActivity {

private final staticStringTAG="UOfly Android Thread ==>";

private intcount=0;

privateHandlermHandler=newHandler();

privateRunnablemRunnable=newRunnable() {

public voidrun() {

Log.e(TAG, Thread.currentThread().getName() +" "+count);

count++;

setTitle(""+count);

//每3秒执行一次

mHandler.postDelayed(mRunnable,3000);//给自己发送消息,自运行

}

};

/** Called when the activity is first created. */

@Override

public voidonCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.main);

//通过Handler启动线程

mHandler.post(mRunnable);//发送消息,启动线程运行

}

@Override

protected voidonDestroy() {

//将线程销毁掉

mHandler.removeCallbacks(mRunnable);

super.onDestroy();

}

}
上一篇 下一篇

猜你喜欢

热点阅读