多协程的使用


# 多协程使用

import asyncio
import time

# async def fun1():
#     print('你好,我是潘金莲')
#     await asyncio.sleep(3)
#     print('你好,我叫潘金莲')
#
# async def fun2():
#     print('你好,我是狄仁杰')
#     await asyncio.sleep(2)
#     print('你好,我叫狄仁杰')
#
# async def fun3():
#     print('你好,我是李元芳')
#     await asyncio.sleep(4)
#     print('你好,我叫李元芳')
#
#
# async def main():
#     tasks = [
#         fun1(),
#         fun2(),
#         fun3()
#     ]
#     await asyncio.gather(*tasks)
#     pass
#
# if __name__ == '__main__':
#     t1 = time.time()
#     # 一次性启动多个任务(协程)
#     asyncio.run(main())
#     t2 = time.time()
#     print(t2-t1)


# 在爬虫领域的使用

async def download(url):
    print('开始下载')
    await asyncio.sleep(2) # 网络请求
    print('下载完成')

async def main():
    urls = [
        'http://www.baidu.com',
        'http://www.163.com'
    ]
    tasks = []
    for url in urls:
        d = download(url)
        tasks.append(d)

    await asyncio.gather(*tasks)

if __name__ == '__main__':
    asyncio.run(main())



实战 图片下载

# requests.get(),同步的代码 ->异步操作

import asyncio
import aiohttp

urls = [
    'http://kr.shanghai-jiuxin.com/file/2021/0112/22bb24bf6176209f02439463c408fa58.jpg',
    'http://kr.shanghai-jiuxin.com/file/2021/0112/3de4facfc886317dece22a09ec4a2343.jpg',
    'http://kr.shanghai-jiuxin.com/file/2021/0112/a6a25f86d932716142aa418c9c2bf119.jpg'
]
# s = aiohttp.ClientSession()  # 等价于requests
    # 发送请求
    # 得到图片
    # 保持图片
async def aiodownload(url):
    name = url.rsplit('/',1)[1] # resplit从末尾开始切
    async with aiohttp.ClientSession() as session:
        async with session.get(url) as resp:
            # 请求回来,写入文件
            with open(name,mode='wb') as f:
                f.write(await resp.content.read()) # 读取内容是异步的,需要await挂起
                # resp.content.read()  # 等价于resp.content
                # resp.text()  #等价于resp.text
                # resp.json() #等价于resp.json()
    print(name,'搞定')

    pass

async def main():
    tasks = []
    for url in urls:
        tasks.append(aiodownload(url))
    await asyncio.gather(*tasks)
    pass

if __name__ == '__main__':
    asyncio.run(main())


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Unity中的使用分为两部分:程本体和程调度器。程本体是使用C#的迭代器函数来实现的,它允许函数在中间暂停并返回。而程调度器则利用了MonoBehaviour中的生命周期函数来实现分时调度。\[1\]\[2\] 在Unity中,程的使用有多种场景。首先,它可以用于异步加载资源,通过在程中加载资源,可以避免阻塞主线程。其次,程可以将一个复杂的程序分帧执行,使得程序的执行更加平滑。最后,程还可以用作定时器,通过在程中设置等待时间来实现定时功能。\[3\] 在使用程时,需要注意一些事项。首先,程只能在继承了MonoBehaviour的类中使用。其次,程函数必须返回IEnumerator类型。另外,程函数中可以使用yield语句来暂停执行,并指定下一次执行的时间或条件。最后,程函数可以通过StopCoroutine函数来停止程的执行。\[3\] 总结来说,Unity的使用是通过程本体和程调度器来实现的,程本体使用C#的迭代器函数,程调度器利用了MonoBehaviour的生命周期函数。程的使用场景包括异步加载资源、分帧执行复杂程序和定时器。在使用程时需要注意一些事项,如只能在继承了MonoBehaviour的类中使用程函数必须返回IEnumerator类型等。 #### 引用[.reference_title] - *1* *3* [【Unity】Unity程(Coroutine)的原理与应用](https://blog.csdn.net/hafeiyangha/article/details/125365152)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Unity的程详解](https://blog.csdn.net/vinkey_st/article/details/126759402)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值