当前位置:   article > 正文

封装数据--Map,远离POJO_不想用pojo接收数据

不想用pojo接收数据

用Map替代pojo类来装数据

需要用到的依赖!如下:

        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.66</version>
        </dependency>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 作用
    • 用以转换数据—> map <==> jsonString

代码如下

package com.hao.sftp;
import com.alibaba.fastjson.JSON;
import org.junit.Test;
import java.util.ArrayList;
import java.util.Random;
import java.util.concurrent.ConcurrentHashMap;
/**
 * @Author: Java页大数据
 * @Date: 2022-05-09:19:22
 * @Describe:
 *          1.使用ConcurrentHashMap,为线程安全的map类型;此处不用hashmap,因为hashmap为非线程安全!
 *          2.初学之前,遇到json格式,我都习惯用一个类的属性来封装数据,但是后来了解到对象的属性,其实就是一个map类型!
 *          3.如果有多层的话,就用到了List!
 *          4.此处用if语句来判断一些属性时为缺失的!或者说根据i的奇偶来获取不同的值
 *          5.多习惯这种写法,因为看框架的时候就没怎么看到会有用类来封装数据
 */
public class TestMap {

    @Test
    public void test01(){
        ArrayList<Object> lists = new ArrayList<>();
        for (int i = 1; i <= 10; i++) {
            ConcurrentHashMap<String , Object> concurrentHashMap = new ConcurrentHashMap<>(20);
            concurrentHashMap.put("id", i );
            concurrentHashMap.put("age", i + new Random().nextInt(85));
            concurrentHashMap.put("name", "javaAndBigdata" + new Random().nextInt(85));
            if (i % 3 == 0){
                concurrentHashMap.put("grade", "low");
//                concurrentHashMap.put("hobby", i % 2 == 0 ? "tv" : "sleeping"); // 控制该属性可有可无!!!
            }else if (i % 3 == 1){
                concurrentHashMap.put("grade", "midden");
                concurrentHashMap.put("hobby", i % 2 == 0 ? "football" : "tennis");
            }else {
                concurrentHashMap.put("grade", "high");
                concurrentHashMap.put("hobby", i % 2 == 0 ? "basketball" : "table tennis");
            }
            lists.add(concurrentHashMap);
        }
        String s = JSON.toJSONString(lists);
        System.out.println(s);
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42

需要实现类似的数据展示

[
	{
		"grade": "xx",
		"name": "xxx",
		"id": num,
		"age": num,
		"hobby": "x"
	},
	...
	,
	{
		"grade": "xx",
		"name": "xxx",
		"id": num,
		"age": num,
		"hobby": "xx"
	}
]
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

实现的数据展示

在这里插入图片描述

  • tip

    • 上面json格式化使用了 Notepad++的 JSON viewer插件!
    • json为前后端数据交换数据的常用数据格式!
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/爱喝兽奶帝天荒/article/detail/991937
推荐阅读
相关标签
  

闽ICP备14008679号