Su的技术博客

  • 首页
  • Java
  • MySQL
  • DDD
  • 事故复盘
  • 架构方案
  • AI
  • Other
  • 工具
  • 打赏
  • 关于
路很长,又很短
  1. 首页
  2. AI
  3. 正文
                           

【京东】解放双手!ChatGPT助力编写JAVA框架

2023-10-07 118点热度 0人点赞 0条评论
解放双手!ChatGPT助力编写JAVA框架
Tech

导读

本文介绍了使用 ChatGPT逐步创建 一个简单的Java框架,包括构思、交流、深入优化、逐步完善和性能测试等步骤。

亲爱的Javaer们,在平时编码的过程中,你是否曾想过编写一个Java框架去为开发提效?但是要么编写框架时感觉无从下手,不知道从哪开始。要么有思路了后对某个功能实现的技术细节不了解,空有想法而无法实现。如果你遇到了这些问题,看完这篇文章你也能用ChatGPT编写一个简单的JAVA框架。

01 

构思清晰

在今年的敏捷团队建设中,我通过Suite执行器实现了一键自动化单元测试。Juint除了Suite执行器还有哪些执行器呢?由此我的Runner探索之旅开始了!

首先,你需要明确你的框架要解决什么问题,具有什么特性。这将有助于ChatGPT更好的理解你的需求。

例如:在一个前后端分离的需求中发现有太多的枚举类的描述需要给前端返回。传统的方式是后端根据枚举类的映射,每个枚举值编写代码映射成描述给前端返回。但这次需求需要给前端返回的枚举描述太多了,感觉无从下手。所以就思考能否编写一个注解自动帮助扫描这些枚举类,然后生成key和描述的map,最终放到容器中去呢?

解决问题:解决前后端分离过程中需要手动编写代码将枚举key的描述映射给前端。

特性:框架有一个注解,注解有三个字段name,key,和desc,修饰在枚举类上。框架需提供外部获取枚举map的接口。

02 

  与ChatGPT交流  

理解,首先 MCube 会依据模板缓存状态判断是否需要网络获取最新模板,当获取到模板后进行模板加载,加载阶段会将产物转换为视图树的结构,转换完成后将通过表达式引擎解析表达式并取得正确的值,通过事件解析引擎解析用户自定义事件并完成事件的绑定,完成解析赋值以及事件绑定后进行视图的渲染,最终将目标页面展示到屏幕。
启动 ChatGPT,向它讲述你的构想和需求。它可以为你生成初始代码、提供结构建议,甚至帮你处理一些逻辑。
想好了框架要解决的问题和框架的特性之后,接下来就要将框架要解决的问题和特性给总结成一段文字发给ChatGPT。

解放双手!ChatGPT助力编写JAVA框架图1.与ChatGPT交流示意

chatgpt根据需求大概生成了下框架的demo版本。可以看到和设想的还是有些区别的,本想是将枚举放在类上。然后枚举的属性有name,key,和desc。

name:代表枚举map在最外层map中的key。

key:代表枚举的key或值字段。

desc:代表枚举的描述字段。

解放双手!ChatGPT助力编写JAVA框架

解放双手!ChatGPT助力编写JAVA框架

解放双手!ChatGPT助力编写JAVA框架图2、3、4.
03 

  

深入互动  

理解,首先 MCube 会依据模板缓存状态判断是否需要网络获取最新模板,当获取到模板后进行模板加载,加载阶段会将产物转换为视图树的结构,转换完成后将通过表达式引擎解析表达式并取得正确的值,通过事件解析引擎解析用户自定义事件并完成事件的绑定,完成解析赋值以及事件绑定后进行视图的渲染,最终将目标页面展示到屏幕。
与 ChatGPT 进行更深入的交流,询问它关于代码优化、异常处理等方面的建议。它可以帮你找到更好的解决方案。
接下来需要与ChatGPT进一步交流,让ChatGPT将之前生成的代码进行优化。

EnumInfo注解优化前:

解放双手!ChatGPT助力编写JAVA框架

图5.

优化后:
解放双手!ChatGPT助力编写JAVA框架图6.
04 

  逐步完善  

理解,首先 MCube 会依据模板缓存状态判断是否需要网络获取最新模板,当获取到模板后进行模板加载,加载阶段会将产物转换为视图树的结构,转换完成后将通过表达式引擎解析表达式并取得正确的值,通过事件解析引擎解析用户自定义事件并完成事件的绑定,完成解析赋值以及事件绑定后进行视图的渲染,最终将目
4.1  逐步引导ChatGPT完善框架
    
在 ChatGPT 的帮助下,逐步完善你的框架。亲自动手编写代码,与 ChatGPT 一起探讨每个细节。

