首页
Python
Java
前端
数据库
Linux
Chatgpt专题
开发者工具箱
eventloop专题
[Android源码解析]Eventloop在jni层的分析
3 eventloop在jni层的详细分析 Eventloop在整个bluetooth的jni层和bluez之间的交互,以及jni和framework层之间的交互过程中有着举足轻重的作用。所以,本文仍然需要花费一定的笔墨来分析它,当然由于它更像是一个桥梁,我们的分析有可能就不是那么的深入了,会从比较宏观地角度来看待这个东西的作用。 当然,一切的一切还是要从
阅读更多...
17.EventLoop-IO任务
服务端代码 package com.xkj.learn;import io.netty.bootstrap.ServerBootstrap;import io.netty.buffer.ByteBuf;import io.netty.channel.ChannelHandlerContext;import io.netty.channel.ChannelInboundHandlerAda
阅读更多...
webserver服务器从零搭建到上线(九)|⭐️EventLoop类(一)——详解成员变量、简述成员方法
在本节中,我们一起来仔细探讨一下EpollPoller类。该类可以说是muduo库中最最核心的类了,一定要搞懂! 文章目录 私有成员`using ChannelList = std::vector<Channel*>``looping_`、`quit_``threadId_``pollReturnTime_`、`poller_``wakeup_fd`、`wakeupChannel_`int
阅读更多...
webserver服务器从零搭建到上线(十)|⭐️EventLoop类(二)——成员方法详解
首先,在阅读本章之前,我们需要搞清楚为什么EventLoop类这么复杂 其次,我们还需要再强调一次关于mainLoop唤醒subLoop的流程(可以看完该类代码后再回顾该流程): 为什么需要唤醒 subLoop? subLoop(通常指的是工作线程中的 EventLoop)可能会被阻塞在 poller 的等待调用上,例如 epoll_wait。当主线程或其他线程需要向 subLoop 传
阅读更多...
Netty初识Hello World 事件循环对象(EventLoop) 事件循环组 (EventLoopGroup)
初始Netty-HelloWorld Netty在网络通信中的地位就如同Spring框架在JavaEE开发中的地位。 基于Netty网络通信开发简易的服务端、客户端,以实现客户端向服务端发送hello world,服务端仅接收不返回数据。 服务端代码: @Slf4jpublic class HelloServer {public static void main(String[] args)
阅读更多...
13.Netty组件EventLoopGroup和EventLoop介绍
EventLoop 是一个单线程的执行器(同时维护了一个Selector),里面有run方法处理Channel上源源不断的io事件。 1.继承java.util.concurrent.ScheduledExecutorService因此包含了线程池中所有的方法。 2.继承netty自己的OrderedEventExecutor EventLoopGroup 一般不会直接使用E
阅读更多...
[muduo网络库]——muduo库三大核心组件之EventLoop类(剖析muduo网络库核心部分、设计思想)
接着上一节[muduo网络库]——muduo库三大核心组件之 Poller/EpollPoller类(剖析muduo网络库核心部分、设计思想),我们来剖析muduo库中最后一类核心组件,EventLoop类。 先回顾一下三大核心组件之间的关系。 接着我们进入正题。 EventLoop Poller封装了和事件监听有关的方法和成员,调用Poller派生类EpollPoller::poll方法,我
阅读更多...
菜鸡学习netty源码(四)—— EventLoop
1.概述 我们前面进行过分析,channel为netty网络操作的抽象类,EventLoop负责处理注册到其上的Channel处理的I/O事件;EventLoopGroup是一个EventLoop的分组,它可以获取到一个或者多个的EventLoop对象。 2.类关系图 NioEventLoopGroup的类继承图,蓝色部分为对应的java类,绿色的部分就为一些接口的信息 3.Event
阅读更多...
AJAX——事件循环(EventLoop)
1.事件循环(EventLoop) 概念:JavaScript有一个基于事件循环的并发模型,事件循环负责执行代码、收集和处理事件以及执行队列中的子任务。这个模型与其它语言中的模型截然不同,比如C和Java。 原因:JavaScript单线程(某一刻只能执行一行代码),为了让耗时代码不阻塞其他代码运行,设计了事件循环模型 1.1 事件循环-执行过程 定义:执行代码和收集异步任务的模型,在调用
阅读更多...
事件队列事件循环(EventLoop) 宏任务 微任务详解 面试题
事件队列 事件循环 EventLoop 宏任务 微任务详解 一、概念二、宏任务(多个)、微任务(1个)三、Promise 的构造函数四、process.nextTick在事件循环中的处理五、vue nextTick原理 一、概念 event: 事件 loop: 循环,循环的是一个又一个的任务队列 任务队列: 是一个先进先出的数据结构, 排在前面的事件, 优先被主进程读取 任务队列
阅读更多...
Netty专栏 (五)——— EventLoop和线程模型
Netty-In-Action @author 鲁伟林记录《Netty 实战》中各章节学习过程,写下一些自己的思考和总结,帮助使用Netty框架的开发技术人员们,能够有所得,避免踩坑。本博客目录结构将严格按照书本《Netty 实战》,省略与Netty无关的内容,可能出现跳小章节。本博客中涉及的完整代码:GitHub地址: https://github.com/thinkingfioa/n
阅读更多...
Netty学习——源码篇5 EventLoop
1 Reactor线程模型 Reactor线程模型 中对Reactor的三种线程模型——单线程模型、多线程模型、主从多线程模型做了介绍,这里具体分析Reactor在Netty中的应用。 1.1单线程模型 单线程模型处理流程如下图: 单线程模型,即Accept的处理和Handler的处理都在同一个线程中。这个模型的弊端是:当其中某个Handler阻塞时,会
阅读更多...
同步代码和异步代码、回调地狱、Promise链式调用、async和awat、事件循环EventLoop、宏任务和微任务、Promise.all静态方法
同步代码和异步代码 异步代码举例 定时器、事件、AJAX、回调函数 回调地狱 回调函数是一个异步的任务,回调函数嵌套回调函数就组成了回调地狱 可读性差、异常捕获困难、耦合性严重 举例:一旦省份报错,后面的就无法获取 <!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Co
阅读更多...
事件驱动的奇迹:深入理解Netty中的EventLoop
欢迎来到我的博客,代码的世界里,每一行都是一个故事 事件驱动的奇迹:深入理解Netty中的EventLoop 前言基础概念EventLoop的工作原理Channel与EventLoop的关系定时任务与延时任务EventLoop的生命周期EventLoop中的线程模型性能优化与最佳实践 前言 在网络编程的舞台上,EventLoop犹如一位巧妙的舞者,负责
阅读更多...
LoopThread实例化EventLoop管理类实现(模块八)
目录 类功能 类定义 类实现 编译测试 类功能 类定义 class LoopThread{private:/* 用于实现_loop获取的同步关系,避免线程创建了,但是_loop还没有实例化之前去获取_loop*/std::mutex _mutex; // 互斥锁std::cond_variable _cond; // 条件变量EventLoop *_loop;
阅读更多...
muduo网络库学习--EventLoop(二)
//EvengtLoop.h/.cc void EventLoop::loop(){...while (!quit_){...pollReturnTime_ = poller_->poll(kPollTimeMs, &activeChannels_); //返回活动通道...// TODO sort channel by priorityeventHandling_ = true;for (C
阅读更多...
EventLoop整合与TimerWheel联合调试(整合二)
目录 概要 tcp_cli.cc tcp_srv.cc server.hpp 测试结果 第二次整合 概要 本主要是将以下模块进行整合测试 Poller模块与Channel模块整合-CSDN博客 时间轮设计-CSDN博客 timerfd的认识与基本使用-CSDN博客 整合基于的理念 tcp_cli.cc #include "../source/server.
阅读更多...
复习 深入JS执行原理:一文搞定 EventLoop、宏任务、微任务
面试官:你了解JavaScript事件循环吗,掌握多少,把你知道的都说一下。 今天我们就来说一下,JavaScript作为一门单线程语言,如何通过事件循环(Event Loop)和任务队列(Task Queue)的机制,高效地处理异步任务,保证用户体验的流畅性。在本文中,我们将详细探讨事件循环、任务队列,以及在实际开发中的一些应用场景(面试常见笔试题)。 事件循环概述 在事件循环中,当主线程
阅读更多...
Netty应用(五) 之 Netty引入 EventLoop
目录 第三章 Netty 1.什么是Netty? 2.为什么需要使用Netty? 3.Netty的发展历程 4.谁在使用Netty? 5.为什么上述这些分布式产品都使用Netty? 6.第一个Netty应用 7.如何理解Netty是NIO的封装 8.logback日志使用的加强 9.EventLoop(NioEventLoop) 9.1 作用 9.2 类结构图 9.3
阅读更多...
EventLoop事件循环以及异步代码执行过程
1.EventLoop事件循环 首先我们需要了解JavaScript是一门什么类型的语言,以及同步代码,异步代码的执行过程。 1.1JS JavaScript 是一门单线程执行的语言,简单来说就是,同一时间只能做一件事情。 1.2JS执行环境 Js需要在宿主环境中执行(浏览器,nodejs),浏览器内部有执行js代码的引擎(V8引擎)。一般讨论的是JS在浏览器中的事件循环。 JS为了
阅读更多...
基于多反应堆的高并发服务器【C/C++/Reactor】(中)EventLoop初始化
这个Dispatcher是一个事件分发模型,通过这个模型,就能够检测对应的文件描述符的事件的时候,可以使用epoll/poll/select,前面说过三选一。另外不管是哪一个底层的检测模型,它们都需要使用一个数据块,这个数据块就叫做DispatcherData。除此之外,还有另外一个部分,因为在这个反应堆模型里边对应一系列的文件描述符,都属于epoll/poll/select,但是这些文件描述
阅读更多...
基于多反应堆的高并发服务器【C/C++/Reactor】(中)EventLoop初始化
这个Dispatcher是一个事件分发模型,通过这个模型,就能够检测对应的文件描述描述符的事件的时候,可以使用epoll/poll/select,前面说过三选一。另外不管是哪一个底层的检测模型,它们都需要使用一个数据块,这个数据块就叫做DispatcherData。除此之外,还有另外一个部分,因为在这个反应堆模型里边对应一系列的文件描述符,都属于epoll/poll/select,但是这些文件
阅读更多...
EventLoop笔记
node环境 Event Loop各阶段: - timers 阶段:这个阶段执行 setTimeout 和 setInterval 的回调函数。- I/O callbacks 阶段:不在 timers 阶段、close callbacks 阶段和 check 阶段这三个阶段执行的回调,都由此阶段负责,这几乎包含了所有回调函数。- idle, prepare 阶段(译注:看起来是两个阶段,不过
阅读更多...
muduo网络库学习之EventLoop(三):Socket、Acceptor、TcpServer、TcpConnection(连接建立,接收消息)
1、Socket 操作封装 Endian.h 封装了字节序转换函数(全局函数,位于muduo::net::sockets名称空间中)。 SocketsOps.h/ SocketsOps.cc 封 装了socket相关系统调用(全局函数,位于muduo::net::sockets名称空间中)。 Socket.h/Socket.cc(Socket类) 用RAII方
阅读更多...
muduo网络库学习之EventLoop(一):事件循环类图简介和muduo 定时器TimeQueue
1、EventLoop、Channel、Poller 等类图如下: 黑色菱形:组合;白色菱形:聚合;白色三角形:继承;实线:关联; Channel是selectable IO channel,负责注册与响应IO 事件,它不拥有file descriptor。 Channel是Acceptor、Connector、EventLoop、TimerQueu
阅读更多...
muduo_net库源码分析(五)(通过EventLoop::runInLoop实现跨线程调用)
知识点 pipe:等待线程关注fd[0]的可读事件,通知线程只需要往fd[1]中写入数据,fd[0]就变得可读了。 socketpair:与pipe类似,区别在于socketpair可以双向工作,pipe只能单向工作。 eventfd:比pipe更高效。 别忘了线程间的等待/通知还可以用条件变量实现。 一.Eventloop与Channel是聚合关系,但是有一个地方例外,这个地方就是Even
阅读更多...