Thread总结:一直以来用thread比较多,一般会在同步以及ui中用到.以下对于经常用作为简单介绍.

一 实现方法:

一种直接new thread,另外一种是实现Runnable接口,在创建thread的时候将Runnable直接丢进去即可.另外从java的唯一继承性那么用runnable更适合.

Example:

public class MainActivity extends Activity {
    Thread thread1;
    Thread thread2;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        operateThread();
        thread1.start();
        thread2.start();
    }

    public void operateThread(){
        Log.d("ThreadTest", "threadGroup");
        thread1 = new Thread(new Runnable(){
            public void run(){
                while(true){
                    Log.d("ThreadTest","thread_1.running: ");
                    try {
                        Thread.sleep(4000);
                    } catch (InterruptedException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                    }
                }
            }
        });
        
        class MyRunnable implements Runnable {
            public void run(){
                while(true){
                    Log.d("ThreadTest","thread_2.running: ");
                    //Thread.yield();
                    try {
                        Thread.sleep(4000);
                    } catch (InterruptedException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                    }
                }
            }
        }
        thread2 = new Thread(new MyRunnable());
    };

运行结果:
04-25 15:05:38.299 28518 28518 D ThreadTest: threadGroup
04-25 15:05:38.301 28518 28536 D ThreadTest: thread_1.running:
04-25 15:05:38.319 28518 28537 D ThreadTest: thread_2.running:
04-25 15:05:42.302 28518 28536 D ThreadTest: thread_1.running:
04-25 15:05:42.323 28518 28537 D ThreadTest: thread_2.running:

二.方法解说:
  run()-->线程运行时所执行的代码
   start()-->用于启动线程
   sleep(long millis)-->线程休眠,交出CPU,让CPU去执行其他的任务,然后线程进入阻塞状态,sleep方法不会释放锁
  yield()-->使当前线程交出CPU,让CPU去执行其他的任务,但不会进入阻塞状态,而是重置为就绪状态,yield方法不会释放锁.和sleep区别是sleep会阻塞会再执行,yield让出cpu后,和其它线程存在竞争状态.
  join()-->当前主线程等待其他线程执行完毕后,再来继续执行Thread.join()后面的代码
  interrupt()//中断线程,自stop函数过时之后,我们通过interrupt方法和isInterrupted()方法来停止正在运行的线程,注意只能中断已经处于阻塞的线程
   getId()-->当前线程id
   getName()/setName()-->获取和设置线程的名字
   getPriority()/setPriority()-->获取和设置线程的优先级,property用1-10整数表示,默认优先级是5,优先级最高是10,优先级高的线程被执行的机率高
  setDaemon()/isDaemo()//设置和判断是否是守护线程
  currentThread()-->静态函数获取当前线程
  wait()/notyfy/notifyAll-->他们是属于Obeject对象,不是属于线程。它们用在线程同步时synchronized语句块中。wait交出cpu,让CPU去执行其他的任务,线程进入阻塞状态,同时也会释放锁.notify()并不会让当前线程休眠,但会唤醒休眠的线程。 (notifyAll方法就会通知所有等待这个对象控制权的线程继续运行)
    eg:wait():我等会儿再用这把锁,CPU也让给你们,我先休息一会儿!notify()意思是说,我用完了,你们谁用?

 关于wait && notify的简单例子如下:
public class MainActivity extends Activity {
    Thread thread1;
    Thread thread2;
    boolean threadRunning;
    final Object object = new Object();
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        operateThread();