最后可以和ChatGPT一步步交流,让它帮你构建一个完整的框架。

解放双手!ChatGPT助力编写JAVA框架图7.

最终慢慢与ChatGPT不断对话迭代之后将框架的核心类生成,迭代过程由于太长故省略。
4.2  框架核心类说明
    
在ChatGPT给出核心代码之后,参考Spring模块设计最终初版框架类如下:

PackageScanner:用于扫描给定包中带有指定注解的类的实用工具类。

PropertiesUtils:提供操作属性文件的实用方法的工具类。

EnumInfo:用于标注枚举类的注解,指定枚举项的名称、key 字段和 desc 字段信息。 通过在枚举类上添加该注解,可以为枚举项建立索引映射,并指定用于查找 key 和 desc 的字段名称。

EnumContext:枚举上下文类,用于管理枚举定义信息并提供获取枚举信息的方法。

EnumContextFactory:枚举上下文工厂类,用于创建和获取单例的枚举上下文对象。

EnumDefinition:表示枚举定义的类,用于存储枚举类的信息。

EnumDefinitionRegistry:枚举定义注册接口,用于注册、查询和管理枚举定义。

DefaultEnumFactory:默认的枚举定义工厂类,实现了 EnumDefinitionRegistry 接口。

解放双手!ChatGPT助力编写JAVA框架图8.

看到这使用ChatGPT编写框架部分已经完成了。大件可以使用chatgpt开发自己的JAVA框架。但要想把框架实际应用到生产还需要做一些收尾流程。
05 

  框架使用测试  

理解,首先 MCube 会依据模板缓存状态判断是否需要网络获取最新模板,当获取到模板后进行模板加载,加载阶段会将产物转换为视图树的结构,转换完成后将通过表达式引擎解析表达式并取得正确的值,通过事件解析引擎解析用户自定义事件并完成事件的绑定,完成解析赋值以及事件绑定后进行视图的渲染,最终将目

在于ChatGPT交流,完成框架编写之后需要将框架应用到实际项目中。

在业务系统管理端在进行前后端分离的过程中,研发们发现有许多枚举类对应的枚举描述需要给前端返回。

1)一开始设想的是每个枚举类都写代码给前端封装返回文字。但是由于笔者业务系统配置项过多,每个配置项都写代码太过麻烦。

2)于是研发们想能否使用一个统一的接口给前端返回枚举类对应的描述,前端只需要输入枚举类名称就可以获得对应的枚举key和描述的映射关系。

于是创建了一个接口,定义了一个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中。并且枚举类需要新增一个获取key和描述的映射关系方法。这样还是太麻烦了。并且后续新增映射关系还得更改这个类的代码。

能否将map初始化的步骤和枚举类创建map的步骤省略呢?

3)于是设想定义一个注解。使用这个注解标记的类,框架扫描这些类。并生成获取枚举key和描述的映射关系的方法。最终完成初始化Map的过程。对外只提供获取总枚举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和描述的映射关系。极大的减少了研发联调时间及测试回归时间。

06 

  框架性能压测  

理解,首先 MCube 会依据模板缓存状态判断是否需要网络获取最新模板,当获取到模板后进行模板加载,加载阶段会将产物转换为视图树的结构,转换完成后将通过表达式引擎解析表达式并取得正确的值,通过事件解析引擎解析用户自定义事件并完成事件的绑定,完成解析赋值以及事件绑定后进行视图的渲染,最终将目
框架应用到实际生产项目中,需要对ChatGPT辅助编写的框架进行充分的测试验证。同时也要对框架的性能进行测试,知道框架的瓶颈。常见的接口压测工具有LoadRunner和Apache JMeter等。任选一种压测工具进行压测即可。

将框架应用到项目中对外暴露了一个接口,该接口在4C4G机器配置下,单机最高可支持1000QPS,在1000QPS下,单机CPU使用率达到30%,系统负载接近0.9,内存使用率与压测前无明显变化。

07 

  总结  

理解,首先 MCube 会依据模板缓存状态判断是否需要网络获取最新模板,当获取到模板后进行模板加载,加载阶段会将产物转换为视图树的结构,转换完成后将通过表达式引擎解析表达式并取得正确的值,通过事件解析引擎解析用户自定义事件并完成事件的绑定,完成解析赋值以及事件绑定后进行视图的渲染,最终将目

本文演示了如何使用ChatGPT逐步创建Java框架,解决前后端分离中的问题。以上使用ChatGPT逐步完善框架的经验分享给大家,希望对各位有所帮助。

解放双手!ChatGPT助力编写JAVA框架
解放双手!ChatGPT助力编写JAVA框架

‍

