线程/Handle详解

线程(Thread)简介

  • 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()// 静态函数获取当前线程

  • Thread线程主要状态

    ( 1)New一旦被实例化之后就处于new状态
    ( 2)Runnable调用了start函数之后就处于Runnable状态
    ( 3)Running线程被cpu执行 调用run函数之后 就处于Running状态
    ( 4 ) Blocked调用join()、sleep()、wait()使线程处于Blocked状态
    ( 5 ) Dead线程的run()方法运行完毕或被中断或被异常退出,线程将会到达Dead状态

Handle 简介

Handle内部解析

  • 主要函数:

    sendMessage()可以延伸的方法
    sendMessageAtTime(Message msg, long uptimeMillis)在指定时间uptimeMillis时发送消息msg;
    sendMessageDelayed(Message msg, long delayMillis)延迟delayMillis时间后发送消息msg
    **sendEmptyMessage(int what) **发送一个指定类型what的空消息;
    sendEmptyMessageAtTime(int what, long uptimeMillis)在指定时间uptimeMillis时发送一条指定类型what的空消息;
    sendEmptyMessageDelayed(int what, long delayMillis)延迟delayMillis时间后发送一条指定类型what的空消息;
    sendMessageAtFrontOfQueue(Message msg)在消息队列头(优先)发送这条消息msg;
    同样,post()可以延伸的方法
    postAtTime(Runnable r, long uptimeMillis)
    postAtTime(Runnable r, Object token, long uptimeMillis)
    postDelayed(Runnable r, long delayMillis)
    postAtFrontOfQueue(Runnable r)
    请自行查阅相应方法,这里不予一一列出。

实际用法

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();

}

}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容