kotlin基本语法

<pre>

classMainTestActivity : Activity() {
     //当某个变量的值可以为null的时候,必须在声明处的类型后添加?来标识该引用可为空。
     override fun onCreate(savedInstanceState: Bundle?) {
         super.onCreate(savedInstanceState)
         setContentView(R.layout.main_test_activity)
         kotlin_test.setText("kotlin测试")
         
         valtestButton= findViewById(R.id.kotlin_test_btn) as Button
         testButton.setText("进行kotlin测试")
         testButton.setOnClickListener {
             Toast.makeText(this,"kotlin点击事件",Toast.LENGTH_LONG).show()
         }

         //变量声明:
         //可以用关键字var声明为可变的,否则使用只读关键字val 
         //一次赋值(只读)的局部变量:
         //int类型常量定义
         val aConstant: Int =1000
         val bConstant: Int =200
         val cConstant: Int =300
         
         //可变变量:
         var dVariable: Int
         dVariable=5

         Log.d("alen","sum is " + sum(aConstant,bConstant))
         Log.d("alen","printSum is " + printSum(aConstant,bConstant,cConstant))

         stringTemplate()
         printValue("4","6")
         printValue("4","")
         val length= getStringLength("nihao")
         Log.d("alen","length is " +length)
         loopForTest1()
         loopForTest2()
         whileForTest()
         Log.d("alen","msg is " + whenForTest("hello"))
         Log.d("alen","msg is " + whenForTest(1))
         mapForTest()
         setForDataClassTest()}   
     }
}
//使用字符串模板
fun stringTemplate(): Unit {
    var arg: Int =1
    val s1= "arg is$arg"
    Log.d("alen","s1 is " +s1)

    arg=2
    //模板中的任意表达式:
    var s2= "${s1.replace("is","was")}, but now arg is$arg"
    Log.d("alen","s2 is " +s2)
}
// 带有两个Int参数、返回Int的函数
funsum(arg1: Int,arg2: Int): Int {
    returnarg1 + arg2
}
// 函数返回无意义的值,Unit返回类型可以省略
funprintSum(arg1: Int,arg2: Int,arg3: Int): Unit {
    Log.d("alen","sum is " + (arg1 + arg2 + arg3))
}
// 把字符串转为Int
fun parseInt(str: String): Int? {
    // try表达式
    try{
       if(str !=null) {
           returnstr.toInt()
       }
    } catch (e: NumberFormatException) {
       return null}return null
    }
}

funprintValue(str1: String,str2: String) {
    val result1: Int? = parseInt(str1)
    valr esult2: Int? = parseInt(str2)
    if(result1!=null&&result2!=null) {
       Log.d("alen","value is " +result1*result2)
    } else {
       Log.d("alen"," '$result1' or '$result2' is null")
    }
}
// 打印字符串的长度
fun getStringLength(obj: Any): Int? {
    if(obj is String) {
        return obj.length
    }
    return null
}
// 迭代
fun loopForTest1() {
    val items=listOf("item1","item2","item3")
    for(item in items) {
        Log.d("alen","item is " +item);
    }
}
// 通过索引值进行循环
fun loopForTest2() {
    val items=listOf("item1","item2","item3")
    //使用in运算符来检测某个数字是否在指定区间内:
    for(index in items.indices) {
        Log.d("alen","item index is$index,value is${items[index]}")
    }
    
    if(-1 !in items.indices) {
       Log.d("alen","-1 not in range")
    }
    
    // 从9到0开始迭代,步长为3
    // 区间表达式由具有操作符形式..的rangeTo函数辅以in和!in形成。
    // downTo()函数 倒序迭代数字
    // step()函数 以不等于1的任意步长迭代数字
    for(x in 9 downTo 0 step 3) {
        Log.d("alen","x is " +x)
    }

    //创建一个不包括其结束元素的区间,可以使用until函数:
    for(x in 1 until 10) {
        // i in [1, 10)排除了10
        Log.d("alen","until x is " +x)
    }
}
// while循环测试
fun whileForTest() {
    val items=listOf("apple","item2","banana")
    items.isEmpty()
    Log.d("alen","items size is " +items.size)
    //区间range
    Log.d("alen","items indices is " +items.indices)
    if(items.size >2) {
       Log.d("alen","items index 2 is " +items.get(2))
    }

    Log.d("alen","items last index is " +items.lastIndex)
    //使用in运算符来判断集合内是否包含某实例:
    when {
        "apple"initems-> {
              Log.d("alen","items contain apple")
         }

        "orange"!initems-> {
              Log.d("alen","items do not contain orange")
        }
    }
}
// when条件测试
fun whenForTest(obj: Any): String =
      when(obj) {
          1-> {
               Log.d("alen","test one")
               "one"
          }
          "hello" -> "Greeting"
          isLong -> "Long"
          !isString -> "Not a string"
          else-> "Unkonwn"
      }
