协程(一)——什么是协程

简介: 协程是一种全新的处理并发的设计模式,说到并发,自然就想到异步,既然是异步,那么我们就想到很多处理异步的方式,比如Rxjava,Android开发中的Handler、异步任务、service等。

协程是一种全新的处理并发的设计模式,说到并发,自然就想到异步,既然是异步,那么我们就想到很多处理异步的方式,比如Rxjava,Android开发中的Handler、异步任务、service等。

做为一个Android开发者,单开始用kotlin的时候,以为协程是kotlin才有,其实不是。

协程不是一个新的概念,而是很早之前就有,最早使用协程的编程语言可以追溯到 1967 年的 Simula 语言,在过去几年间,协程这个概念发展势头迅猛,现已经被诸多主流编程语言采用,比如 Javascript、C#、Python、Ruby 以及 Go 等。Kotlin 的协程是基于来自其他语言的既定概念。

kotlin 在1.3开始引入协程。我们主要也kotlin的协程来讲解,然后再延伸到Android上。那么既然有很多处理并发的方法了,为什么还会用协程呢?先从以下几个概念来开始了解

什么是进程
进程就是一个程序的执行实例,一个app就是一个进程

什么是线程
线程属于进程,是最小的任务执行单位,一个进程有且只有一个主线程(在Android上就是UI线程)、若干子线程。

什么是协程
java处理并发时必须切换线程,线程是最小任务执行单位,并发时必须多个线程来处理
Kotlin中的协程提供了一种全新处理并发的方式(无需切换线程),轻量级的线程,可以使用它来简化异步执行的代码,它的目的就是在保证主线程(在Android上就是UI线程)安全的基础上处理耗时任务,协程依赖于线程存在,当线程销毁了,协程也就不存在了。

协程的特点
轻量级的线程、开销小无成本、 数量几乎没有限制
容易控制生命周期
用同步的方式去表达异步
依赖于当前线程,线程结束,协程也会结束
运行在单线程中的并发处理
为什么使用协程
避免了线程间的切换、调度、数据传递导致的性能、资源浪费
协程的核心
要了解协程的核心,先从一个关键字开始,那就是spend,suspend是暂停,挂起的意思,用于修饰函数,那么被suspend修饰的函数,就是挂起函数,此函数只能在协程中或者被另外一个suspend修饰的的函数调用。

协程代码块中遇到suspend函数,会将该函数挂起执行(可以理解为当前线程中虚拟一个子线程来执行挂起函数=异步,并没有切换线程也不会阻塞当前线程),挂起函数执行完毕以后,继续执行剩余协程代码块中代码,这是协程实现异步的核心!

我们主线程(Android中指UI线程)挂起是会阻塞UI界面的,但是利用协程的核心功能,在主线程中开启一个协程去处理耗时操作,可以很好的避免阻塞问题。

很多人会问,我直接在主线程开一个新的子线程做耗时操作不也一样的吗?

答案就是,是一样,效果上是一样,但是协程做法简单,上面也说了,可以避免协程间的切换、调度,资源浪费等,因为子线程操作完耗时操作后是要切换到主线程更新UI的,而协程可以做到可以不能切换线程也可以更新UI。

而且但业务逻辑复杂的情况下,比如并发三个请求,而且是三个请求是相互关联的,这种情况下用普通的处理异步操作是很累赘很麻烦的,用协程就不一样了。这里先卖个关,下一篇文章会讲到。

依照上面协程的核心,我们看个例子:

fun test() {
    GlobalScope.launch {
        val ret= sf1()
        Log.d...... //log2 thread name
    }
    Log.d......// log3 thread name
}
suspend fun sf1():Int{
  delay(2000)
  Log.d......// log1 thread name
  //todo
}

以上代码在主线程被调用,log打印顺序是log3、log1、log2,sf1函数是可挂起函数,在协程中该函数被挂起,但并不会阻塞主线程!所以依旧先打印出了log3。
而且如果在3个log打印处打印当前线程名称,得到的结果都是是 主线程!如果你之前没有了解过协程的概念,那这将会颠覆你对异步的认知,无需切换线程也能异步!而这仅仅是刚刚开始!
通俗的表达:协程异步就是将耗时的函数标记为suspend,并在协程中调用!
以上就是针对什么是协程的一些内容,下一篇开始讲解协程的使用。

