python教程

当前位置:首页 > 计算机底层基础 > 当前文章

计算机底层基础

什么是同步异步,同步异步的区别

2021-11-10 65赞 老董笔记

  同步在感觉上容易让人觉得是一起开始,在正常的人类沟通中说同步就是在表达一起开始一起结束,但是在计算机领域同步并不是这个意思。

  在编程中说的同步是表达不同的操作要有步骤、有顺序。核心在于多个任务按顺序等着1个个执行。概念听起来跟抽象,我们用例子说明。

  例1:

  以抓取数据为例,我们发1个请求去获取网页,然后就得等着,等这个网页从服务器端通过网线穿越千山万水最终抵达你的电脑上后,代码接下来才可以去往下执行。


def  get_html():
    """
      获取网页
    """

def do_other():
  """
    其他任务
  """

def main():
    get_html()
    do_other()

  main函数可以视为调用方,里面执行了2个函数,如果第一个get_html函数未结束的话后面的do_other无法运行。这个就是同步机制,后面的任务得等前面的任务。简而言之:同步就是代码调用io操作时须等待io操作完成后才返回的调用方式。(抓取数据是网络IO)

  上述例子如果用1个子线程去完成do_other任务,那么do_other可以不用等get_html完成就可以执行,因为多线程之间可以并发运行,这种现象就是异步机制。异步就是无序的,多个任务并没有按顺序一个个等着执行。

def  get_html():
    """
      获取网页
    """

def do_other():
  """
    其他任务
  """

def main():
    get_html()
    threading.Thread(do_other)

  同步和异步体现的是多个任务的执行方式是怎么样的,并不受制于单线程或者多线程。上述虽然是通过多线程实现了异步,但是单线程内也能实现异步(在python里借助yield来让出CPU)!

  例2:

  python里多线程修改同1个全局变量时需要加锁,因为修改1个变量不是一步到位的而是经历了很多步骤期间会产生临时变量,多个线程操作时候可能把数据搞错乱。

  加锁就是为了让1个线程操作变量时其他线程不可以操作,这样可以保证数据不会出错。这种场景也常说为了保持数据同步多线程操作需要加锁!其实表达的是各个线程的操作要同步有序。

  人类理解1个概念以后喜欢灵活的去使用它来描述一些现象,比如说人拉的屎很臭,也可以说人的脾气很臭。人们随心所欲的使用一个概念会让人产生误解,只要理解了概念的原始意思,就不纠结一些使用场景了。

感兴趣直接点击图片获取>>

文章评论

什么是同步异步,同步异步的区别文章写得不错,值得赞赏