Android学习笔记(三)

ContentProvider简单介绍

  ContentProvider是不同应用程序之间进行数据交换的标准API,当一个应用程序须要把自己的数据暴露给其它程序使用时。该应用程序便可通过提供ContentProvider来实现,其它应用程序就可通过ContentResolver来操作ContentProvider暴露的数据。假设某一应用程序通过ContentProvider暴露了自己的数据操作接口,则无论该应用程序是否启动。其它应用程序都能够通过该接口来操作该应用程序的内部数据。包含添加、删除、改动、查询数据。

android:authorities属性

   定义好的ContentProvider类必须在AndroidManifest.xml里声明后才干使用,声明中必须加入授权属性

android:authorities。相当于为该ContentProvider指定域名,Content uri中content://authority/optionalPath/optionalId的authority部分便是android:authorities属性指定的值。

属性值定义的方法为包名+ “.”+ 该ContentProvider的名称。

Service本身存在的两个问题

1. Service不会专门启动一条单独的进程,Service与它所在应用处于同一个进程中。

2. Service不是一条新的线程。因此不应该在Service中直接处理耗时的操作。耗时的操作应该开启一个新的线程来处理。

处理耗时任务的问题

假设就开发这须要在Service模块中处理耗时任务,通常是在Service中另外启动一条新线程来处理,但不能在其它应用程序组件中启动子线程来处理,由于Activity可能会被用户退出、BroadcastReceiver的生命周期非常短。非常有可能出现子线程还没有结束。Activity已经被用户退出,或者BroadcastReceiver已经结束,出现空线程的情况。

IntentService简单介绍

  IntentService可以弥补Service本身的两个缺陷: IntentService会使用队列来管理请求的Intent,每当client代码通过Intent请求启动IntentService时。IntentService会将该Intent增加队列中,然后开启一条新的worker线程来处理该Intent,对于异步的startService()请求。IntentService会按次序依次处理队列中的Intent,该线程保证同一时刻仅仅处理一个Intent。

因为IntentService使用新的worker线程处理Intent请求,因此IntentService不会堵塞主线程,所以IntentService自己便能处理耗时的任务。

静态代码块

   即类中不包括不论什么方法体的静态代码块,其格式一般为static{…}。这样的静态代码块仅仅在类被载入时运行,并且仅仅运行一次。

静态代码块一般用来运行类属性的初始化。

getResources().getStringArray(…)作用

getResources().getStringArray(R.array.setting)是获取应用程序中数组资源的方法。即假设要使用应用程序中定义的数组资源,须要使用getResources().getStringArray(R.array.*),其返回值为一个数组。

TelephonyManager服务类的getXxx()方法举例

  1.TelephonyManager.getDeviceId()                      //获取设备的编号

  2.TelephonyManager.getDeviceSoftwareVersion()           //获取系统平台的版本号

  3.TelephonyManager.getNetworkOperator()                //获取网络运营商代号

  4.TelephonyManager.getNetworkOperatorName()           //获取网络运营商名称

  5.TelephonyManager.getPhoneType()                     //获取手机网络类型

  6.TelephonyManager.getCellLocation()                    //获取设备所在位置

  7.TelephonyManager.getSimCountryIso()                  //获取SIM卡的国别

  8.TelephonyManager.getSimSerialNumber()                //获取SIM卡序列号

  9.TelephonyManager.getSimState()                       //获取SIM卡状态

  返回值的类型都是String类型。

通话状态监听器PhoneStateListener简单介绍

PhoneStateListener是通话状态监听器,定义该监听器时必须实现onCallStateChanged(intstate, String number)方法。通话状态的主要静态常量: int CALL_STATE_IDLE  //空暇状态,没有不论什么活动    int CALL_STATE_OFFHOOK  //摘机状态。至少有个电话活动,该活动或是拨打或是通话,或者是on hold。而且没有电话是ringing or waiting   intCALL_STATE_RINGING //来电状态。电话铃声响起的那段时间或正在通话又来新电,新来电话不得不等待的那段时间。

获取短信管理器的方法

  SmsManager sManager= SmsManager.getDefault();     //由此方法获取应用程序的SmsManager

PendingIntent对象简单介绍

   PendingIntent对象是对Intent的包装,一般通过调用PendingIntent的getActivity()、getService()、getBroadcastReceiver()静态方法来获取PendingIntent对象。与Intent对象不同的是。PendingIntent一般会传给其它应用组件,从而由其它应用程序来运行PendingIntent所包装的Intent。

BroadcastReceiver简单介绍

  BroadcastReceiver属于系统级的监听器,拥有自己的进程,仅仅要存在与之匹配的Intent被广播出来。BroadcastReceiver就能被激发。

当被激发后,会自己主动触发它的onReceive()方法,onReceive()方法运行完毕后。BroadcastReceiver的实例便会被销毁。与Activity组件不同的是,当系统通过Intent启动指定的Activity组件时,假设没有找到合适的Activity组件,会导致程序异常终止。但系统通过Intent激发BroadcastReceiver时,假设找不到合适的BroadcastReceiver组件,应用不会有不论什么问题。此外,不能在onReceive()中运行耗时的操作,能够考虑通过Intent启动一个Service来完毕该操作。但不能使用新线程完毕耗时的操作。由于BroadcastReceiver本身的生命周期非常短,可能出现子线程还没结束,BroadcastReceiver就已经退出了。

原文地址:https://www.cnblogs.com/mthoutai/p/7017071.html