网络编程--回调函数 阻塞操作 异步执行

其实写这篇文章的目的是这样的:在基本的网络库中,经常看到有注册回调这么一说,让回调函数做真正去做的事情,在libevent中就是这样。这样做的目的说了为了避免阻塞,避免异步(这里首先说明异步和阻塞是不同的概念)。但是我的问题是:如果在回调中执行了很耗时的操作,甚至是在回调中出现了阻塞的操作,这该怎么办?还有就是,在执行回调函数的部分时,是不是流程和回调函数的内容顺序执行的,想执行中断那样,不管怎么说,必须等到这个回调函数执行结束以后才能执行下一个回调后的代码,如果这样的话,在执行回调的时候有事件到达(这里是采用的I/O复用监听各个事件,事件存在返回的场景!!)

如果有知道答案或者哟自己想法的都可以交流!!

   下面的都是从不同的地方看到的文章:

回调函数在什么场景有用?
我要在特定时候执行一个任务,至于是什么时候我自己都不知道。比如某一时间到了或者某一事件发生或者某一中断触发。

回调函数怎么起作用?
把我要执行的这个任务写成一个函数,将这个函数和某一时间或者事件或者中断建立关联。当这个关联完成的时候,这个函数华丽的从普通函数变身成为回调函数。

回调函数什么时候执行?
当该回调函数关心的那个时间或者事件或者中断触发的时候,回调函数将被执行。
一般是触发这个时间、事件或中断的程序主体(通常是个函数或者对象)观察到有一个关注这个东东的回调函数的时候,这个主体负责调用这个回调函数。

回调函数有什么好处?

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
异步编程中,回调函数是一种常见的处理方式。当一个异步操作完成时,系统会调用预先定义好的回调函数来处理结果。回调函数通常作为参数传递给异步操作的函数,以便在操作完成后进行调用。 举个例子,假设我们有一个异步读取文件的操作。在传统的同步编程中,我们会使用阻塞方式等待文件读取完成后再进行下一步操作。但在异步编程中,我们可以使用回调函数来处理文件读取完成后的结果。 下面是一个简单的示例代码,展示了如何使用回调函数处理异步文件读取: ```python import asyncio async def read_file(file_path, callback): # 模拟异步读取文件的操作 await asyncio.sleep(1) # 假设文件读取完成后返回内容 content = "File content" # 调用回调函数处理结果 callback(content) def handle_result(content): print("File content:", content) # 异步读取文件,并指定回调函数 asyncio.run(read_file("file.txt", handle_result)) ``` 在上述代码中,`read_file` 函数是一个异步函数,它模拟了文件的异步读取操作。在操作完成后,会调用传入的回调函数 `callback` 来处理结果。 `handle_result` 函数是我们定义的回调函数,它接收文件读取完成后的内容,并进行处理。在这个例子中,我们简单地打印了文件的内容。 通过使用回调函数,我们可以在异步操作完成后执行特定的逻辑,而不需要等待操作完成。这种方式可以提高程序的并发性和响应性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值