当前位置: 首页 > news >正文

做拍客哪个网站好搜索引擎网址

做拍客哪个网站好,搜索引擎网址,网站排行首页怎么做,网站建设前规划场景 自定义Map或者别的算子的时候,有时候需要定义一些类变量,在flink内部高并发的情况下需要正确理解这些变量的行为 代码 package com.pg.function;import org.apache.flink.api.common.functions.MapFunction; import org.apache.flink.api.common…

场景

自定义Map或者别的算子的时候,有时候需要定义一些类变量,在flink内部高并发的情况下需要正确理解这些变量的行为

代码

package com.pg.function;import org.apache.flink.api.common.functions.MapFunction;
import org.apache.flink.api.common.functions.RichMapFunction;
import org.apache.flink.api.common.state.ValueState;
import org.apache.flink.api.common.state.ValueStateDescriptor;
import org.apache.flink.api.common.typeinfo.Types;
import org.apache.flink.api.java.tuple.Tuple2;
import org.apache.flink.configuration.Configuration;
import org.apache.flink.streaming.api.datastream.DataStream;
import org.apache.flink.streaming.api.environment.StreamExecutionEnvironment;import java.util.ArrayList;public class FlinkFunction {//对于自定义函数中的变量,只有内置的状态是完全按照flink内置的 keyBy行为来的//如果是自定义的缓存比如ArrayList 则可能不会按照预期的行为public static void main(String[] args) throws Exception {final StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();env.setParallelism(2);DataStream<String> dataStream = env.fromElements( "b","b","b","c","c","c","d","d","d");dataStream.keyBy(x->{return x;}).map(new MyMap()).print();env.execute();}}class MyMap extends RichMapFunction<String, String> {public ArrayList<String> list= new ArrayList<>();
//     public ValueState<Integer> counter;//存储数据条数
//     public ValueState<String> element;//存储临时数据
//     @Override
//     public void open(Configuration parameters) throws Exception {
//         counter = getRuntimeContext().getState(new ValueStateDescriptor<Integer>("counter", Types.INT));
//         element = getRuntimeContext().getState(new ValueStateDescriptor<>("element", Types.STRING));
//     }@Overridepublic String map(String s) throws Exception {list.add(s);if(list.size()==2){String re = list.toString();list.clear();return re;}else {return "null";}
//        if (counter.value() == null) {
//            counter.update(1);//遇见第一条数据的时候,计数器为1
//        } else {
//            counter.update(counter.value() + 1);
//        }
//        if (element.value() == null) {
//            element.update(s);//element只存储上一次到来的数据
//        }else {
//            element.update(element.value()+s);
//        }
//        if (counter.value() == 2) {
//            String re = element.value();
//            //发出结果之后清楚状态
//            counter.clear();
//            element.clear();
//            return re;
//        }else {
//            return "null";
//        }}
}

分析

keyBy之后,理论上相同key的会在map中用同样的处理逻辑,我们的预期行为是输出:bb,cc,dd
但是用ArrayList实现的逻辑最终输出却是:bb,bc,cc,dd
用ValueState的输出是:bb,cc,dd
这说明了,keBy后的逻辑,ArrayList不会按照预期的行为执行。这是因为在flink中,当多个并发的时候,多个key如果落入同一个线程
则当前线程的valueState是和某一个key绑定的,符合flink预期行为,但是ArrayList以及其它你定义的变量则不做保证, 它是线程级别的局部变量, 这点要注意。

http://www.mmbaike.com/news/24375.html

相关文章:

  • 网站制作的内容什么好网络快速推广渠道
  • 网上做衣服的网站有哪些百度关键字优化精灵
  • 什么做电子书下载网站好关键词排名优化易下拉技巧
  • 代做毕设要注册答疑网站搜索引擎营销的基本流程
  • 交易平台网站开发教程百度云企业网站推广有哪些方式
  • 一般做网站宽度是多少营销策划案ppt优秀案例
  • 佛山网站建设有限公司设计公司网站
  • 廊坊网站建设方案服务济南优化哪家好
  • 免费微信微网站模板下载小说搜索风云榜排名
  • 做网站需要工具苏州网站
  • 苏州退工在哪个网站做宁波企业网站seo
  • 微网站搭建的步骤和技巧重庆seo推广服务
  • 企业网站管理系统用哪个好网络服务提供者收集和使用个人信息应当符合的条件有
  • 建设积分网站长沙百度贴吧
  • 学校网站建设评审会议通知杭州网站建设网页制作
  • 泊头在哪做网站比较好大数据培训机构排名前十
  • 网站改版设计思路中国刚刚发生的新闻
  • 做网站的软件初中生泉州百度推广咨询
  • 北京市网站备案百度下载老版本
  • wordpress论坛注册网站运营seo实训总结
  • 网站维护后期费用营销网站建设教学
  • 毕业论文设计网站开发成免费crm软件有哪些优点
  • 免费域名网站申请流量平台排名
  • 网站用香港的空间速度怎么样网站优化基本技巧
  • 建设部标准定额网站营销型网站建设公司价格
  • 赣县网站建设软件开发工资一般多少
  • 做市场分析的网站seo搜索引擎优化方式
  • 建筑公司企业愿景文案珠海优化seo
  • 网购哪个平台最靠谱百度手机seo
  • 做网站需要备案舆情危机公关公司