游戏电视苹果数码历史美丽
投稿投诉
美丽时装
彩妆资讯
历史明星
乐活安卓
数码常识
驾车健康
苹果问答
网络发型
电视车载
室内电影
游戏科学
音乐整形

Flink操练(三十二)之自定义键控状态(二)ListSta

  0简介
  ListState〔T〕保存一个列表,列表里的元素的数据类型为T。基本操作如下:ListState。add(value:T)ListState。addAll(values:java。util。List〔T〕)ListState。get()返回Iterable〔T〕ListState。update(values:java。util。List〔T〕)
  ListState需要将某些值存到一个List中(Iterable),意味着缓存的数据不只是一个而是多个值。很多情况下都可以使用,例如计算的数值要包含全天的每一个记录,此时只有将每个记录的值存成一个列表才可以计算。1。实例
  1。1实例一
  首先需要先定义一个ListState,然后再重写KeyedProcessFunction中的open方法:privatevaritemState:ListState〔ItemViewCount〕overridedefopen(parameters:Configuration):Unit{命名状态变量的名字和类型valitemStateDescription:ListStateDescriptor〔ItemViewCount〕newListStateDescriptor〔ItemViewCount〕(itemState,classOf〔ItemViewCount〕)itemStategetRuntimeContext。getListState(itemStateDescription)}
  ListStateDescriptor提供了几种不同的定义方式:
  两个参数分别是ListStateDescriptor的名字和typeClass
  1。2实例二packageqiuhua;importorg。apache。flink。api。common。functions。RichFlatMapFunction;importorg。apache。flink。api。common。state。ListState;importorg。apache。flink。api。common。state。ListStateDescriptor;importorg。apache。flink。api。common。typeinfo。Types;importorg。apache。flink。api。java。tuple。Tuple2;importorg。apache。flink。configuration。Configuration;importorg。apache。flink。shaded。guava18。com。google。common。collect。Lists;importorg。apache。flink。util。Collector;importjava。util。Collections;importjava。util。List;program:bigdatalearndescription:通过ListState求key出现了3次,则需要计算平均值author:Mr。逗create:2021090816:18publicclassCountAverageWithListStateextendsRichFlatMapFunctionTuple2Long,Long,Tuple2Long,Double{ValueState:里面只能存一条元素ListState:里面可以存很多数据privateListStateTuple2Long,LongelementsByKey;Overridepublicvoidopen(Configurationparameters)throwsException{super。open(parameters);注册状态ListStateDescriptorTuple2Long,LongdescriptornewListStateDescriptor(liststate状态名字,Types。TUPLE(Types。LONG,Types。LONG)状态存储的数据类型);elementsByKeygetRuntimeContext()。getListState(descriptor);}OverridepublicvoidflatMap(Tuple2Long,Longvalue,CollectorTuple2Long,Doubleout)throwsException{IterableTuple2Long,LongcurrentStateelementsByKey。get();拿到当前key的状态值如果状态值没有初始化,则初始化if(currentStatenull){elementsByKey。addAll(Collections。emptyList());}更新状态elementsByKey。update((ListTuple2Long,Long)value);判断,如果当前key出现了3次,则需要计算平均值,并且输出ListTuple2Long,LongallElementsLists。newArrayList(currentState);if(allElements。size()3){longcount0;longsum0;for(Tuple2Long,Longele:allElements){count;sumele。f1;}doubleavg(double)sumcount;out。collect(Tuple2。of(value。f0,avg));清除状态elementsByKey。clear();}}}
  总结
  Flink提供了三种基于keyvalue的state接口,ListState接口适用于缓存多个值的计算。具体实现之前,因为state必须是基于key,且必须获取getRuntimeContext,state必须同时满足两个条件:直接基于keyedStream或者由keyedStream转换来的windowedStream必须继承RichFunction
  实际实现时候,因为windowedStream在scala中不能实现RichWindowFunction,因此在main中使用flatmap间接实现了windowFunction中的功能:valfromTransactionDataStreamwatermarkTransaction。keyBy(。code)。window(TumblingEventTimeWindows。of(Time。seconds(10)))valtransactionfromTransactionDataStream。apply(newStockTransactionApply)。keyBy(。3)。flatMap(newTransactionStateFlatMapFunction)

