CRUD是指集合的增删改查,看到这个题目首先对他进行分析
Kafka拿到数据,搞个字符串,json字符串,把它解析成一个json对象,把它封装成javaBean,解析过程中,可能有异常,把它捕获处理一下。遥测数据,有个kafka数据格式,我们拿到的kafka都是json格式,json解析一定要会。我拿到的是json字符串,转成json对象,因为要为javabean赋值,自己手动搞几条数据,也可以在数据库里面用jdbc把它弄出来。比如这边搞几条数据,可以玩list,map,map比如以psID为key,list可以增删改查,用java8的lambda表达式和stream流去玩。没写数据库,可以自己把jdbc融合进去可以自己搞几条数据,这种格式能不能自己模拟出来,搞个模拟程序,自己搞模拟程序发,往kafka发数据,自己开发的时候,可以自己造数据,自己搞个程序造数据,暂时可以一个单线程去造,造完以后直接读,可以kafka发,kafka读,网上一搜就出来了,发过来直接读,读完以后去转换,转换以后集合map去玩。
代码如下:
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import java.time.Period;
import java.util.*;
public class MainType {
public static void main(String[] args) {
//创建json对象,Psid对象与json之间的转换
Psid p1 = new Psid(109063,"20200106121210","3","1",25.64);
Object obj = JSONArray.toJSON(p1);
String json = obj.toString();
System.out.println("将Psid对象转换成json"+json);
System.out.println("==========================");
// kafka 数据格式
String kafkaMsg = "{\"devType\":\"3\",\"val\":25.64,\"recvTime\":\"20200106121210\",\"devCode\":\"1\",\"psID\":109063}";
// 1. str -> JSONObject,从JSONObject中取出属性值,做校验,封装到javabean中
// 2. str -> JavaBaan,使用javabean做属性校验 ,决定是否保留javabean
// 3. 转换过程中,有可能出现异常,try -- catch,让程序继续运行
System.out.println(JSONObject.parseObject(kafkaMsg, Psid.class));
Psid p2 = JSONArray.parseObject(json, Psid.class);
System.out.println("转换后的person对象:"+"PSID:"+p2.getPsID()
+" Recvtime:"+p2.getRecvTime()+" devType:"+p2.getDevType()
+" devcode:"+p2.getDevCode()+" val:"+p2.getVal());
System.out.println("=========================");
ArrayList<Integer> list1 = new ArrayList<>();
ArrayList<String> list2 = new ArrayList<>();
ArrayList<Double> list3 = new ArrayList<>();
list1.add(109063);
Collections.addAll(list2,"3","20200106121210","1");
list3.add(25.64);
methodlist(list1);
methodlist(list2);
methodlist(list3);
System.out.println("========================");
//增删改查
//设置一个集合list4
ArrayList<String> list4 = new ArrayList<>();
Collections.addAll(list4,"109063","3","20200106121210","1","25.64");
System.out.println(list4);
//使用for增强循环遍历集合
for (String s : list4) {
System.out.println(s);
}
System.out.println("================");
//往集合里添加元素
list4.add("2");
System.out.println(list4);
//获取集合第一个数据
System.out.println(list4.get(0));
//删除集合最后一个数据
System.out.println(list4.remove(5));
System.out.println(list4);
//替换list4集合中的第三个元素为52
list4.set(2,"52");
System.out.println(list4);
// list 的stream + lambda
// 3 = List[psIdbean1,psIdb3]
}
//泛型通配符
public static void methodlist(ArrayList<?> list){
//使用迭代器遍历集合
Iterator<?> it = list.iterator();
while(it.hasNext()){
System.out.println(it.next());
}
}
}
封装的成员属性代码如下
import com.alibaba.fastjson.annotation.JSONField;
public class Psid {
//使用toJson方法把对象转换成json格式字符串
@JSONField(name = "aaaaaaaa")
private int psID; //电站id
private String recvTime;//设备消息上传时间
private String devType;//设备类型
private String devCode;//设备编码
private double val;//测点值
public Psid() {
}
public Psid(int psID, String recvTime, String devType, String devCode, double val) {
this.psID = psID;
this.recvTime = recvTime;
this.devType = devType;
this.devCode = devCode;
this.val = val;
}
@Override
public String toString() {
return "Json{" +
"psID=" + psID +
", recvTime='" + recvTime + '\'' +
", devType='" + devType + '\'' +
", devCode='" + devCode + '\'' +
", val=" + val +
'}';
}
public int getPsID() {
return psID;
}
public void setPsID(int psID) {
this.psID = psID;
}
public String getRecvTime() {
return recvTime;
}
public void setRecvTime(String recvTime) {
this.recvTime = recvTime;
}
public String getDevType() {
return devType;
}
public void setDevType(String devType) {
this.devType = devType;
}
public String getDevCode() {
return devCode;
}
public void setDevCode(String devCode) {
this.devCode = devCode;
}
public double getVal() {
return val;
}
public void setVal(double val) {
this.val = val;
}
}
运行后的结果如下
将Psid对象转换成json{"devType":"3","val":25.64,"recvTime":"20200106121210","devCode":"1","aaaaaaaa":109063}
==========================
Json{psID=0, recvTime='20200106121210', devType='3', devCode='1', val=25.64}
转换后的person对象:PSID:109063 Recvtime:20200106121210 devType:3 devcode:1 val:25.64
=========================
109063
3
20200106121210
1
25.64
========================
[109063, 3, 20200106121210, 1, 25.64]
109063
3
20200106121210
1
25.64
================
[109063, 3, 20200106121210, 1, 25.64, 2]
109063
2
[109063, 3, 20200106121210, 1, 25.64]
[109063, 3, 52, 1, 25.64]