Android游戏开发之多线程的操作方式

Linux大全评论964 views阅读模式

游戏开发与软件开发多线程的重要性

如果程序主线程被阻塞超过5秒,系统会提示“应用程序无响应” 这就是ANR 。 ANR的全称是Application Not Responding,使用多线程可以避免ANR。但是这里要注意一下不要为了避免ANR而过多的使用多线程,除非万不得已的情况。 比如访问网络服务端返回的过慢、数据过多导致滑动屏幕不流畅、或者I/O读取过大的资源等等。这里可以开启一个新线程来处理这些耗时的操作。 如果过多使用多线程会出现数据同步的问题须要程序员去处理,所以使用多线程的时候尽量保持它的独立不会被其它线程干预。java语言提供了一个线程锁的概念 synchronized 可以添加对象锁与方法锁专门避免多线程同时访问一个方法或者一个对象导致的问题,有兴趣的朋友可以去看看这里我不罗嗦啦 。

1.Thread与Handler执行多线程

  1. import java.io.InputStream;  
  2.   
  3. import Android.app.Activity;  
  4. import android.content.Context;  
  5. import android.graphics.Bitmap;  
  6. import android.graphics.BitmapFactory;  
  7. import android.os.Bundle;  
  8. import android.os.Handler;  
  9. import android.os.Message;  
  10. import android.view.View;  
  11. import android.view.View.OnClickListener;  
  12. import android.widget.Button;  
  13. import android.widget.TextView;  
  14.   
  15. public class SingleActivity extends Activity {  
  16.   
  17.     /**读取进度**/  
  18.     public final static int LOAD_PROGRESS = 0;   
  19.       
  20.     /**标志读取进度结束**/  
  21.     public final static int LOAD_COMPLETE = 1;   
  22.       
  23.       
  24.     /** 开始加载100张图片按钮 **/  
  25.     Button mButton = null;  
  26.     /** 显示内容 **/  
  27.     TextView mTextView = null;  
  28.     /** 加载图片前的时间 **/  
  29.     Long mLoadStatr = 0L;  
  30.     /** 加载图片后的时间 **/  
  31.     Long mLoadEnd = 0L;  
  32.   
  33.     Context mContext = null;  
  34.   
  35.     //接收传递过来的信息   
  36.     Handler handler = new Handler() {  
  37.     @Override  
  38.     public void handleMessage(Message msg) {  
  39.         switch (msg.what) {  
  40.         case LOAD_PROGRESS:  
  41.         mTextView.setText("当前读取到第" + msg.arg1 + "张图片");  
  42.         break;  
  43.         case LOAD_COMPLETE:  
  44.         mTextView.setText("读取结束一共耗时" + msg.arg1 + "毫秒");  
  45.         break;  
  46.         }  
  47.         super.handleMessage(msg);  
  48.     }  
  49.     };  
  50.   
  51.     @Override  
  52.     protected void onCreate(Bundle savedInstanceState) {  
  53.     setContentView(R.layout.single);  
  54.     mContext = this;  
  55.   
  56.     /** 拿到button 与 TextView 对象 **/  
  57.     mButton = (Button) findViewById(R.id.button0);  
  58.     mTextView = (TextView) findViewById(R.id.textView0);  
  59.     mTextView.setText("点击按钮开始更新时间");  
  60.     mButton.setOnClickListener(new OnClickListener() {  
  61.         @Override  
  62.         public void onClick(View arg0) {  
  63.         //开始读取图片   
  64.         LoadImage();  
  65.         }  
  66.     });  
  67.   
  68.       
  69.     super.onCreate(savedInstanceState);  
  70.     }  
  71.   
  72.     public void LoadImage() {  
  73.     new Thread() {  
  74.         @Override  
  75.         public void run() {  
  76.         //得到加载图片开始的时间   
  77.         mLoadStatr = System.currentTimeMillis();  
  78.           
  79.         for (int i = 0; i < 100; i++) {  
  80.             // 这里循环加载图片100遍   
  81.             ReadBitMap(mContext, R.drawable.bg);  
  82.   
  83.             // 每读取完一张图片将进度甩给handler   
  84.             Message msg = new Message();  
  85.             msg.what = LOAD_PROGRESS;  
  86.             msg.arg1 = i + 1;  
  87.             handler.sendMessage(msg);  
  88.         }  
  89.           
  90.         //得到加载图片结束的时间   
  91.         mLoadEnd = System.currentTimeMillis();  
  92.           
  93.         //100张图片加载完成   
  94.         Message msg = new Message();  
  95.         msg.what = LOAD_COMPLETE;  
  96.         msg.arg1 = (int) (mLoadEnd - mLoadStatr);  
  97.         handler.sendMessage(msg);  
  98.         }  
  99.     }.start();  
  100.   
  101.     }  
  102.   
  103.     /** 
  104.      * 读取本地资源的图片 
  105.      *  
  106.      * @param context 
  107.      * @param resId 
  108.      * @return 
  109.      */  
  110.     public Bitmap ReadBitMap(Context context, int resId) {  
  111.     BitmapFactory.Options opt = new BitmapFactory.Options();  
  112.     opt.inPreferredConfig = Bitmap.Config.RGB_565;  
  113.     opt.inPurgeable = true;  
  114.     opt.inInputShareable = true;  
  115.     // 获取资源图片   
  116.     InputStream is = context.getResources().openRawResource(resId);  
  117.     return BitmapFactory.decodeStream(is, null, opt);  
  118.     }  
  119. }  

企鹅博客
  • 本文由 发表于 2019年8月1日 00:19:56
  • 转载请务必保留本文链接:https://www.qieseo.com/170919.html

发表评论