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(安卓)小发现:xml里定义的组件取出始终为null
  2. sharedUserId 区别 process
  3. Android(安卓)Camera使用小结
  4. Android:WebView与Javascript交互(相互调用参数、传值)
  5. Android中蓝牙使用步骤小结
  6. Android的线程使用来更新UI----Thread、Handler、Looper、TimerT
  7. android九宫格实现
  8. [Android] Android(安卓)视频播放总结
  9. 使用WebView中的JavaScript调用Android方法

随机推荐

  1. Android学习心得
  2. MapMe
  3. Android中打开多个Activity,返回到第一个A
  4. 学习Android之用户界面基础
  5. Unity编译Android的原理解析和apk打包分
  6. ffmpeg2.2在ubuntu下使用NDK编译——并在
  7. Android倒计时定时器CountDownTimer的用
  8. 深入了解android平台的jni(一)
  9. android相册选择图片的编码实现
  10. Android源码分析:TabHost