1. java中对多线程访问控制可使用关键字synchronized
下面将以Producer Consumer模型介绍android中线程同步的使用。

步骤:
建立一android project,
修改main activity如下:


代码:

package com.test.thread;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;

public class MultiThread extends Activity {
   
    private static final String MultiThread_ACTIVITY_TAG = "MultiThread_TAG";
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
       
        CubbyHole c = new CubbyHole();
        Producer p1 = new Producer(c, 1);
        Consumer c1 = new Consumer(c, 1);
       
        p1.start();
        c1.start();
       
        // Test log system.
        //testLog();
       
        setContentView(R.layout.main);
       
    }
   
    // This is a example to use android.util.Log.
    public void testLog() { 
        Log.i(MultiThread_ACTIVITY_TAG, "============================="); 
       
        Log.d(MultiThread_ACTIVITY_TAG, "this is a DEBUG of MyAndroid. "); 
        Log.i(MultiThread_ACTIVITY_TAG, "this is a INFO of MyAndroid. "); 
        Log.w(MultiThread_ACTIVITY_TAG, "this is a WARNING of MyAndroid. ");  
    } 
   
   
    public class Producer extends Thread {
        private CubbyHole cubbyhole;
        private int number;

        public Producer(CubbyHole c, int number) {
            cubbyhole = c;
            this.number = number;
        }

        public void run() {
            for (int i = 0; i < 10; i++) {
                cubbyhole.put(i);
                Log.d(MultiThread_ACTIVITY_TAG, "Producer #" + this.number + " put: " + i);
                //System.out.println("Producer #" + this.number + " put: " + i);
                try {
                    sleep((int)(Math.random() * 100));
                } catch (InterruptedException e) {}
            }
        }
    }

    public class CubbyHole {
        private int contents;
        private boolean available = false;
   
        public synchronized int get() {
            while (available == false) {
                try {
                    wait();
                    } catch (InterruptedException e) { }
            }
           
            available = false;
            notifyAll();
            return contents;
        }
   
        public synchronized void put(int value) {
            while (available == true) {
                try {
                    wait();
                    } catch (InterruptedException e) { }
            }
            contents = value;
            available = true;
            notifyAll();
        }
    }
   
   
    public class Consumer extends Thread {
        private CubbyHole cubbyhole;
        private int number;
   
        public Consumer(CubbyHole c, int number) {
            cubbyhole = c;
            this.number = number;
        }
   
        public void run() {
            int value = 0;
            for (int i = 0; i < 10; i++) {
                value = cubbyhole.get();
                Log.d(MultiThread_ACTIVITY_TAG, "Consumer #" + this.number + " got: " + value);
                //System.out.println("Consumer #" + this.number + " got: " + value);
            }
        }
    }
}

2. 上面的代码中引入了android.util.Log包, 以拥有debug。
    运行上面的工程后,在dbg窗口的Logcat区,显示打出的log。

 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/shilongdred1979/archive/2008/10/19/3080142.aspx

更多相关文章

  1. 《android开发应用实战详解》光盘源代码
  2. Android/java 多线程(五)-ThreadPoolExecutor线程池的使用
  3. Android 线程池来管理线程
  4. Android的线程使用来更新UI----Thread、Handler、Looper、TimerT
  5. Android关于线程更新UI的方法
  6. 解析Android中的main线程与子线程

随机推荐

  1. Android重力感应实现方式简介
  2. Android(安卓)开发者调查
  3. Android面试6家一线大厂,这个问题是必问!
  4. (转)分析android与java的关系
  5. ios应用比android大,为什么iOS版APP安装
  6. 在android 中使用og4j
  7. Android(安卓)SharedPreferences本地缓存
  8. ❤️烦恼?头疼?不知所措?Android的ANR问题,一剂
  9. Android(安卓)富文本编辑器 - ListItemSp
  10. android TV-Working with Channel Data