Kotlin 语法

字符串比较

var str1 = "chaychan"
var str2 = "chaychan"
println(str1 == str2)

比较两个字符串,如果两个字符串的内容一致,在Java中使用 str1 == str2 时,是比较两个字符串的地址值,很清楚两个字符串的地址不一样,返回false,但是在kotlin中,则不是如此,比较的只是字符串的内容,而=相当于Java中的,用来比较引用对象, 上述代码返回的是true。

equal函数

  1. equals(str:String)

方法中的参数是与之对比的字符串,默认不忽略大小写,即大小写敏感,比如:

var str1 = "chaychan"
var str2 = "ChayChan"
println(str1.equals(str2))

打印结果为false,因为不忽略大小写的话,两个字符串内容对比是不一致的,所以返回false。
2. equals(str:String,ignoreCase:Boolean)
方法中有两个参数,第一个参数是与之对比的字符串,第二个参数是布尔类型的值,是否忽略大小写,如:

var str1 = "chaychan"
var str2 = "ChayChan"
println(str1.equals(str2,true))

返回结果为true。

源码优化分析

源码

1.Lateinit

在View声明阶段,都会需要使用lateinit来延迟声明变量。

class TaskActivity : AppCompatActivity(){
  private val CURRENT_FILTERING_KEY = "CURRENT_FILTERING_KEY";
  private lateinit var drawerLayout : DrawerLayout
  private lateinit var tasksPresenter:TasksPresenter
}

kotlin中延迟声明还包括lazy的方式

val name:String by lazy {"cangwang"}
lateinit var drawLayout:drawLayout

区别在于:

  1. .lazy{}只能用再val类型,lateinit只能用在var类型
  2. .lateinit不能用在可空的属性上和java的基本类型上lateinit var name:String会报错
  3. .lateinit可以在任何位置初始化并且可以初始化多次,因为其衔接var变量.而lazy在第一次被调用时就被初始化,其衔接的是val常量,想要被改变只能重新定义
2.findViewById

Api26前:

@Override
public View findViewById(@IdRes int id){
  return getDelegate().findViewById(id);
}

Api26之后

@SuppressWarnings("TypeParameterUnusedInFormals")
@Override
public <T extends View> T indViewById(@IdRes int id){
  return getDelegate().findViewById(id);
}
五个kotlin Standard.kt里面的函数:apply,with,let,run,also
  1. apply作用
setSupportActionBar(findViewById<Toolbar>(R.id.toolbar))
supportActionBar?.apply{
  setDisplayHomeAsUpEnabled(true)
  setDisplayShowHomeEnabled(true)
}

在函数内可以通过this指代该对象,返回值为该对象自己
2. with函数
将某对象作为函数的参数,在函数内可以通过this指代该对象.返回值为函数块的最后一行或指定return表达式

override fun getView(i:Int,view:View?,viewGroup:ViewGroup):View{
  val rowView=Vview?:LayoutInflater.from(viewGroup.context).inflate(R.layout.task_item,viewGroup,false)
  val task = getItem(i)
  with(rowView.findViewById<TextView>(R.id.title)){
    text = task.titleForList
  }
  with(rowView.findViewById<CheckBox>(R.id.complete)){
    isChecked=task.isCompleted
    rowView.setBackgroundDrawable(...)
    setOnClickListener{

    }
  }
}
3.lat函数
private fun showMessage(message:String){
  view?.let{
    Snackbar.make(it,message,Snackbar.LENGTH_LONG).show()
  }
}

将对象作为函数参数,在函数块内可以通过it指代该对象.返回值为函数块的最后一行或指定return表达式

4. run函数

其有两种表达式:

  • 第一种无参数输入
  • 第二种会将对象本身this给函数调用
    返回值为函数块最后一行,或者指定return表达式

Object

单例对象是使用Object申明
Kotlin没有静态属性和方法,需要使用单例对象来实现类似的功能.

data

相当于java中定义的数据bean类,其可以直接在属性之后编写get和set方法

@JvmOverloads

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

轻口味

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值