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

ueditor是做网站的吗成功营销十大经典案例

ueditor是做网站的吗,成功营销十大经典案例,苏州建设局网站首页,网站建设架构场景 自定义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.wangmingla.cn/news/88236.html

相关文章:

  • 泗洪做网站seo流量是什么
  • 温州快建网站建设5g影讯5g天线在线观看免费视频
  • 制作自己的网站学校无锡哪里有做网站的
  • 怎么做本地网站好项目推荐平台
  • 服装线上结合线下的推广方案东莞seo技术
  • 免费做公众号的网站中国企业500强最新排名
  • 泉州网站建设价格拉新推广平台有哪些
  • 天津餐饮网站建设兰州关键词快速上首页排名
  • wordpress投稿管理系统太原自动seo
  • 一个主机怎么做两个网站十大最免费软件排行榜
  • 浦江做网站郑州seo推广优化
  • 贵阳网站制作贵阳网站建设哪家好深圳百度公司地址在哪里
  • 买服务器做网站主机网络营销师资格证
  • 朋友圈海报用什么网站做的国内it培训机构排名
  • 品牌商标购买网站互联网推广渠道
  • 在国外社交网站做产品推广seo技巧seo排名优化
  • 网站排名忽然不见了合肥网站快速优化排名
  • 万载网站建设全球搜索
  • 个人网站认证搜索广告优化
  • 营销网站建设方案新闻头条最新消息国家大事
  • 企业网站哪个平台好南宁推广公司
  • logo做ppt模板下载网站小红书推广方式有哪些
  • 惠州市网站建设济南seo优化公司助力网站腾飞
  • 丰县数据网站建设多少钱网站优化的方法有哪些
  • 做俄语网站中国国际新闻
  • 安阳做网站推广百度推广上班怎么样
  • 网站查询真假拉新平台
  • 网站建设费需要分摊吗网络营销的基本方式有哪些
  • 四川省建设厅申报网站网络营销推广网站
  • 重庆建设雅马哈125价格站长之家seo查询