导读
本文介绍了使用 ChatGPT逐步创建 一个简单的Java框架,包括构思、交流、深入优化、逐步完善和性能测试等步骤。
亲爱的Javaer们,在平时编码的过程中,你是否曾想过编写一个Java框架去为开发提效?但是要么编写框架时感觉无从下手,不知道从哪开始。要么有思路了后对某个功能实现的技术细节不了解,空有想法而无法实现。如果你遇到了这些问题,看完这篇文章你也能用ChatGPT编写一个简单的JAVA框架。
构思清晰
首先,你需要明确你的框架要解决什么问题,具有什么特性。这将有助于ChatGPT更好的理解你的需求。
例如:在一个前后端分离的需求中发现有太多的枚举类的描述需要给前端返回。传统的方式是后端根据枚举类的映射,每个枚举值编写代码映射成描述给前端返回。但这次需求需要给前端返回的枚举描述太多了,感觉无从下手。所以就思考能否编写一个注解自动帮助扫描这些枚举类,然后生成key和描述的map,最终放到容器中去呢?
解决问题:解决前后端分离过程中需要手动编写代码将枚举key的描述映射给前端。
特性:框架有一个注解,注解有三个字段name,key,和desc,修饰在枚举类上。框架需提供外部获取枚举map的接口。
与ChatGPT交流
图1.与ChatGPT交流示意
chatgpt根据需求大概生成了下框架的demo版本。可以看到和设想的还是有些区别的,本想是将枚举放在类上。然后枚举的属性有name,key,和desc。
name:代表枚举map在最外层map中的key。
key:代表枚举的key或值字段。
desc:代表枚举的描述字段。
深入互动
EnumInfo注解优化前:
图5.
逐步完善
最后可以和ChatGPT一步步交流,让它帮你构建一个完整的框架。
图7.
PackageScanner:用于扫描给定包中带有指定注解的类的实用工具类。
PropertiesUtils:提供操作属性文件的实用方法的工具类。
EnumInfo:用于标注枚举类的注解,指定枚举项的名称、key 字段和 desc 字段信息。 通过在枚举类上添加该注解,可以为枚举项建立索引映射,并指定用于查找 key 和 desc 的字段名称。
EnumContext:枚举上下文类,用于管理枚举定义信息并提供获取枚举信息的方法。
EnumContextFactory:枚举上下文工厂类,用于创建和获取单例的枚举上下文对象。
EnumDefinition:表示枚举定义的类,用于存储枚举类的信息。
EnumDefinitionRegistry:枚举定义注册接口,用于注册、查询和管理枚举定义。
DefaultEnumFactory:默认的枚举定义工厂类,实现了 EnumDefinitionRegistry 接口。
图8.
框架使用测试
在于ChatGPT交流,完成框架编写之后需要将框架应用到实际项目中。
1)一开始设想的是每个枚举类都写代码给前端封装返回文字。但是由于笔者业务系统配置项过多,每个配置项都写代码太过麻烦。
于是创建了一个接口,定义了一个Map对象给前端返回枚举类的key和描述的对应关系。但是由于业务系统的渠道配置还是太多了。使用这种方式需要初始化这个Map。初始化Map代码如下:
public HashMap<String, Map<Integer, String>> initEnumMap() { enumMap = new HashMap<>(); enumMap.put("前端获取枚举map的key", XXXEnum.getEnumMap()); enumMap.put("前端获取枚举map的key", XXXEnum.getEnumMap()); enumMap.put("前端获取枚举map的key", XXXEnum.getEnumMap()); ... return enumMap; }
能否将map初始化的步骤和枚举类创建map的步骤省略呢?
/** * 获取枚举 * * @param enumKey 枚举key * @return 返回值 Map<Integer,String>;code,描述 */ @RequestMapping("/getEnum") public Result<Map<String, Map<String, String>>> getEnum(String enumKey) { try { // 获取枚举上下文对象 EnumContext enumContext = EnumContextFactory.getEnumContext(); // 获取枚举map newEnumMap = enumContext.getEnumIndexMap(); // buid映射从ducc中获取,所以需要手动设置 newEnumMap.put(BUID.getKey(), getBuIdMap()); } catch (Exception e) { log.error("获取枚举map出错!enumKey:{}", enumKey, e); return Result.createFail(e.getMessage()); } // 如果枚举key为空则返回全部 if (StringUtils.isBlank(enumKey)) { return Result.createWithSuc(newEnumMap); } // 如果枚举key不为空则返回指定值 Map<String, Map<String, String>> resultMap = new HashMap<>(); resultMap.put(enumKey, newEnumMap.get(enumKey)); return Result.createWithSuc(resultMap); }
4)注解类代码如下:
@EnumInfo(name = "StatusEnum", key = "code", desc = "description") public enum StatusEnum { SUCCESS(200, "Success"), ERROR(500, "Error"); private final int code; private final String description; StatusEnum(int code, String description) { this.code = code; this.description = description; } public int getCode() { return code; } public String getDescription() { return description; } }
以后新增一个枚举类只需要标记@EnumInfo(name = "StatusEnum", key = "code", desc = "description")。将枚举类的name ,key字段名称和描述字段名称指定即可。无需修改接口的代码即可给前端返回该枚举的key和描述的映射关系。极大的减少了研发联调时间及测试回归时间。
框架性能压测
将框架应用到项目中对外暴露了一个接口,该接口在4C4G机器配置下,单机最高可支持1000QPS,在1000QPS下,单机CPU使用率达到30%,系统负载接近0.9,内存使用率与压测前无明显变化。
总结
本文演示了如何使用ChatGPT逐步创建Java框架,解决前后端分离中的问题。以上使用ChatGPT逐步完善框架的经验分享给大家,希望对各位有所帮助。
本文仅供学习!所有权归属原作者。侵删!文章来源: 京东技术 -云交易 王凤玺 :http://mp.weixin.qq.com/s/OWDGQKNB-gWvXB0mogOSdw
文章评论