当前位置:首页 > > 充电吧
[导读]    实现线程的两种方式  使用继承的方法  class MyThread extends Thread{  @Override  public void run(){  //处理具体的逻辑  } 

  

  实现线程的两种方式

  使用继承的方法

  class MyThread extends Thread{

  @Override

  public void run(){

  //处理具体的逻辑

  }

  }

  要启动这个线程,在主线程中新建一个该实例,调用其start()方法即可。

  使用实现Runnable借口的方式

  class MyThread implements Runnable{

  @Override

  public void run(){

  //处理具体的逻辑

  }

  }

  开启现成时,使用:

  MyThread myThread = new MyThread();

  new Thread(MyThread).start();

  匿名类的方法去实现Runnable也是一样的

  new Thread(new Runnalbe(){

  @Override

  public void run(){

  //处理具体逻辑

  }

  }).start();

  异步操作

  和很多的GUI库一样,Android的UI也是线程不安全的,所以,我们不能在子线程中更新UI元素。

  我们需要通过异步的操作通过子线程向主线程通信的方式来将UI更新的操作交给主线程来完成。

  Handler和Message结合传递的方法

  这里,有Message、Handler、MessageQueue和Looper在作用。

  1、Message是县城之间传递的消息。

  2、Handler是处理者,用于发送和处理消息

  3、MessageQueue是消息队列的意思,存放通过Handler发送的消息。

  4、Looper是每个线程中的MessageQueue的管家。

  Handler handler = new Handler(){

  public void handleMessage(Message msg){

  switch (msg.what){

  case UPDATA_TEXT:

  txvHello.setText("Nice to meet you!");

  break;

  default:

  break;

  }

  }

  };

  8new Thread(new Runnable() {

  @Override

  public void run() {

  Message msg = new Message();

  msg.what = UPDATA_TEXT;

  handler.sendMessage(msg);

  }

  }).start();

  使用Async Task

  Async Task是一个抽象类,我们要使用它,就要先对他进行处理。

  3个参数:

  1、Params在执行AsyncTask时需要传入的参数,可用于在后台服务中使用。

  2、Progress如果需要在界面上显示当前的进度,使用这里的泛型作为进度单位。

  3、Result任务执行完毕后,对结果进行返回。

  4个重写的方法:

  1、onPreExecute()

  2、DoInBackground(。。。)

  3、onProgressUpdate(。。。)

  4、onPostExecute(Result)

  public class DownloadTask extendsAsyncTask{

  TextView txvDownloading;

  ProgressBar progressBar;

  @Override

  protected void onPreExecute() {

  super.onPreExecute();

  progressBar.setMax(100);

  }

  public DownloadTask(TextView txvDownloading, ProgressBar progressBar) {

  this.txvDownloading = txvDownloading;

  this.progressBar = progressBar;

  }

  @Override

  protected Integer doInBackground(Void... params) {

  int count = 0;

  for (int i =100; i > 0; i-- ){

  count++;

  publishProgress(count);

  try {

  Thread.sleep(500);

  } catch (InterruptedException e) {

  e.printStackTrace();

  }

  }

  return count;

  }

  @Override

  protected void onProgressUpdate(Integer... values) {

  int a = values[0];

  Log.d("TAG",a+"");

  progressBar.setProgress(a);

  }

  @Override

  protected void onPostExecute(Integer integer) {

  super.onPostExecute(integer);

  if(integer.equals(100)){

  txvDownloading.setText("Done");

  }else{

  txvDownloading.setText("downloading");

  }

  }

  }

  在Mainactivity中只需要写入:

  1new DownloadTask(txvShow, prgsDownload).execute();

  即可。

  服务

  什么是服务:服务是Android的四大组件之一,在后台运行

  创建服务

  创建一个继承Service的类,

  其中onBind方法是默认重写的,其他的还有3个重要的方法,onCreate()、onStartCommand()、onDestroy()。

  1、onCreate()方法会在服务创建的时候调用

  2、onStartCommand()会在每次服务启动的时候调用

  3、onDestroy()会在服务销毁的时候调用。

  每个服务都必须在AndroidManifest.xml中注册才能生效。

  启动和关闭服务

  通过Intent我们可以来开启和关闭服务

  switch (v.getId()){

  case R.id.btn_start:

  Intent startTntent = new Intent(this, MyService.class);

  startService(startTntent);

  break;

  case R.id.btn_stop:

  Intent stopIntent = new Intent(this, MyService.class);

  stopService(stopIntent);

  break;

  default:

  break;

  }

  onBind方法,绑定服务

  private DownloadBinder mBinder = new DownloadBinder();

  class DownloadBinder extends Binder{

  public void startDownload(){

  Log.d("TAG","StartDownload");

  }

  public int getProgress(){

  Log.d("TAG","getProgress executed");

  return 0;

  }

  }

  @Nullable

  @Override

  public IBinder onBind(Intent intent) {

  return mBinder;

  }

  private ServiceConnection connection = newServiceConnection() {

  @Override

  public void onServiceConnected(ComponentName name, IBinder service) {

  downloadBinder = (MyService.DownloadBinder) service;

  downloadBinder.startDownload();

  downloadBinder.getProgress();

  }

  @Override

  public void onServiceDisconnected(ComponentName name) {

  }

  };

  case R.id.btn_bindstart:

  Intent bindIntent = new Intent(this, MyService.class);

  bindService(bindIntent,connection,BIND_AUTO_CREATE);

  break;

  case R.id.btn_bindstop:

  unbindService(connection);

  服务器的生命周期:

  略。

  更多的服务---前台服务

  类似于通知的使用方法,在onCreate代码中构建Notification对象,建立Intent对象,PendingIntent,setLatestEventInfo,接下来是startForeground方法

  public void onCreate() {

  super.onCreate();

  Notification notification = newNotification(R.drawable.ic_launcher,"Notification comes",System.currentTimeMillis());

  Intent notificationIntent = new Intent(this, MainActivity.class);

  PendingIntent pendingIntent = PendingIntent.getActivity(this,0,notificationIntent,0);

  startForeground(1,notification);

  }

  7. IntentService

  为了避免在主线程中出现耗时逻辑,我们需要使用Android的多线程编程的方法,将耗时逻辑放入线程中进行。

  @Override

  public int onStartCommand(Intent intent, int flags,int startId) {

  new Thread(new Runnable() {

  @Override

  public void run() {

  //处理耗时逻辑

  }

  }).start();

  return super.onStartCommand(intent, flags, startId);

  }

  在耗时逻辑执行完成了之后,如果我们希望服务在处理完这些内容之后就自动关闭,呢么在耗时逻辑的最后加上stopSelf()方法是个不错的选择。

  当然这里要可以使用IntentService类,它可以简单的创建一个异步的,会自动停止的服务。

  public class MyIntentService extends IntentService{

  /**

  * Creates an IntentService. Invoked by your subclass's constructor.

  *

  *

  */

  public MyIntentService() {

  super("MyIntentService");

  }

  @Override

  protected void onHandleIntent(Intent intent) {

  for (int a = 10; a > 0; a--){

  try {

  Thread.sleep(500);

  } catch (InterruptedException e) {

  e.printStackTrace();

  }

  Log.d("TAG", ""+a);

  }

  }

  @Override

  public void onDestroy() {

  super.onDestroy();

  Log.d("TAG", "onDestroy");

  }

  }

  ase R.id.btn_intentservice:

  Intent intentService = newIntent(this,MyIntentService.class);

  startService(intentService);

  break;

  

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