对于Android工作线程进行全解析

移动开发 Android
Android工作线程工作原理为:主要是为了节约CPU时间,发挥利用,根据具体情况而定. 线程的运行中需要使用计算机的内存资源和CPU。

Android工作线程是程序中一个单一的顺序控制流程.在单个程序中同时运行多个线程完成不同的工作,这些内容都是一些门户网站和技术论坛找到的,中间可能有不少错误是我没有挑出的,欢迎大家指正。

由于SurfaceHolder是一个共享资源,因此在对其操作时都应该实行“互斥操作“,即需要使用synchronized进行”封锁“机制。再来讨论下为什么要使用消息机制来更新界面的文字信息呢?其实原因是这样的。

渲染文字的工作实际上是主线程(也就是LunarView类)的父类View的工作。而并不属于Android工作线程LunarThread,因此在Android工作线程中式无法控制的。所以我们改为向主线程发送一个Message来代替。

让主线程通过Handler对接收到的消息进行处理,从而更新界面文字信息。再回顾上一篇SnakeView里的文字信息更新,由于是SnakeView自己(就这一个线程)对其包含的TextView做控制,当然没有这样的问题了。

  1. public void run()   
  2.         {  
  3.             while (mRun)   
  4.             {  
  5.                 Canvas c = null;  
  6.                 try   
  7.                 {  
  8.                     //锁定待绘制区域  
  9.                     c = mSurfaceHolder.lockCanvas(null);  
  10.                     synchronized (mSurfaceHolder)  
  11.                     {  
  12.                         if (mMode == STATE_RUNNING)   
  13.                             updatePhysics();//更新底层数据,判断游戏状态  
  14.                         doDraw(c);//强制重绘制  
  15.                     }  
  16.                 }   
  17.                 finally   
  18.                 {  
  19.                     if (c != null) {  
  20.                         mSurfaceHolder.unlockCanvasAndPost(c);  
  21.                     }  
  22.                 }  
  23.             }  
  24.         } 

下面就是LunaThread这个Android工作线程的执行函数了,它一直不断在重复做一件事情:锁定待绘制区域(这里是整个屏幕),若游戏还在进行状态,则更新底层的数据,然后直接强制界面重新绘制。

  1. canvas.save();  
  2.             canvas.rotate((float) mHeading, (float) mX, mCanvasHeight  
  3.                     - (float) mY);  
  4.             if (mMode == STATE_LOSE) {  
  5.                 mCrashedImage.setBounds(xLeft, yTop, xLeft + mLanderWidth, yTop  
  6.                         + mLanderHeight);  
  7.                 mCrashedImage.draw(canvas);  
  8.             } else if (mEngineFiring) {  
  9.                 mFiringImage.setBounds(xLeft, yTop, xLeft + mLanderWidth, yTop  
  10.                         + mLanderHeight);  
  11.                 mFiringImage.draw(canvas);  
  12.             } else {  
  13.                 mLanderImage.setBounds(xLeft, yTop, xLeft + mLanderWidth, yTop  
  14.                         + mLanderHeight);  
  15.                 mLanderImage.draw(canvas);  
  16.             }  
  17.             canvas.restore(); 

LunarLancher的暂停其实并没有不再强制重绘制,而是没有对底层的数据做任何修改,依然绘制同一帧画面,而继续则是把mLastTime设置为当前时间+100毫秒的时间点,因为以前暂停时mLastTime就不再更新了,这样做事为了与当前时间同步起来。

责任编辑:chenqingxiang 来源: 计世网
相关推荐

2010-02-06 10:42:41

Android Ser生命周期

2010-02-23 16:46:27

Python设计语言

2010-02-05 14:34:11

Android操作系统

2010-02-06 10:14:36

Android Act

2010-03-03 14:51:02

Android手机

2010-03-04 16:38:37

Android开发技巧

2009-12-07 09:58:35

WCF性能

2010-02-02 13:32:32

Python继承

2010-02-06 16:26:30

Android开源

2010-02-07 10:21:27

Android应用程序

2010-02-04 14:16:45

Android平台

2010-03-01 14:28:46

Python进程

2010-02-22 10:18:29

Python代码

2010-03-04 17:50:42

Android操作系统

2016-12-02 19:00:13

Android FraAndroid

2009-12-01 17:55:11

VS2003配置

2010-03-01 13:19:21

Python线程内容

2010-02-06 09:38:42

Android调用服务

2010-03-02 15:51:05

Android手机

2010-02-05 14:54:56

Android UI
点赞
收藏

51CTO技术栈公众号