打造SAAS化服务的会员徽章体系,可以作为标准的产品化方案统一对外输出。结合现有平台的通用能力,实现会员行为全路径覆盖,并能结合企业自身业务特点,规划相应的会员精准营销活动,提升会员忠诚度和业务的持续增长。
▪
底层能力:维护用户基础数据、行为数据建模、用户画像分析、精准营销策略的制定

▪功能支撑:会员成长体系、等级计算策略、权益体系、营销底层能力支持

▪用户活跃:会员关怀、用户触达、活跃活动、业务线交叉获客、拉新促活

‍

‍

本文仅供学习!所有权归属原作者。侵删!文章来源: 京东技术 -云交易 王凤玺 :http://mp.weixin.qq.com/s/OWDGQKNB-gWvXB0mogOSdw

更多文章:

  1. Chrome插件(扩展)开发全攻略2.6w字,看这篇就够了!
  2. 殷浩详解DDD系列 第一讲 - Domain Primitive
  3. 手把手教你实战TDD
  4. 殷浩详解DDD 第四讲:领域层设计规范
  5. 浅析设计模式3 —— 装饰者模式
  6. 设计模式在外卖营销业务中的实践
  7. 全链路压测之影子库及ShardingSphere实现影子库源码剖析
  8. 浅析设计模式1 —— 工厂模式
标签: 京东 Java AI ChatGPT 框架 编程助手
最后更新:2023-10-07

coder

分享干货文章,学习先进经验。

打赏 点赞
< 上一篇
下一篇 >

文章评论

razz evil exclaim smile redface biggrin eek confused idea lol mad twisted rolleyes wink cool arrow neutral cry mrgreen drooling persevering
取消回复

文章目录
  • 构思清晰
  •   与ChatGPT交流  
  •   逐步完善  
  •   框架使用测试  
  •   框架性能压测  
  •   总结  
最新 热点 推荐
最新 热点 推荐
图解Git ChatGLM:ChatGPT的替代方案 关于聚合根、领域事件的那点事——深入浅出理解DDD 系统设计 | UUID 和 自增 ID 怎么选? Vim 一下日志文件,Java 进程没了? DDD系列第五讲:聊聊如何避免写流水账代码 LLM下半场之Agent基础能力概述:Profile、Memory、Plan、Action、Eval学习笔记 浅析Redis大Key
OpenAI震撼技术圈!0代码构建Assistants API,技术原理探秘LLM下半场之Agent基础能力概述:Profile、Memory、Plan、Action、Eval学习笔记系统设计 | 导入和导出系统设计 | 如何管理应用系统中的配置?系统设计 | UUID 和 自增 ID 怎么选?Vim 一下日志文件,Java 进程没了?关于聚合根、领域事件的那点事——深入浅出理解DDD浅析Redis大Key
4.架构风格 vs. 架构模式 vs. 设计模式(译) Spring中@Autowired和@Inject注解的区别? JAVA字节码增强解密(下) Redis为什么这么快? 京东购物车如何提升30%性能 阿里云香港云服务器P0史诗级宕机事件复盘 Java后端18种接口优化技巧 殷浩详解DDD 第三讲 - Repository模式

618 (1) Agent (2) AIGC (1) bigkey (2) chatglm (1) checkout (1) commit (2) Disruptor (1) Excel (1) FGC (3) G1 (1) G1GC (2) git (2) GLM (1) hotkey (1) LangChain (1) LLM (3) mvc (1) OpenAI (2) ParNew (3) pull (1) push (1) solid (1) UUID (1) Vim (1) vivo (2) ygc (1) 业务编号 (1) 事务隔离级别 (1) 低耦合 (1) 依赖注入原则 (1) 分布式ID (1) 分支 (1) 分页 (3) 单一职责原则 (1) 命名 (1) 垃圾回收器 (7) 大模型 (2) 大语言模型 (1) 开源 (1) 开闭原则 (1) 微博 (1) 微服务 (1) 性能调优 (10) 接口隔离原则 (1) 数据字典 (1) 数据导入 (1) 数据导出 (1) 方案设计 (7) 权限 (1) 架构师 (1) 架构模式 (1) 架构设计 (4) 架构风格 (1) 模块 (1) 死锁 (1) 测试策略 (1) 滴滴 (1) 版本控制 (2) 电商 (2) 系统架构 (4) 编程语言 (2) 订单号 (1) 认证 (1) 软件架构 (2) 配置 (1) 里氏替换原则 (1) 鉴权 (1) 降级 (1) 高内聚 (1)

COPYRIGHT © 2014-2023 verysu.com . ALL RIGHTS RESERVED.

Theme Kratos Made By Seaton Jiang

粤ICP备15033072号-2