    public void operateThread(){
        Log.d("ThreadTest", "threadGroup");
        thread1 = new Thread(new Runnable(){
            public void run(){
                synchronized (object) {
                   threadRunning = true;
                   for(int i =0;i <= 100;i++){
                       Log.d("ThreadTest","thread_1.running: i: " + i);
                       if(i== 50){
                           try {
                            object.wait();
                        } catch (InterruptedException e) {
                            e.printStackTrace();
                        }
                       }
                   }
                   threadRunning = false;
                }
            }
        });
        thread1.start();
        
        class MyRunnable implements Runnable {
            public void run(){
             synchronized (object) {
                for(int i=0;i<100;i++){
                    Log.d("ThreadTest","thread_2.running: i: " + i);
                    if(i== 50){
                        object.notify();
                    }
                }
              }
            }
        }
        thread2 = new Thread(new MyRunnable());
        thread2.start();
04-26 10:33:32.376  4956  4956 D ThreadTest: threadGroup
04-26 10:33:32.379  4956  4976 D ThreadTest: thread_1.running: i: 0
      ......中间thread_1一直在运行,由于有object的占用
04-26 10:33:32.381  4956  4976 D ThreadTest: thread_1.running: i: 49
04-26 10:33:32.381  4956  4976 D ThreadTest: thread_1.running: i: 50//到50就释放锁,让出cpu,进入wait阻塞状态
04-26 10:33:32.381  4956  4977 D ThreadTest: thread_2.running: i: 0
      ........thread_2获取锁后运行,
04-26 10:33:32.382  4956  4977 D ThreadTest: thread_2.running: i: 50
      ........thread_2在50的时候notify持有object对象的线程后,不释放锁,以及不会让出cpu
04-26 10:33:32.382  4956  4977 D ThreadTest: thread_2.running: i: 51
04-26 10:33:32.383  4956  4977 D ThreadTest: thread_2.running: i: 99
      .......线程2执行完后线程1运行
04-26 10:33:32.384  4956  4976 D ThreadTest: thread_1.running: i: 51
04-26 10:33:32.384  4956  4976 D ThreadTest: thread_1.running: i: 52

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

对于这些thread介绍如有不清楚或者不对的地方,望指出,大家可以共同进步.以及有兴趣的地方大家可以一起讨论.

Thread部分总结以及小例子的更多相关文章

  1. java即时通信小例子

    学习java一段时间了,今天写来一个即时通信的小例子练手在其过程中也学到了一些知识拿出来和大家分享,请路过的各位大神多多赐教... 好了下面讲一下基本的思路: 首先,编写服务器端的程序,简单点说吧就是 ...

  2. c# BackGroundWorker 多线程操作的小例子

    在我们的程序中,经常会有一些耗时较长的运算,为了保证用户体验,不引起界面不响应,我们一般会采用多线程操作,让耗时操作在后台完成,完成后再进行处理或给出提示,在运行中,也会时时去刷新界面上的进度条等显示 ...

  3. c/c++ 继承与多态 文本查询的小例子(非智能指针版本)

    问题:在上一篇继承与多态 文本查询的小例子(智能指针版本)在Query类里使用的是智能指针,只把智能指针换成普通的指针,并不添加拷贝构造方法,会发生什么呢? 执行时,代码崩掉. 分析下面一行代码: Q ...

  4. c/c++ 继承与多态 文本查询的小例子(智能指针版本)

    为了更好的理解继承和多态,做一个文本查询的小例子. 接口类:Query有2个方法. eval:查询,返回查询结果类QueryResult rep:得到要查询的文本 客户端程序的使用方法: //查询包含 ...

  5. Hadoop中RPC协议小例子报错java.lang.reflect.UndeclaredThrowableException解决方法

    最近在学习传智播客吴超老师的Hadoop视频,里面他在讲解RPC通信原理的过程中给了一个RPC的小例子,但是自己编写的过程中遇到一个小错误,整理如下: log4j:WARN No appenders ...

  6. 【转】 Pro Android学习笔记(九七):BroadcastReceiver(1):基础小例子

    目录(?)[-] 基础小例子 发送Broadcast intent 运行情况 应用间的广播 文章转载只能用于非商业性质,且不能带有虚拟货币.积分.注册等附加条件.转载须注明出处:http://blog ...

  7. Java多线程分批发送消息的小例子

    需求: 假设有10万个用户,现在节假日做活动,需要给每个用户发送一条活动短信,为了提高程序的效率,建议使用多线程分批发送. 这里值得注意的是: 每开一个线程都会占用CPU的资源,所以线程根据所需要的条 ...

  8. springmvc入门的第一个小例子

    今天我们探讨一下springmvc,由于是初学,所以简单的了解一下 springmvc的流程,后续会持续更新... 由一个小例子来简单的了解一下 springmvc springmvc是spring框 ...

  9. Runtime的几个小例子(含Demo)

    一.什么是runtime(也就是所谓的“运行时”,因为是在运行时实现的.)           1.runtime是一套底层的c语言API(包括很多强大实用的c语言类型,c语言函数);  [runti ...

随机推荐

  1. C++继承中的public/protected/private

    今天杨老师讲到C++的继承的时候用一个表来说明子类继承父类后访问权限的变化,如下表: 注:在本类中,protected与private是相同的,但protected可以被继承,而private却不行. ...

  2. Android Camera开发系列(上)——Camera的基本调用与实现拍照功能以及获取拍照图片加载大图片

    Android Camera开发系列(上)--Camera的基本调用与实现拍照功能以及获取拍照图片加载大图片 最近也是在搞个破相机,兼容性那叫一个不忍直视啊,于是自己翻阅了一些基本的资料,自己实现了一 ...

  3. HBase Master 启动

    –>首先初始化HMaster –>创建一个rpcServer,其中并启动 –>启动一个Listener线程,功能是监听client的请求,将请求放入nio请求队列,逻辑如下: –&g ...

  4. SharePoint 2013配置开发环境,需安装VS2012插件

    SharePoint 2013已经安装好了,接下来就是配置开发环境,安装VS2012,但是,装好了以后,发现没有SharePoint 2013开发的支持,如下图: 然后,去网上查找资料,VS2012对 ...

  5. SharePoint 开发TimerJob 介绍

    项目需要写TimerJob,以前也大概知道原理,不过,开发过程中,还是遇到一些问题,网上看了好多博客,也有写的灰常好的,不过,自己还是想再写一下,也算是给自己一个总结,也算给大家多一个参考吧. Tim ...

  6. 关于UIView中相关坐标及改变的相关方法

    // 将像素point由point所在视图转换到目标视图view中,返回在目标视图view中的像素值 - (CGPoint)convertPoint:(CGPoint)point toView:(UI ...

  7. leetcode(57)- Implement strStr()

    题目: Implement strStr(). Returns the index of the first occurrence of needle in haystack, or -1 if ne ...

  8. javascript语言扩展:可迭代对象(1)

    在ECMAScript中我们知道可以通过for in语句进行对象属性的遍历,当然这些属性不包括继承而来的属性: var ary = [1,2,3,"aa",4]; for(i in ...

  9. React Native入门 开发第一个React Native应用

    1. 首先创建一个目录(比如ReactNativeDir),用于存放各个ReactNative工程的代码 2.使用React Native命令工具来创建(初始化)一个ReactNative项目(tes ...

  10. Fragment生命周期与Fragment执行hide、show后的生命周期探讨

    一.Fragment 生命周期中的每个方法的意义与作用: 1.setUserVisibleHint()(此方法不属于生命周期方法):设置Fragment 用户可见或不可见时调用此方法,此方法在Frag ...