最新要闻
- 每日播报!若若_关于若若的简介
- 焦点速读:长沙凌晨1点马路人流量惊人 像在倒时差:网友称想去打卡 当地人回应
- 全球最资讯丨8GB来了!iPhone 15内存大升级:苹果区别对待 想要花万元买Pro版
- 环球热头条丨荣耀Magic5 Lite获DXO电池性能第一名 续航可超三天
- 雷克萨斯、英菲尼迪、凯迪拉克等豪车中国市场暴跌:国人不当冤大头
- 热文:OPPO打造!唯一配备潜望长焦的天玑旗舰来了
- 天天短讯!死磕RTX 40!AMD RX 7600/7700/7800齐曝光:据说苏妈定价有诚意
- 重现《放羊的星星》!林志颖特斯拉车祸后复出晒照 事故原因成谜 是踩错刹车?
- 天天百事通!今日成都到康定怎么坐车_成都到康定
- 亮机卡也有春天 锐龙7000核显超频到3.1GHz 游戏性能猛增40%
- 当前要闻:困扰十几亿人!脚趾甲咋会向肉里长?
- 世界焦点!TCL发布超薄四开门冰箱T9:0cm无缝式嵌入 456L仅3399元
- 增程、换电、800V高压快充 谁才是未来新能源车最佳补能方式?
- 环球新动态:发3000元却收回2800元!“慈善主播”被行拘 账号被封
- 【焦点热闻】秘而不宣的读法
- 世界热门:RTX 4070 Laptop逆天能效比!七彩虹将星X15 AT 2023游戏本首发评测
广告
手机
iphone11大小尺寸是多少?苹果iPhone11和iPhone13的区别是什么?
警方通报辅警执法直播中被撞飞:犯罪嫌疑人已投案
- iphone11大小尺寸是多少?苹果iPhone11和iPhone13的区别是什么?
- 警方通报辅警执法直播中被撞飞:犯罪嫌疑人已投案
- 男子被关545天申国赔:获赔18万多 驳回精神抚慰金
- 3天内26名本土感染者,辽宁确诊人数已超安徽
- 广西柳州一男子因纠纷杀害三人后自首
- 洱海坠机4名机组人员被批准为烈士 数千干部群众悼念
家电
热门:读Java实战(第二版)笔记17_反应式编程
(相关资料图)
1.再次出现在聚光灯下的原因
1.1.基本思想已经有二三十年的历史
1.2.大数据
1.2.1.以PB计量的大数据
1.2.2.当前互联网中流量最大的部分是移动流量
1.2.3.物联网(Internet of things, IoT)流量取代移动流量成为互联网流量的主流,这种情况还会进一步加剧
1.3.异构环境
1.3.1.移动设备
1.3.2.运行着数千个多核处理器的云端集群
1.4.使用模式
1.4.1.用户期望毫秒级的响应时间
1.4.2.希望应用百分之百时时刻刻都在线
2.反应式编程
2.1.一种利用反应式流的编程技术
2.1.1.以异步方式处理潜在无边界数据流的标准技术
2.2.以异步的方式处理、整合来自不同系统和源头的数据流
2.2.1.比线程更轻量级
2.2.2.提升了创建并发以及异步应用的抽象层次
2.2.3.任务能以异步的方式运行
2.3.可以构建单一组件或者应用
2.4.协调多个组件,将它们搭建成一个反应式系统
2.5.主线程池中运行的线程执行的都为无阻塞的操作
2.5.1.确保所有的CPU核都能得到最充分的利用
2.6.不要在主事件循环中添加可能阻塞的操作
2.6.1.所有I/O密集型的操作
2.6.1.1.访问数据库或文件系统
2.6.1.2.调用远程服务
2.6.2.无法预测何时能够结束
2.6.3.可能消耗比较长时间的事件
2.7.开辟独立的线程池用于执行阻塞式操作
2.7.1.为CPU密集型和I/O密集型的操作分别创建单独的线程池
2.7.2.更精细地监控不同类型任务的性能
2.7.3.更好地配置和调整线程池的规模
2.7.4.更好地适应业务的需求
2.8.背压
2.8.1.发表-订阅模式下的一种常见的流量控制机制
2.8.2.提供了一种协议,可以在不阻塞线程的情况下,避免数据接收方被压垮
2.8.3.避免流中事件处理的消费者由于处理速度较慢,被一个或多个快速的生产者压垮
2.8.4.组件需要一种方式来向上游生产者反馈,让它们减缓生产速度
2.8.5.告诉生产者它在接收更多数据之前,在给定的时间内能够接受和处理多少事件
3.Flow类
3.1.java.util.concurrent.Flow
3.1.1.Java 9
3.2.所有实现该接口的库需要遵守的合约
3.2.1.使构建于不同的反应式库之上的应用间能相互协调、相互理解沟通的通用语言
3.2.2.接口可以帮助你更好地构建你的程序思维
3.2.3.并不能帮你更快地完成程序设计
3.3.标准化使得不同库之间互通和调用成为可能
3.3.1.Akka
3.3.2.RxJava
3.4.发布-订阅”模型
3.4.1.发布者(Publisher)
3.4.1.1.顺序事件的提供者
3.4.1.2.事件的数量可能没有上限
3.4.1.3.受背压机制的制约
3.4.1.4.按照Subscriber的反馈进行元素的生产
3.4.1.5.Java函数式接口
3.4.2.订阅者(Subscriber)
3.4.2.1.把自己注册为该事件的监听方从而完成对Publisher事件的注册
3.4.3.订阅(Subscription)
3.4.3.1.流量控制,包括Publisher与Subscriber之间的背压都是由Subscription管理的
3.4.3.2.cancel()方法的实现必须是幂等和线程安全的
3.4.3.2.1.调用它一次与重复调用多次的效果是同样的
3.4.3.2.2.任何对Subscription的额外调用都不会有副作用
3.4.4.处理者(Processor)
3.4.4.1.反应式流中事件的转化阶段
3.4.4.2.转换数据
3.4.5.所有方法都返回void,从而确保它们能以完全异步的方式实现
4.RxJava
4.1.应用最广泛的反应式库
4.1.1.诞生于Netflix
4.1.2.对微软.Net环境中反应式扩展(reactive extension, Rx)项目的迁移
4.1.3.比Java 9的Flow API更方便
4.1.3.1.更加丰富的函数集
4.1.3.2.更灵活地对流进行整合、创建以及过滤操作
4.2.io.reactivex.Observable
4.2.1.不支持背压
4.2.2.适用于
4.2.2.1.用户接口事件(譬如鼠标移动)
4.2.2.2.流元素不超过一千个
4.2.2.3.基于图形用户界面的事件流
4.2.2.4.无法背压或不常发生的事件时
4.2.3.onSubscribe方法需要一个Disposable参数
4.2.4.只在需要Observable的额外结构时使用Observable,否则就应该继续使用它的Publisher接口
4.3.Subscriber可以通过request(Long.MAX_VALUE)调用关闭背压功能
4.4.just()工厂方法
4.4.1.将一个或多个元素转换为Observable
4.5.interval工厂方法
4.5.1.按照固定的时间间隔发出事件
4.6.blockingSubscribe方法
4.6.1.调用当前线程(在这个例子中就是main函数所在的线程)的回调函数
4.7.弹珠图
5.反应式宣言
5.1.2013年至2014年间发起
5.2.开发反应式应用和系统的规范
5.3.Jonas Bonér、Dave Farley、Roland Kuhn和Martin Thompson
5.4.响应性
5.4.1.反应式系统的响应时间很快
5.4.2.响应时间应该是稳定且可预测的
5.4.2.1.用户才能明确地设定他的预期
5.4.2.2.增强用户的信心
5.5.韧性
5.5.1.系统在出现失败时依然能继续响应服务
5.5.1.1.组件运行时复制
5.5.1.2.从时间(发送方和接受方都拥有相互独立的生命周期)和空间(发送方和接收方运行于不同的进程)维度对组件进行解耦
5.5.1.3.任何一个组件都能以异步的方式向其他组件分发任务
5.6.弹性
5.6.1.应用的工作负载
5.6.2.有能力自动地适配和服务更大的负荷
5.7.消息驱动
5.7.1.组件间的松耦合
5.7.2.组件隔离
5.7.3.位置透明性
5.7.3.1.实现韧性的决定性要素
5.7.3.2.使得系统能够依据当前的负荷情况,对应用进行复制或者自动地水平扩展
5.7.3.3.位置无关的扩展也是反应式应用(异步、并发、即时松耦合)与反应式系统(凭借位置透明性从空间角度解耦)之间的另一个区别
6.反应式应用
6.1.主要对临时数据流进行处理
6.2.事件驱动型
6.2.1.事件会被所有注册了该事件的组件接收
6.3.异步、并发、即时松耦合
7.反应式系统
7.1.多个独立应用可以像一个单一系统那样步调一致地工作,同时其又具备良好的扩展性
7.2.各个应用也是充分解耦的
7.2.1.即使其中某一个应用发生失效,也不会拖垮整个系统
7.3.用于构造应用以及协调组件间的通信
7.3.1.以异步的方式发送和接收的,这种方式有效地解耦了发送方与接收方
7.4.消息驱动系统
7.4.1.消息往往是直接发送给某个单一目标的
7.5.组件间完全的解耦合既是实现有效隔离的必要前提,也是保障系统在遭遇失效(韧性)和超大负荷(弹性)时仍能保持响应的基础
7.6.韧性更偏向于容错
7.6.1.系统不只要能优雅地降级,更重要的是能通过隔离失效组件,将系统重新拉回健康状
7.6.2.失效节点的管理可以不受失效组件自身的影响,在一个安全的上下文中进行
7.7.凭借位置透明性从空间角度解耦
7.7.1.反应式系统的所有组件都可以和其他任何服务通信,无须顾忌接收方在什么位置
热门:读Java实战(第二版)笔记17_反应式编程
每日播报!若若_关于若若的简介
焦点速读:长沙凌晨1点马路人流量惊人 像在倒时差:网友称想去打卡 当地人回应
全球最资讯丨8GB来了!iPhone 15内存大升级:苹果区别对待 想要花万元买Pro版
环球热头条丨荣耀Magic5 Lite获DXO电池性能第一名 续航可超三天
雷克萨斯、英菲尼迪、凯迪拉克等豪车中国市场暴跌:国人不当冤大头
今日聚焦!面试官:怎么去除 List 中的重复元素?我一行代码搞定,赶紧拿去用!
热文:OPPO打造!唯一配备潜望长焦的天玑旗舰来了
天天短讯!死磕RTX 40!AMD RX 7600/7700/7800齐曝光:据说苏妈定价有诚意
重现《放羊的星星》!林志颖特斯拉车祸后复出晒照 事故原因成谜 是踩错刹车?
Map数据结构详解
环球视讯!在PHP和JavaScript中设置Cookie、会话存储(SessionStorage)和本地存储(LocalStorage)
天天百事通!今日成都到康定怎么坐车_成都到康定
亮机卡也有春天 锐龙7000核显超频到3.1GHz 游戏性能猛增40%
当前要闻:困扰十几亿人!脚趾甲咋会向肉里长?
世界焦点!TCL发布超薄四开门冰箱T9:0cm无缝式嵌入 456L仅3399元
增程、换电、800V高压快充 谁才是未来新能源车最佳补能方式?
环球新动态:发3000元却收回2800元!“慈善主播”被行拘 账号被封
【焦点热闻】秘而不宣的读法
C#的string是一种糟糕的设计吗?
当前视讯!队列——queue的用法(及洛谷B3616)
vue-cli安装依赖 props属性三种方式 混入迷信 插件 elementUI vuex vue Routerd localStorage系列
openfoam文件读取
fusion app自定义事件源码介绍(上)
世界热门:RTX 4070 Laptop逆天能效比!七彩虹将星X15 AT 2023游戏本首发评测
全球快看:1月豪华车销量榜:蔚来碾压全系合资二线豪华品牌
被网友玩坏?微软Bing的ChatGPT被证实变愚蠢了
每日消息!“张伟”骗取数位宝马车主百万购车款 4S店疯狂推卸责任?
AMD锐龙7 7735HS迷你机也有“青春版”:只变了两个USB接口
环球今头条!攒台白色的MATX主机,在B760主板上也能玩好内存超频
全球焦点!RS485 MODBUS转PROFINET网关案例 | 超声波明渠流量计接入到PLC1200 PROFINE
焦点热门:前后端分离项目解决跨域的终极方法
环球今热点:[Java基础]自动装箱与自动拆箱--为什么整型比较必须用equals?
【天天新要闻】Detecting glass in Simulataneous Localisation and Mapping
天天热文:贝叶斯与卡尔曼滤波(2)--连续随机变量的贝叶斯公式
当前热门:用送的那块布擦镜片:小心眼镜被废!
观热点:60岁快递员意外猝死 快递公司回应:深感痛心 善后已达成一致
女子连刷10个差评商家找上门:不好吃你天天来干嘛 谁生活容易啊
【世界报资讯】果粉入手一加Ace 2:开20个应用不杀后台 苹果开3个应用就不行了
80后回忆的“均瑶牛奶”公司进军新能源车:首款纯电SUV云兔来了 莆田生产
信息:Qt调用摄像头一,基础版
k8s多节点二进制部署以及Dashboard UI
记住这12个要点,你也能打造出让HR和技术主管前一亮的前端简历
《原子之心》冰箱诺拉全九国语言配音:怎么没日语?
粉丝发现周深自用手机是iQOO 11 Pro传奇版:5米开外就能看到
电动两轮车总是骑半路就没电?这5种错误充电习惯赶快纠正
世界今头条!男子酷爱嚼槟榔:最终确诊舌癌
【报资讯】免费的ChatGPT意外断网 国内伪装自主的AI露馅了
守护安全|AIRIOT城市天然气综合管理解决方案
0x03_My-OS在实体机上面运行
每日播报!【算法训练营day53】LeetCode1143. 最长公共子序列 LeetCode1035. 不相交的线 LeetCode53. 最大子序和
快讯:两数之和、三数之和、四数之和(双指针)
世界焦点!今日山水一程三生有幸是形容爱情的吗_山水一程三生有幸
环球最资讯丨俞敏洪说想给董宇辉在北京买套房子 这话我听着耳熟
消息!魅族20未发先火!1元超前预订7小时订单破10万
世界热讯:研究称果糖或能导致老年痴呆:专家建议少食用
全球热议:旅日大熊猫香香坐顺丰飞机到家!1个月后与公众见面
环球视讯!成都一公司面试需填芝麻信用分 网友热议
每日信息:100亿级订单怎么调度,来一个大厂的极品方案
[学习笔记]Rocket.Chat业务数据备份
记录--uni-app实现京东canvas拍照识图功能
世界快资讯:Java+Jquer实现趋势图
全球最新:温州特斯拉事故20年驾龄司机仍昏迷:特斯拉回应称难过 重申全力配合调查
环球今热点:Xbox游戏将登陆任天堂主机 网友质疑:NS能带动吗?
世界微资讯!场面爆笑!外国人为开比亚迪开始学中文:难为“小迪”了
即时看!音悦台将回归登热搜!主体公司已成老赖:累计被执行1376万
世界视讯!什么是经营贷什么是消费贷?浅谈二者区别
puppet安装使用踩坑笔记
箭头函数详解
TypeScript 入门自学笔记 — 接口的使用(六)
快资讯丨Python关于异常处理的教程
天天观察:scrollView 嵌套 recyclerview 时 BaseQuickAdapter 九宫格图片拖拽到底部删除
14年老牌网站 音悦台要回归了!官方称很快就要内测
每日快看:杭州发现鱼类新物种苕溪鱲:通体散发宝蓝色金属光泽
当前播报:爱奇艺认错 恢复会员投屏!上海消保委:愿意为消费者叫板
是懂玩家的!《原子之心》为机器人姐妹花开通ins账号
焦点观察:张小泉公开一防菜刀断裂专利 这次拍蒜不断了?
当前最新:中小企业如何有效应对计算资源的弹性变化需求?
热消息:来一波骚操作,Java内存模型
全球新消息丨Windows家庭版安装本地组策略编辑器【gpedit.msc】
Redis详解
当前焦点!@ResponseBody注解的作用
万马股份(002276.SZ):万马新能源充电桩的枪线已经自产 由万马专缆生产
精选!售10-20万元 蔚来整合猎豹工厂:新品牌“萤火虫”落户安徽
今日最新!冲刺IPO!一年狂赚7亿美元 中国跨境电商神话靠啥吸粉?
乐视被强制执行100万:没版权擅自转播了优酷综艺
男子网购iPhone 14开箱发现是iQOO 商家赔50元优惠券被拒
当前动态:曾致135人死亡 印度断桥事故调查报告出炉:钢索严重腐蚀
0x02_My-OS操作系统里的helloworld
天天新资讯:iptables防火墙
世界热议:万物皆可集成资源包!低代码集成系列一网打尽
天天快播:通过例子学习粒子群优化算法
全球速讯:暂时性死区以及函数作用域
全球观察:祸不单行!美国俄亥俄州又现爆炸:30公里外都见到蘑菇云
天天新消息丨2.8K OLED屏+10核CPU 小米首款翻转本降价1000元起
售价高达4199元!森海塞尔HD 660S2开放式动圈耳机正式开售
【世界独家】【算法训练营day52】LeetCode300. 最长递增子序列 LeetCode674. 最长连续递增子序列 LeetCode718. 最长重复子
开心档之Bootstrap4 自定义表单
速读:标准语言的重要性_语言的重要性
环球热讯:《蚁人3》等漫威大片中国吃瘪!国人为国产电影买单 《流浪地球2》等降维打击