相关文章
|
移动开发 Java Android开发
构建高效Android应用:Kotlin协程的实践之路
【2月更文挑战第31天】 在移动开发领域,性能优化和流畅的用户体验一直是开发者追求的目标。随着Kotlin语言的流行,其异步编程解决方案——协程(Coroutines),为Android应用带来了革命性的并发处理能力。本文将深入探讨Kotlin协程的核心概念、设计原理以及在Android应用中的实际应用案例,旨在帮助开发者掌握这一强大的工具,从而提升应用的性能和响应能力。
|
存储 运维 监控
双11黑科技,阿里百万级服务器自动化运维系统StarAgent揭秘
还记得那些年我们半夜爬起来重启服务器的黑暗历史吗?双11期间,阿里巴巴百万量级主机管理能安全、稳定、高效,如丝般顺滑是如何做到的?阿里巴巴运维中台技术专家宋意,首次直播揭秘阿里IT运维的基础设施StarAgent,详细分析StarAgent是如何支持百万级规模服务器管控?如何像生活中的水电煤一样,做...
17019 16
|
弹性计算 缓存 测试技术
云服务器2核4G能支持多少人同时访问?2核4G5M并发量评测!
阿里云2核4g服务器能支持多少人访问?2核4G服务器并发数性能测试,阿小云账号下的2核4G服务器支持20人同时在线访问,然而应用不同、类型不同、程序效率不同实际并发数也不同,2核4G服务器的在线访问人数取决于多个变量
|
JavaScript Linux 编译器
c++开源协程库libgo介绍及使用
c++开源协程库libgo介绍及使用
|
调度 开发者 UED
Kotlin 中的协程是什么?
【8月更文挑战第31天】
1395 1
|
Dubbo 网络协议 Java
RPC框架:一文带你搞懂RPC
这篇文章全面介绍了RPC(远程过程调用)的概念、原理和应用场景,解释了RPC如何工作以及为什么在分布式系统中广泛使用,并探讨了几种常用的RPC框架如Thrift、gRPC、Dubbo和Spring Cloud,同时详细阐述了RPC调用流程和实现透明化远程服务调用的关键技术,包括动态代理和消息的编码解码过程。
RPC框架:一文带你搞懂RPC
终于明白:有了线程,为什么还要有协程?
其实,在早期计算机并没有包含操作系统,这个时候,这个计算机只跑一个程序,这个程序独享计算机的所有资源,这个时候不存在什么并发问题,但是对计算机的资源来说,确实是一种浪费。早期编程都是基于单进程来进行,随着计算机技术的发展,于是,操作系统出现了,操作系统改变了这种现状,让计算机可以运行多个程序,并且不同的程序占用独立的计算机资源,如内存,CPU等。
|
存储 消息中间件 监控
容器日志采集利器Log-Pilot
容器时代越来越多的传统应用将会逐渐容器化,而日志又是应用的一个关键环节,那么在应用容器化过程中,如何方便快捷高效地来自动发现和采集应用的日志,如何与日志存储系统协同来高效存储和搜索应用日志,本文将主要跟大家分享下如何通过Log-Pilot来采集容器的标准输出日志和容器内文件日志。
22851 0
|
Linux 网络安全 Android开发
SSH神器: Termius介绍与使用
Termius是一款跨平台的SSH工具,提供美观的界面和便捷的操作,支持Android、Windows、macOS及Linux。它允许用户在不同设备间同步服务器连接,适合多设备切换工作。通过注册并关联GitHub学生账号,可以免费获取Termius使用权。软件功能包括SFTP文件传输,还有团队分享功能(需付费)。更多特色等待探索。官网:<https://www.termius.com/>
29087 0
SSH神器: Termius介绍与使用
Zookeeper命令行操作(常用命令;客户端连接;查看znode路径;创建节点;获取znode数据,查看节点内容,设置节点内容,删除节点;监听znode事件;telnet连接zookeeper)
8.1.常用命令 启动ZK服务 bin/zkServer.sh start 查看ZK服务状态 bin/zkServer.sh status 停止ZK服务 bin/zkServer.sh stop 重启ZK服务 bin/zkServer.sh restart 连接服务器 zkCli.sh -server 127.0.0.1:2181   8.2 客户端连接 运行
14137 1