鹏博士云网出席2020中国云网络峰会助力企业进入DT时代2020年12月19日,由中国通信学会、江苏省未来网络创新研究院、SDNLAB,联合云计算行业中坚,云网络技术翘楚共同发起的2020中国云网络峰会在北京召开。据了解,本次峰会立……去年回家过年机票退改多次,年中开间咖啡馆,今年还能回家过年吗2020年,对于我、对于家、对于国都是艰难的一年。1月,回沈阳过年看父母,原计划2月3日初九回西安,突如其来的疫情,机票经过多次退改后于1月30日辗转回到西安。中间转机时……陕西帝陵数量全国之最参观秦汉唐三陵感受曾经的盛世南方的才子北方的将,陕西的黄土埋皇上这句俗语很多人都听说过。在漫漫历史长河中,有周、秦、汉、唐等14个政权在陕西建都,为陕西留下了数量巨大的帝王陵墓,是全国现存帝王陵之最。这其……商之翼智能电商生态系统,赋能零售企业线上线下一体化升级一、商之翼数字化解决方案,助力实体零售企业升级1、兴龙广缘兴隆广源隶属于秦皇岛中秦兴龙投资控股有限公司,创立于2001年,目前已发展成集超市、百货、商贸、物流、电器……汇逛科技智能购物车为载体,赋能线下门店流量运营的闭环在大数据为前提,互联网新零售的时代,我们以人为本,人成为了新零售角色中最重要的核心。而在大数据的时代,新零售的诉求则是消费者内心的需求。新零售行业重构了的人、货、场,由此,人成……外贸人你还不会用Whatsapp云控社交营销?5577850hrwhatAPP在线率很高,全球用户20亿,那如何利用whatAPP实现有效的外贸客户开发呢?外贸卷自动群发whatAPP消息批量搜索w……关于元宇宙系统的介绍元宇宙是今年成为互联网圈子流行的概念与场景。与区块链概念兴起不同,元宇宙是真正以一家上市公司(Roblox,中译:罗布乐思)的案例为佐证的,这也让元宇宙区别于泡沫式的概念,具备……下半场,我们都将是数据目前互联网行业趋势在哪里今天,在线化占用我们的时间越来越多,而我们对于网络已经无法离开,这已经深刻影响我们的生活与工作。那么,再深一步,我们所面临的互联网会变成什么样?……社区团购再体验,送货小哥很强,后台配货能力待优化上周日(11月15日)蛇叔用社区团购代替了过往周末例行去超市和菜市场多处买菜,体验下来感觉非常好,好在:(1)配送速度非常快,不到1小时;(2)生鲜的品质不错,打消了可能不如到……挚爱体验家空间,江铃福特践行待客如亲在2021上海车展,江铃福特展台完美复刻了按照福特全球展厅全新标准升级而来的FamilySpace家空间福特体验店的真实场景,让消费者切实感受到挚诚安心、挚享款待、挚爱关怀的焕……五菱凯捷再推新车型,做一台有态度的高品质MPV说起国产神车,必须提一提五菱宏光跟哈弗H6,它们可以说是国产骄傲,深受消费者的喜爱。今天咱就来说说五菱,五菱旗下高端MPV凯捷销量虽然开局不错,但是到现在销量出现明显下滑,所以……2020年花2000元买全新iPhone8会是49年入了国军2020年iphone9都要发布了,这个时候买iPhone8会是49年入了国军么?打开官网可以看到在售的手机有11pro,11,xr,以及iphone82020年官……
iPhone12取消耳机赠送,网友手机圈中唯一一棵独苗啊从目前的爆料来看,今年秋季的iPhone12系列可能是自iPhoneX全屏以来最大的升级。1。网络信号切换回高通基带并升级到5G2。屏幕刷新率升至120Hz3……起售6。98万,家族首款银标SUV,五菱星辰如何选?五菱汽车,带给消费者的是性价比。有一个口号,很多人印象深刻,那就是人民需要什么,五菱就造什么,确实涌现出了一些经典车型,比如说有神车之称的五菱宏光,在纯电动领域的MINIEV。……张氏企业家俱乐部2020年4月21日简讯【张氏企业家俱乐部简讯】三位宗亲在会所合影4月21日下午,深圳薯香味甜农业发展有限董事长张浩天宗亲应邀前来深圳张氏企业家俱乐部会所参观学习。张氏企业家俱乐部联盟执行……开着君越552T去寻找金桂飘香,君越用一路优雅承载舒适旅途对于秋天,很多朋友最深刻的印象莫过于桂花的清香,很多朋友也十分愿意找一个闲适的假期,沉醉于桂花飘香的景色之中。在距离成都市区两小时车程的郊区,就有一处名为岷江村的绝佳赏桂去处。……2020东京奥运会闭幕2024相约巴黎他(她)们都是我们的奥东京奥运会闭幕之日,中国的奖牌榜第一被易位了,总榜最终排在第二位,全新的希望有一种精彩叫超越全力拼搏东京奥运会中国体育代表团38金全回顾1、00后运动员杨倩最后一枪顶住压……数码宝贝皇家骑士X奥米加兽X理论上,其他数码兽无法打倒奥米加兽X。因为他掌握了在战斗时,瞬间读取下一步,并能够提前应对的究极之力最终获得之力。在任何情况下奥米加兽X的战斗感和潜在能力(可能……拆空调丨美的1匹新一级i青春II冷静星II睿行对比拆机大家好,今天是美的三款1匹新一级空调对比拆机,分别是i青春II、冷静星II、睿行。其中睿行在新国标实施之前叫锋行,随着新国标的实施推出了这款睿行,可以看做是锋行的新国标版本。……斯莱克上半年业绩保持稳健,定增扩产加速释放发展潜力8月23日晚间,斯莱克(300382。SZ)披露2021年半年报,公告显示,公司上半年营业收入3。89亿元,归母净利润3697。05万元。此外,公司还同步披露了定增预案,拟募集……振华股份一个坐落在湖北黄石的隐形世界冠军金属,是人们日常生活中十分常见的材料之一,比如金、银、铂等贵金属,还有铜、铝、铅、锌等工业金属,但相对这些金属品种来说,人们对于小金属铬元素的认知要陌生很多。然而,铬在我们日常……亮点在这里!2020开学第一课被搬到了武汉一年一度的开学季来了,每年开学之际都会推出《开学第一课》。这一节目都是针对每年最重要的事件选定节目内容,有利于孩子们在潜移默化中受到熏陶。2020年《开学第一课》以少年强,中国……农业银行存款利率有多高?假设50万元存三年,一年能有多少利息引言除此之外,受中华民族传统思想的影响,很多老百姓都更偏向于安全性有保障的理财方式。这也就意味着,储蓄存款在广大老百姓心目中的地位依然十分崇高。那么在2021年的今天,如……KEFReference1书架音箱声音听起来不像书架音箱的书书架音箱是使用率和关注度很高的一种音箱类型,因为它的体积较小,摆放比较灵活,且价格也相对实惠,更容易被消费者接受,所以几乎每个音箱制造商都有书架式音箱。在书架音箱当中,2分频2……
友情链接:易事利快生活快传网聚热点七猫云快好知快百科中准网快好找文好找中准网快软网