一、接收系统广播
有静态注册和动态注册两种方法
静态注册指在AdroidManifest.xml文件中注册
动态注册当然是指代码实现实现注册
由系统发出一条广播,然后我们指定一个action来接收广播并且做出相应的动作
这里有一个比较颠覆认知的东西:
我们的软件居然可以在未启动时对系统的广播做出响应,有点难以想象
BroadcastReceiver不允许开线程,所以不能在里面放一些耗时的操作
二、发送自定义广播
广播有两种:标准广播和有序广播
标准广播是异步的同时接收
有序广播是同步的有序的接收,并且前面的广播可以截断后面的
自定义的广播默认是隐式广播无法被静态注册的BroadcastReceiver接收到
需要设置包名用setPackage设置一下包名使得广播变成显式广播
设置有序广播的操作也比较简单调用sendOrderedBroadcast即可
AdroidManifest里面有个标签android:priority = “100”
可以给广播设置优先级,优先级高的可以先接收到广播
三、广播的最佳实践:实现强制下线
这里面利用了activity管理的一部分内容,总体实现难度不是很大,广播响应在baseActivity里面执行使得只需要继承此类即可实现无论在哪个界面都可以实现强制下线功能
四、kotlin的高阶函数
1.高阶函数简单介绍
这部分对于初学kotlin的我来讲,真的有亿点点难
高阶函数的定义一个函数是接收另一个函数为参数则称此函数为高阶函数,涉及一个新的类型:函数类型
无返回值用Unit (kotlin),java里面是用void,举个栗子
fun exmple(func:(int ,String)-> Unit ){
val result = func(int,String)
return result
}
也可以利用lambda表达式的形式进行调用高阶函数
exmple{n1,s1 ->
n1.toSting + s1
}
2.内联函数
由于高阶函数背后的实现原理是利用创建匿名类实例实现的,所以为了解决过高的内存开销这个痛点,
引入了内联函数的概念,利用内联函数解决,举个栗子
inline fun exmple(func:(int ,String)-> Unit ){
val result = func(int,String)
return result
}
3.noinline和crossinline
昨天看这个看的头疼,可能是从未接触过,有点不理解
inline关键字一声明代表里面所有的函数类型关键字都会被声明成内联函数
而noinline可以让部分函数类型不内联,举个栗子
inline fun inlineTest(fun1:()->Unit,noinline fun2:()->Unit){
}
那为什么不内联?这目前理解的不是非常深,因为没遇见过
return@fun1
return
crossinline就更加头疼了
出现的原因:在内联高阶函数中创建了另外的lambda表达式或者匿名类的实现
这里是lambda表达式或者匿名类中调用函数类型参数不允许使用return关键字而
高阶函数声明为inline可以允许他们之间产生了矛盾,不过一个好的想法,里面的
lambda表达式或者匿名类不进行return 不就好了(也可以进行局部返回),故产生
了crossinline进行一种约定,举个栗子
inline fun runRunnable(crossinline fun1:()->Unit){
val runable = Runnable{
fun1()
}
runnable.run()
}
五、git初识
几个新学的的git命令
配置身份
git config --global user.name "hhh"
git config --global user.email "hhh@email.com"
git config --global user.name
git config --global user.email
创建本地仓库
git init
ls -al
提交本地代码
add和commit命令
add用于添加想要提交的代码
commit用于提交
git add build.gradle
git add app
git add .
git commit -m "First commit"
这一章整体来讲还是比较充实的,除了高阶函数有点难
|