本文是第一次尝试使用kotlin语言编写android代码,并没有什么高深的知识点,在使用的时候其实也只是将java语言转化为kotlin,旨在通过着一个例子作为kotlin入门。事实上结果比我想象的还要好,因为不懂所以不敢说kotlin绝对好坏,但是kotlin的代码风格是真的喜欢,正在积极入坑中,后续可能会写一系列kotlin的笔记,来记录自己的kotlin学习之旅。
Kotlin在AndroidStudio中的使用方法
目前使用的studio版本为2.3.0,使用kotlin需要下载kotlin plugins。
在加载kotlin plugins完成后,就可以在studio中使用kotlin了,通过Tools->Kotlin-> Configure Kotlin in Project将kotlin应用到自己的项目中。
通过code->Convert Java File to Kotlin File可以将已有的java代码转化为kotlin代码。本次实践的代码基本就是这么来的 -_-|||
kotlin vs java by CheckPermissionUtil
第一次的尝试基本是通过studio的代码转化来的。真的是毫无技术含量啊。。。下面会对比相同功能的代码块,以及对kotlin相应知识点的记录。
- 类继承,abstract关键字和java一样,抽象类,类中有抽象方法。: 标识继承
abstract class BaseActivity :AppCompatActivity()
- 抽象方法
abstract fun initActivity()
- open关键字代表这个方法可以被子类复写,kotlin中方法如果需要被子类复写,必须用open标注,子类复写时必须用override标注,冒号后为返回值,抽象方法默认open。
override fun checkPermission(): Boolean
open fun checkPermission(): Boolean
- object 类似于java中static标注,静态方法工具类可以直接用object修饰,可以在使用时直接用类名.(方法名/属性) kotlin中没有static类型的fun,可以用Companion Objects,使用Companion Objects包裹体内的方法可以使用类似于java静态方法调用的方式调用。
object CheckPermissionUtil
- kotlin 里的变量定义有两种,val 和 var。其中 val 等同 Java 中 final 修饰的变量(只读)。kotlin 的变量定义支持 赋值时类型推断,且 所有变量默认被修饰为不可为 null,必须显式在类型后添加 ? 修饰符才可赋值为 null。
- 集合.filter:Returns a list containing only elements matching the given
public inline fun Array.filter(predicate: (T) -> Boolean): List {
return filterTo(ArrayList(), predicate)
}
- 集合.none:Returns true if no elements match the give
public inline fun IntArray.none(predicate: (Int) -> Boolean): Boolean {
for (element in this) if (predicate(element)) return false
return true
}
代码对比
基本上涉及到这些知识点,下边给一些java代码和kotlin的对比:
[java]
private static List findDeniedPermissions(Activity activity, String[] permissions) {
List needRequestPermissionList = new ArrayList<>();
for (String perm : permissions) {
if (ContextCompat.checkSelfPermission(activity, perm) != PackageManager.PERMISSION_GRANTED
|| ActivityCompat.shouldShowRequestPermissionRationale(activity, perm)) {
needRequestPermissionList.add(perm);
}
}
return needRequestPermissionList;
}
[kotlin]
private fun findDeniedPermissions(activity: Activity, permissions: Array): List {
return permissions.filter { ContextCompat.checkSelfPermission(activity, it) != PackageManager.PERMISSION_GRANTED || ActivityCompat.shouldShowRequestPermissionRationale(activity, it) }
}
[java]
public static void showMissingPermissionDialog(final Activity activity) {
AlertDialog.Builder builder = new AlertDialog.Builder(activity);
builder.setTitle("授权提示");
builder.setMessage("取消授权将无法使用app");
// 拒绝, 退出应用
builder.setNegativeButton("取消",
new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
activity.finish();
}
});
builder.setPositiveButton("设置",
new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
startAppSettings(activity);
}
});
builder.setCancelable(false);
builder.show();
}
[kotlin]
fun showMissingPermissionDialog(activity: Activity) {
val builder = AlertDialog.Builder(activity)
builder.setTitle("授权提示")
builder.setMessage("取消授权将无法使用app")
builder.setNegativeButton("取消") { _, _ -> activity.finish() }
builder.setPositiveButton("设置") { _, _ -> startAppSettings(activity) }
builder.setCancelable(false)
builder.show()
}
[java]
public static boolean verifyPermissions(int[] grantResults) {
for (int result : grantResults) {
if (result != PackageManager.PERMISSION_GRANTED) {
return false;
}
}
return true;
}
[kotlin]
fun verifyPermissions(grantResults: IntArray): Boolean {
return grantResults.none { it != PackageManager.PERMISSION_GRANTED }
}
看不出来什么不要紧,其实我也什么都不知道,什么基本语法啊,什么进阶语法啊,什么都不知道啊。。。。。可是,兴趣啊,反正目的已经达成。。。。。
興趣是最好的老師。