kotlin 与java对比_kotlin和java对比

Kotlin是功能非常强大的编程语言,在java以及多种语言的基础上,去掉了冗余代码,方便开发者用较少的模板编写更多的代码。尤其是在Android开发中。除了编程语言自身和它的类之外,Kotlin还为已有的Java类提供一组好用的扩展。这个例子是请求API和下载结果的方法,通过对比我们可以更加直观了解kotlin的艺术。

API请求:Java 与 Kotlin对比

使用android studio的kotlin插件,可以很方便的把java代码转换成kotlin代码,通过两种语言进行对比,看看坚持使用Java会错过什么。

下面是java代码:

public String url(String apiUrl) {

try {

URL url = null;

url = new URL(apiUrl);

urlConnection = (HttpURLConnection) url.openConnection();

urlConnection.setRequestMethod("GET");

urlConnection.connect();

InputStream inputStream = urlConnection.getInputStream();

StringBuffer buffer = new StringBuffer();

if (inputStream == null) {

// Nothing to do.

return null;

}

reader = new BufferedReader(new InputStreamReader(inputStream));

String line;

while ((line = reader.readLine()) != null) {

buffer.append(line + "\n");

}

if (buffer.length() == 0) {

return null;

}

result = buffer.toString();

} catch (ProtocolException e) {

e.printStackTrace();

} catch (IOException e) {

Log.e("Request", "Error ", e);

return null;

} finally {

if (urlConnection != null) {

urlConnection.disconnect();

}

if (reader != null) {

try {

reader.close();

} catch (final IOException e) {

Log.e("Request", "Error closing stream", e);

}

}

}

return null;

}

下面是kotlin代码

fun url(apiUrl: String): String? {

return URL(apiUrl).readText()

}

没有看错,就是一行,是不是很神奇,Kotlin标准库为URL类提供了扩展函数,避免我们编写所有代码。

对于大量的响应,不建议使用这个函数,但是在大多数情况下,它是足够了。如果不这样,还有许多其他有趣的扩展函数,如:BufferedReader.forEachLine(),它产生行Sequence,我们可以用它们中任何一个。或是,可以通过BufferedReader.lineSequence()得到原始的Sequence。这时,你能够使用Sequence进行各种操作,如:过滤、排序、映射等等。

异步请求

主线程是负责UI呈现和交互的,我们不应该因其它运行时间长的任务阻塞它,这将会影响UI性能。在HTTP请求情况下, Android SDK甚至通过抛出一个异常来阻止我们这么做。在Android典型的解决方案是使用AsyncTask

。AsyncTask有一个doInBackground抽象方法,使得方法在另个线程中执行。

java例子

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

TextView textView = (TextView) findViewById(R.id.tv_title);

textView.setText("hello");

task = new AsyncTask() {

@Override

protected String doInBackground(Void... params) {

return requestFromServer("");

}

@Override

protected void onPostExecute(String s) {

if (!isFinishing() && !isCancelled()) {

Log.d("Request", s);

Toast.makeText(MainActivity2.this, "Request performed", Toast.LENGTH_LONG).show();

}

}

};

}

@Override

protected void onDestroy() {

super.onDestroy();

if (task != null) {

task.cancel(true);

task = null;

}

}

private String requestFromServer(String s) {

return s;

}

这实在不清晰也不直观。学习Kotlin开发时,我们不能漏掉Anko库。它主要目的是提供DSL方式用代码来创建布局,而不是用XML。我实际使用过XML,所以我现在不使用它了,但是它还是包括一整套非常有用的特性。特别对异步任务有些小的DSL。

Kotlin代码

val result = URL("").readText()

uiThread {

Log.d("Request", result)

longToast("Request performed")

}

}

实际上,你有async函数,它将在另一个线程中执行代码,并由uiThread

给出返回主线的机会。async是Context的扩展函数实现,且使用它弱应用,所以不会阻止GC释放内存。

uiThread

优势的方面是它依据使用类,以用不同的方式来实现。如果我们从Activity中调用它,假设actiivity.isFinishing()

返回true,uiThread代码是不会执行的,并且在此情况下不会崩溃。

假设你要用future,Async返回Java Future。如果你需要返回future结果,就可以用asyncResult。

你还能够用你自己的执行器:

doAsync(executor) {

// Some task

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值