Android 中三种启用线程的方法

27 篇文章 0 订阅

多线程就是分时利用CPU,宏观上让所有线程一起执行 ,也叫并发
先调用start后调用run

1.start()方法来启动线程,真正实现了多线程运行。
这时无需等待run方法体代码执行完毕,可以直接继续执行下面的代码
通过调用Thread类的start()方法来启动一个线程, 这时此线程是处于就绪状态, 并没有运行
然后通过此Thread类调用方法run()来完成其运行操作的
这里方法run()称为线程体,它包含了要执行的这个线程的内容
Run方法运行结束, 此线程终止。然后CPU再调度其它线程
2.run()方法当作普通方法的方式调用
程序还是要顺序执行,要等待run方法体执行完毕后,才可继续执行下面的代码
程序中只有主线程——这一个线程, 其程序执行路径还是只有一条, 这样就没有达到写线程的目的。

Runnable是一个接口
Thread是Runnable的子类
HandlerThread就是可以处理消息循环的线程,是一个拥有Looper的线程,可以处理消息循环
Handler是沟通Activity 与Thread/runnable的桥梁。而Handler是运行在主UI线程中的,它与子线程可以通过Message对象来传递数据

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

    //继承Thread类,并改写其run方法        
    private final static String TAG = "My Thread ===> ";      
    public void run(){  
        Log.d(TAG, "run");  
        for(int i = 0; i<100; i++)  
        {  
            Log.e(TAG, Thread.currentThread().getName() + "i =  " + i);  
        }  
    }  
} 

调用启动

new MyThread().start();  

运行结果:

	1
	1
2,第二种启用方式创建一个Runnable对象
public class MyRunnable implements Runnable{  
    private final static String TAG = "My Runnable ===> ";  

    @Override  
    public void run() {  
        // TODO Auto-generated method stub  
        Log.d(TAG, "run");  
        for(int i = 0; i<1000; i++)  
        {  
            Log.e(TAG, Thread.currentThread().getName() + "i =  " + i);  
        }  
    }  
} 

调用启动

 new Thread(new MyRunnable()).start(); 

运行结果:

	1
	1
3, 第三种启用方式通过Handler启动线程
public class MainActivity extends Activity {      
    private final static String TAG = "UOfly Android Thread ==>";  
    private int count = 0;  
    private Handler mHandler = new Handler();  
    private Runnable mRunnable = new Runnable() {  
        public void run() {  
            Log.e(TAG, Thread.currentThread().getName() + " " + count);  
            count++;  
            setTitle("" + count);  
            // 每3秒执行一次  
            mHandler.postDelayed(mRunnable, 3000);  //给自己发送消息,自运行
        }  
    };  
    /** Called when the activity is first created. */  
    @Override  
    public void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        setContentView(R.layout.main);  
        // 通过Handler启动线程  
        mHandler.post(mRunnable);  //发送消息,启动线程运行
    }  

      @Override      
         protected void onDestroy() {       
             //将线程销毁掉       
             mHandler.removeCallbacks(mRunnable);       
             super.onDestroy();       
         }       

} 
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Tan.]der

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值