// map测试
fun mapForTest() {
    val map=mapOf("a"to"1","b"to"2","c"to"3")
    Log.d("alen","map key is a,value is " +map["a"])
    for(item in map) {
        Log.d("alen","map key is " +item.key + ",value is " +item.value)
    }
}
// set测试
// set
// 1. Set中没有重复的对象
// 2. Set中对象不按特定的方式排序
//判断两个对象的是否重复标准是hashCode()和equals()两个参考值,
//也就是说只有两个对象的hashCode值一样与equals()为真时,才认为是相同的对象
// fun hashSetOf(vararg elements: T): java.util.HashSet
// fun linkedSetOf(vararg elements: T): java.util.LinkedHashSet
// sortedSetOf(comparator: java.util.Comparator, vararg elements: T): java.util.TreeSet
// fun sortedSetOf(vararg elements: T): java.util.TreeSet
funsetForDataClassTest() {
    // Book是一个data class,用来做data model使用
    val bookA= Book("A",20,"AA")
    val bookB= Book("B",30,"BB")
    val bookC= Book("C",20,"CC")
    val bookD= Book("D",50,"DD")
    val bookE= Book("B",30,"EE")

    val set=setOf(bookA,bookB,bookC,bookD)
    for(iteminset) {
        Log.d("alen","item$item, hashCode${item.hashCode()}")
    }

    Log.d("alen","--------------------------")

    val mutalbeSet=mutableSetOf(bookA,bookB,bookC,bookD,bookE)

    for(item in mutalbeSet) {
        Log.d("alen","item is$item, hashCode is${item.hashCode()}")
    }

    mutalbeSet.add(Book("甲乙丙丁",50,"EE"))
    Log.d("alen","remove B value is " +mutalbeSet.remove(bookB))
    Log.d("alen","remove E value is " +mutalbeSet.remove(bookE))

    Log.d("alen","--------------------------")

    for(item in mutalbeSet) {
        Log.d("alen","item is$item, hashCode is${item.hashCode()}")
    }
}

</pre>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,362评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,330评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,247评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,560评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,580评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,569评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,929评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,587评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,840评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,596评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,678评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,366评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,945评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,929评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,165评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,271评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,403评论 2 342

推荐阅读更多精彩内容

  • 1.定义函数 带有两个 Int 参数、返回 Int 的函数: 将表达式作为函数体、返回值类型自动推断的函数: 函数...
    正义吖阅读 540评论 0 2
  • 该文为个人学习笔记,如有错误,请各位大佬指导~~~ 针对于一些未具体说明知识点,后续会进行补充。 知识点可能会有点...
    半截铅笔阅读 238评论 0 0
  • 包声明 如: 引入类 与Java没啥区别 有多个包会默认导入到每个 Kotlin 文件中: 函数定义 一般函数 函...
    郎官人阅读 406评论 1 0
  • 带你快速入门,读懂Kotlin基本语法~ 基本语法 定义包 包应该在源文件的头部声明: 不需要匹配目录和包:源文件...
    AeolusFei阅读 681评论 0 2
  • 上篇介绍了Kotlin的特点以及其在Android Studio上的配置步骤,下面接着记录一些Kotlin的基本语...
    ArsenicBing阅读 616评论 0 2