Kotlin笔记

时间:2022-06-01 19:47:49

官网:

http://kotlinlang.org/

http://kotlinlang.org/docs/reference/

中文教程: http://kotlindoc.com/

Gradle: http://gradle.org/

KotlinMvc:  http://code.taobao.org/svn/MyKotlinMvc/

安装:

1. Intellij Idea :

2. Kotlin 编译器。 https://github.com/JetBrains/kotlin

JVM最简生存指南

http://www.importnew.com/10127.html

必读, 是写给 .Net 开发者 转 Java 人员的。

Spring+Kotlin:

https://spring.io/blog/2016/02/15/developing-spring-boot-applications-with-kotlin

技巧:

1. 代码混编。使用 Intellij Idea ,时,可以使用 Java + Kotlin + Scala 混合编译。 需要添加各自的包引用。

2. 把Java代码 Copy 到 Kotlin 时,会有提示,让系统自动进行转换。

3. 函数的参数是不可修改的, 如果想修改, 可以重新定义一个同名的参数,如:

var startIndex = startIndex;

问题

1. 泛型

  Java声明泛型时,在使用时,可以不指定泛型, 如: List jm = new ArrayList<String>();   C#可以这样:

  public class JsonMsg<T> : JsonMsg{}

  但 Kotlin 不能使用同名泛型类。

2.  关于 Maven :

  http://blog.csdn.net/ubuntu64fan/article/details/7462981 ,作者极力反对, 首推: Rake , 其次是 Ant

  http://westsky.blog.51cto.com/358372/1590573 ,推荐顺序是: Gradle > Ant > Maven.

3.  Cloneable

  Cloneable 接口的 clone 方法居然是 protected,直接导致泛型参数是Cloneable对象无法直接调用 clone 方法。

4 . 死循环调用:

open class MapModel2   : HashMap<String,String> ()  {
companion object{} override fun get(key: String): String {
return super.get(key).toString()
}
}
class abc : MapModel2() {
companion object{
@JvmStatic
var instance:MapModel2? = null;
}
var Name= ""; override fun get(key: String): String {
return super.get(key).toString()
}
}
fun main(arg: Array<String>) {
abc.instance = abc();
abc.instance!!["Name"] = "OK";
println(abc.instance!!["Name"]);
}

必须逐级重写 get 方法,否则就会: 在 abc 里执行get , 在 MapModel2 里执行get ,由于没有重写,转而执行 abc 里的 get 继而造成死循环。

该问题已提交到jetbrains ,并已得到解决: https://youtrack.jetbrains.com/issue/KT-13116?replyTo=27-1522462 。

5. jvm-target 1.6的问题

Bug1:

Kotlin Jar包项目,使用 Artifacts Build,是不对的,会使用 1.6

  查看 jar包里的 /META-INF/MANIFEST.MF 内容如下:

  

Manifest-Version: 1.0
Implementation-Title: HttpComponents Apache HttpClient
Implementation-Version: 4.5.3
Archiver-Version: Plexus Archiver
Built-By: oleg
Specification-Vendor: The Apache Software Foundation
Implementation-Vendor-Id: org.apache
Specification-Title: HttpComponents Apache HttpClient
url: http://hc.apache.org/httpcomponents-client
Implementation-Vendor: The Apache Software Foundation
X-Compile-Target-JDK: 1.6
Implementation-Build: tags/4.5.3-RC1/httpclient@r1779741; 2017-01-21 1
6:58:35+0100
X-Compile-Source-JDK: 1.6
Created-By: Apache Maven 3.0.5
Build-Jdk: 1.7.0_75
Specification-Version: 4.5.3

Bug2:

  在 idea 的 Project Structure 里,把 target platform 改为 1.6 ,是不成功的。 除非选中 使用项目设置(use project settings )再选择 1.8

查看项目的 iml 文件。

 <facet type="kotlin-language" name="Kotlin">
<configuration version="2" platform="JVM 1.6" useProjectSettings="false">
<compilerSettings />
<compilerArguments>
<option name="jvmTarget" value="1.6" />
<option name="languageVersion" value="1.1" />
<option name="apiVersion" value="1.1" />
<option name="pluginClasspaths">
<array />
</option>
<option name="coroutinesWarn" value="true" />
<option name="pluginOptions">
<array />
</option>
</compilerArguments>
</configuration>
</facet>

应该使用 Maven 的 Package 打包,如果出现: 1.8 1.6 的错误,应该添加  jvmtarget 如下:

<plugin>
<artifactId>kotlin-maven-plugin</artifactId>
<groupId>org.jetbrains.kotlin</groupId>
<version>${kotlin.version}</version>
<configuration>
<jvmTarget>1.8</jvmTarget>
<compilerPlugins>
<plugin>spring</plugin>
</compilerPlugins>
</configuration> <executions>
<execution>
<id>compile</id>
<phase>compile</phase>
<goals>
<goal>compile</goal>
</goals>
</execution>
<execution>
<id>test-compile</id>
<phase>test-compile</phase>
<goals>
<goal>test-compile</goal>
</goals>
</execution>
</executions>
<dependencies>
<dependency>
<groupId>org.jetbrains.kotlin</groupId>
<artifactId>kotlin-maven-allopen</artifactId>
<version>${kotlin.version}</version>
</dependency>
</dependencies>
</plugin>

jar包项目和引用jar包的项目都要添加。

编译运行的差异

编译: mvn clean kotlin:compile package

运行  jar -jar  -noverify  xx.jar

字节码校验器 , 具体校验:
变量要在使用之前进行初始化。
方法调用与对象引用类型之间要匹配。
访问私有数据和方法的规则没有被违反。
对本地变量的访问都在运行时堆栈内。
运行时堆栈没有溢出。

java 可以使用  -noverify

tomcat Java_opts 在  setenv.sh 里,分两种情况:

1. startup.sh , 可以用 -noverify

2. daemon.sh 必须用 -Xverify:none

-Xverify:none 兼容性最好.

快捷键:

使用 VS 设置。

Ctrl + Shift + C 拷贝当前文件的全路径。

计算属性生成Json字段

如果设置了 JSON 序列化字段属性,Kotlin 中的 val 计算属性 不会生成字段,所以不会生成 JSON字段。

典型的例子是  IdUrl 中添加  val fullUrl 字段,该字段是根据 host 配置 以及 Url ,动态返回的属性.

添加 @JvmField 会报错,因为不能作用于 val 属性的 get() 方法。

解决方法:

class IdUrl {
fun set_fullUrl() {
if (this.url.isEmpty()) return;
this.fullUrl = "http://dev8.cn" + this.url;
} var fullUrl: String = ""
get
       private set var url: String = ""
get() = field
set(value) {
field = value;
this.set_fullUrl()
} }