- 博客(10)
- 收藏
- 关注
原创 同步和异步(再梳理一次~)
同步非阻塞虽然在是不阻塞等待的,但对于某个线程而言仍然是需要先执行前一条语句再执行后一条语句,这与阻塞与否无关。协程内是顺序执行的,这是否违反了异步的定义?异步这块讲的还是不太清楚,这个上手试一下会比较好理解。
2025-10-26 11:25:09
178
原创 select和epoll 底层原理
总而言之,epoll相较于select做了两件事,一是通过一个中介让注册(加入所有socket等待队列)操作只需要做一次,二是通过“就绪列表”引用需要的处理事件。,而不用每次epoll_wait都需要遍历三次socket列表。维护“就绪队列”和增加和删除epoll事件时。epoll解决了select的两个缺点。
2025-09-14 20:13:49
352
原创 用看守对象管理连接释放
如果未使用连接池,则用close关闭,使用连接池则采取连接池的归还连接函数。如果因为在使用连接池的情况下也有手动创造特殊连接的需求,可以通过pool变量是否为真来分别处理,真则归还,假则关闭。把conn连接传入看守对象,对象销毁时自动调用析构函数处理连接。使用连接池就传入pool_共享指针。不使用就传入nullptr。
2025-07-17 14:16:54
231
原创 异步的理解2(boost::asio的异步操作和协程)
boost::asio通过1.把需要进行异步操作的对象绑定到io_context上,2.io_context会把异步操作注册到操作系统上,3.异步操作完成后操作系统会通知io_context,4.io_context随后调用回调函数。协程上下文yield同理,1.先把异步操作的对象绑定到io_context上,2.io_context把异步操作注册到操作系统上,3.异步操作完成后操作系统通知io_context,4.io_context唤醒协程。
2025-07-12 19:39:32
240
原创 boost库的上下文指的是io_context
因此使用执行器executor和协程上下文yield时所说的“指定异步函数或者协程中异步函数恢复的上下文”指的是io_context,而不是之前理解的进程切换的上下文。指的是context(中文意思:上下文)没系统学习又吃一亏…
2025-07-11 17:57:48
221
原创 异步的定义
由于一开始就没很清楚异步的定义,导致在对用协程用“类同步”的形式实现异步时很难理解——这明明就是同步啊,同步不就是任务按特定的顺序执行。结果区别是在是否阻塞等待上。一开始不理解为什么协程可以省略回调函数→为什么异步操作要这么写回调函数,同步都不需要这么麻烦→为什么这是异步这是同步啊?同步指的是一个任务必须等待前一个任务完成后才能继续执行,越看越迷,没系统学习过还是很吃亏的,看到什么不会学什么很容易在基础概念上翻车。我一直以为异步是后续任务不依赖前一个任务,结果区别是在是否是否阻塞等待前一个任务上吗?
2025-07-10 15:43:46
244
原创 reactor和proactor的回调逻辑区别
区别是一个提醒可读,我绑定一个回调函数去帮我完成这个读的过程及读完后的操作,一个是读完了,我绑定一个回调去进行读完后的操作。认真写博客耗费时间~还是直接贴图好了,省事。epoll需要read/write。
2025-07-09 23:56:01
150
原创 我还以为B/S比C/S难很多
原来都是通过ip+端口建立连接,然后B/S就比C/S多处理一个HTTP协议。然后用WebSocket和Json序列化实现实时通讯,我还以为会麻烦很多。加油吧,剩下就是花时间搭框架然后逐步往上添东西了。
2025-07-06 20:45:40
77
原创 突然悟了“事件驱动和回调函数的优势是什么了”
函数就是某个事件发生时对应要执行的处理(调用函数不需要条件,但我们写代码肯定不能乱调,得在适当的时候调,这个适当就对应某个条件满足/事件发生。比如:事件:饭点到了处理:吃饭如果要写个一天要做的事情的程序,那就是if(早上七点)起床else if(早上八点)学习else if(饭点到了)吃饭else if...在知道一天要做的事情顺序的话,这些if还可以省略,只要按照“起床,学习,吃饭”的顺序写代码调用函数就行,那如果不能确认呢?if(饭点到了)吃饭else if(朋友找你打游戏)
2025-07-06 01:35:15
195
空空如也
空空如也
TA创建的收藏夹 TA关注的收藏夹
TA关注的人
RSS订阅