当前位置: 首页 > 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.yayakq.cn/news/556198/

相关文章:

  • 网站建设开发多少钱贵阳网站开发公司推荐
  • 御花园网站建设公司百度品牌广告收费标准
  • 做淘宝客要有网站吗用vs2010做的网站的源码
  • 温州市微网站制作多少钱做网站的外包需要分享客户信息
  • 公司网站域名备案营销网站有哪些
  • 移动网站开发公司网站修改dns
  • 公司网站制作设计价格gvm网站是什么类的网站
  • 搭建网站的六个基本步骤流程郑州新闻百度
  • 哈尔滨企业建站网站开发家用电脑桌面做网站
  • cad做兼职区哪个网站vx小程序
  • 公司网站怎么做备案wordpress自动发布
  • wordpress仿站难吗微信二维码制作小程序
  • 公司网站建设应注意网站推广目标关键词是什么意思
  • 宁波做网站优化网络推广专员好做吗
  • 做网站 用什么建站软件好网站开发自学网站
  • 泸州市建设规划局网站网站点击率如何做
  • wordpress网站调用导航菜单单页式网站 seo
  • 企业网站优化的方案oa信息管理系统
  • 自己本地可以做网站服务器seo的培训网站哪里好
  • 自己如何创立网站工厂外发订单哪里去找
  • 直播网站开发源码南宁网站建设推广服务
  • 买网站做seo购物网站图标
  • 如何利用模板做网站视频一个网站的优势有哪些
  • 温州网站建设制作企业集团网站建设方案论文
  • 查询网站服务器提供商大庆信息网
  • 百度搜索 网站介绍织梦怎么做的网站
  • 公司怎么建立自己的网站h5和html的区别
  • 哪家公司做的网站好wordpress缩略图幻灯片展现
  • 网站建设 从用户角度开始软件开发线上培训机构
  • 为什么我的网站没有百度索引量关键词排名查询工具有什么作用?