Android

#Activity的生命周期

onCreate->onStart->onResume->Activity运行->新的Activity运行->onPause->onStop->onDestroy->Activity销毁

#Activity的onStart()和onResume()的区别是什么

onResume是activity获得用户焦点,在与用户交互

onStart是activity用户可见,包括有一个activity在他上面,但没有将它完全覆盖,用户可以看到部分activity但不能与它交互

#service生命周期

1、通过startService()创建,必须调用stop self()或者通过其他组件调用stopService()来停止,被停止时自动销毁。

2、被绑定的service是当其他组件(一个客户)调用bindService()来创建的,通过一个onBinder接口和service进行通信,通过 unbindService()方法来关闭这种连接,一个service可以同时和多个客户绑定

#Activity的几种LaunchMode及使用场景

1、standard 模式

这是默认模式

2、singleTop 模式

如果在任务的栈顶正好存在该Activity的实例,就重用该实例

3、singleTask 模式

如果在栈中已经有该Activity的实例,就重用该实例

4、singleInstance 模式

在一个新栈中创建该Activity的实例,并让多个应用共享该栈中的该Activity实例。

#View的绘制流程 Measure - Layout - Draw

Measure 过程

1. 测量过程由上至下,在measure过程的最后,每个视图将存储自己的尺寸大小和测量规格。

2. measure过程会为一个View及其所有子节点的mMeasureWidth和mMeasuredHeight变量赋值, 该值可以通过getMeasuredWidth和getMeasuredHeight方法获得。

3. measure过程的核心方法:measure() - onMeasure() - setMeasuredDimension().

Layout 过程

1.子视图的具体位置都是相对于父视图而言的。View的onLayout()方法为空实现,而ViewGroup的onLayout为abstract,因此,自定义的View要继承ViewGroup时,必须实现onLayout函数。

2.在Layout过程中,子视图会调用getMeasuredWidth()和getMeasuredHeight()方法获取到measure过程得到mMeasuredWidth和mMeasuredHeight,作为自己的width和height。然后调用每一个子视图的layout(),来确定每个子视图在父视图中的位置。

Draw 过程

1.所有视图最终都是调用View的draw方法进行绘制。 在自定义视图中, 也不应该复写该方法, 而是复写onDraw()方法进行绘制, 如果自定义的视图确实要复写该方法,先调用super.draw()完成系统的绘制,再进行自定义的绘制。

2.onDraw()方法默认是空实现,自定义绘制过程需要复写方法,绘制自身的内容。

3.dispatchDraw()发起对子视图的绘制,在View中默认为空实现,ViewGroup复写了dispatchDraw()来对其子视图进行绘制。自定义的ViewGroup不应该对dispatchDraw()进行复写。

如何对自定义View进行控制

1. 如果想控制View在屏幕上的渲染效果,就在重写onDraw()方法,在里面进行相应的处理。

2. 如果想要控制用户同View之间的交互操作,则在onTouchEvent()方法中对手势进行控制处理。

3. 如果想要控制View中内容在屏幕上显示的尺寸大小,就重写onMeasure()方法中进行处理。

4. 在 XML文件中设置自定义View的XML属性。

5. 如果想避免失去View的相关状态参数的话,就在onSaveInstanceState() 和 onRestoreInstanceState()方法中保存有关View的状态信息。

#Touch事件的传递机制

public boolean dispatchTouchEvent(MotionEventev);  //用来分派event

public boolean onInterceptTouchEvent(MotionEventev);//用来拦截event

public boolean onTouchEvent(MotionEventev);//用来处理event

#Android中的几种动画

Android3.0之前有2种,3.0后有3种。

1. FrameAnimation(逐帧动画):将多张图片组合起来进行播放,类似于早期电影的工作原理,很多App的loading是采用这种方式。

2. TweenAnimation(补间动画):是对某个View进行一系列的动画的操作,包括淡入淡出(Alpha),缩放(Scale),平移(Translate),旋转(Rotate)四种模式。

3. PropertyAnimation(属性动画):属性动画不再仅仅是一种视觉效果了,而是一种不断地对值进行操作的机制,并将值赋到指定对象的指定属性上,可以是任意对象的任意属性。


#Android中跨进程通讯有几种方式

1.访问其他应用程序的Activity

2.Content Provider

如访问系统相册

3.广播(Broadcast)

如显示系统时间

4.AIDL服务

AIDL理解(Android接口定义语言)

#Handler的原理

Handler 、 Looper 、Message 这三者都与Android异步消息处理线程相关的概念

## 1、Looper ##

对于Looper主要是prepare()和loop()两个方法。

Looper.prepare()方法不能被调用两次,同时也保证了一个线程中只有一个Looper实例。

## Looper主要作用: ##

1、 与当前线程绑定,保证一个线程只会有一个Looper实例,同时一个Looper实例也只有一个MessageQueue。

2、 loop()方法,不断从MessageQueue中去取消息,交给消息的target属性的dispatchMessage去处理。

## 2、Handler ##

使用Handler之前,我们都是初始化一个实例

在创建handler的时候都是复写handleMessage方法,然后根据msg.what进行消息处理


你可能感兴趣的:(Android)