kotlin基本类型、特殊符号和Anko库

基本类型

函数定义
函数定义使用关键字 fun,参数格式为:参数 : 类型

fun sum(a: Int, b: Int): Int {   // Int 参数,返回值 Int
    return a + b
}

表达式作为函数体,返回类型自动推断:

fun sum(a: Int, b: Int) = a + b
public fun sum(a: Int, b: Int): Int = a + b   // public 方法则必须明确写出返回类型

例如继承FragmentPagerAdapter时声明一个构造方法——

class ViewPagerAdapter(fm: FragmentManager) : FragmentPagerAdapter(fm) {
     init {
        //初始化
     }
}

静态方法

定义静态方法时用companion object{}包裹在方法外层

变量和常量
变量var: 可以被多次赋值

fun main(args:Array<String>){
    
    var a:Int = 12
    a = 20
    var b:String = "hello"
    b = "world"
    println(a) // 20
    println(b) // world
}

常量val:仅能一次赋值

fun main(args:Array<String>){
    
    val flag:Boolean = true
    // Error:(6, 5) Kotlin: Val cannot be reassigned
    // flag = false
}

变量和常量的简化写法
声明时数据类型和初始化至少给定一个,或者两者都声明
如果未进行初始化就必须给定数据类型
如果未进行给定数据类型,就需要进行初始化,kotlin编译器会自动根据右侧的值推导数据类型

// 仅初始化,类型推导
var a = "aaaa"
val b = true
// 仅声明类型
var c:String
val d:Int
// 类型和初始化都声明
var e:Int = 12
val f:String = "abc"

操作符

as
用于类型转换
为导入指定一个别名
as? 用于安全类型转换(它可以在失败时返回 null )
break 终止循环的执行
class 声明一个类
continue 继续最近层循环的下一步
do 开始一个 do/while 循环(后置条件的循环)
else 定义一个 if 表达式条件为 false 时执行的分支
false 指定布尔类型的“假”值
for 开始一个 for 循环
fun 声明一个函数
if 开始一个 if 表达式
in
指定在 for 循环中迭代的对象
用作中缀操作符以检查一个值属于一个区间、 一个集合或者其他定义“contains”方法的实体
在 when 表达式中用于上述目的
将一个类型参数标记为逆变
!in
用作中缀操作符以检查一个值不属于一个区间、 一个集合或者其他定义“contains”方法的实体
在 when 表达式中用于上述目的
interface 声明一个接口
is
检查一个值具有指定类型
在 when 表达式中用于上述目的
!is
检查一个值不具有指定类型
在 when 表达式中用于上述目的
null 是表示不指向任何对象的对象引用的常量
object 同时声明一个类及其实例
package 指定当前文件的包
return 从最近层的函数或匿名函数返回
super
引用一个方法或属性的超类实现
在次构造函数中调用超类构造函数
this
引用当前接收者
在次构造函数中调用同一个类的另一个构造函数
throw 抛出一个异常
true 指定布尔类型的“真”值
try 开始一个异常处理块
typealias 声明一个类型别名
val 声明一个只读属性或局部变量 ,尽量用这个
var 声明一个可变属性或局部变量
when 开始一个 when 表达式(执行其中一个给定分支)
while 开始一个 while 循环(前置条件的循环)

特殊符号

  • 、 - 、 * 、 / 、 %数学操作符
  • 也用于将数组传递给 vararg 参数
    =
    赋值操作符
    也用于指定参数的默认值
    += 、 -= 、 *= 、 /= 、 %= 广义赋值操作符
    ++ 、 --递增与递减操作符
    && 、 || 、 !逻辑“与”、“或”、“非”操作符(对于位运算,请使用相应的中缀函数)
    == 、 != 相等操作符(对于非原生类型会翻译为调用 equals() )
    === 、 !== 引用相等操作符
    < 、 > 、 <= 、 >= 比较操作符(对于非原生类型会翻译为调用 compareTo() )
    [ 、 ] 索引访问操作符(会翻译为调用 get 与 set )
    !! 断言一个表达式非空(一般别用,尽量别用….请看这里)
    ?. 执行安全调用(如果接收者非空,就调用一个方法或访问一个属性)
    ?: 如果左侧的值为空,就取右侧的值(elvis 操作符)
    :: 创建一个成员引用或者一个类引用
    … 创建一个区间(比如for里面)
    : 分隔声明中的名称与类型
    ? 将类型标记为可空
    ->
    分隔 lambda 表达式的参数与主体
    分隔在函数类型中的参数类型与返回类型声明
    分隔 when 表达式分支的条件与代码体
    @
    引入一个注解
    引入或引用一个循环标签
    引入或引用一个 lambda 表达式标签
    引用一个来自外部作用域的 “this”表达式
    引用一个外部超类
    ; 分隔位于同一行的多个语句
    $ 在字符串模版中引用变量或者表达式
    _
    在 lambda 表达式中代替未使用的参数
    在解构声明中代替未使用的参数

导入Anko库

dependencies {
    // Anko Commons
    implementation "org.jetbrains.anko:anko-commons:$anko_version"
 
    // Anko Layouts
    implementation "org.jetbrains.anko:anko-sdk25:$anko_version" // sdk15, sdk19, sdk21, sdk23 are also available
    implementation "org.jetbrains.anko:anko-appcompat-v7:$anko_version"
 
    // Coroutine listeners for Anko Layouts
    implementation "org.jetbrains.anko:anko-sdk25-coroutines:$anko_version"
    implementation "org.jetbrains.anko:anko-appcompat-v7-coroutines:$anko_version"
 
    // Anko SQLite
    implementation "org.jetbrains.anko:anko-sqlite:$anko_version"

}
buildscript {
    ext.anko_version = '0.10.1'
}

导入Anko后使用网络获取资源

 doAsync {
            var toString = URL("http://www.qubaobei.com/ios/cf/dish_list.php?stage_id=1&limit=10&page=1 ").readText()
            println(toString+"\n")
            uiThread {
                tv_text.setText(toString)
            }
        }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值