GPT4结对编程实战,鹅厂一线研发真实使用感受

news2024/11/30 12:44:03

图片

图片

👉腾小云导读

ChatGPT4相比ChatGPT3.5在逻辑推理能力上有很大的进步,其代码生成能力颇为优越。因此作者尝试在工作中某些不涉密的基础工作上,应用ChatGPT4来提升研发效率,简单尝试之后发现其在不少场景是有效的。本文将向大家展示如何充分利用 ChatGPT-4 结合结对编程方法,在研发过程中实现显著的效率提升。

重要提示:大家在做相应尝试的时候,一定要注意信息安全。

👉看目录,点收藏

1 场景一:正则表达式编写

2 场景二:重构代码

3 场景三:实现业务逻辑

4 场景四:改bug与写单测

5 场景五:取名字

6 总结

01、场景一:场景正则表达式编写

我所在的团队负责某可观测平台的研发。PromQL 是可观测领域常用的查询语言,Protobuf 这种协议有自带基于正则表达式的参数检查器,因此我们需要写一个正则表达式,来检测 PromQL 的合法性,以便于尽早的发现不合法的 PromQL,抛出错误、降低底层引擎的压力。

对于这个需求,按个人经验来说我认为至少得花超过一小时编码及单元测试。得翻阅不少 PromQL 手册、正则表达式的手册。我们试着把这个任务交给 ChatGPT4:

图片

ChatGPT4 写了一个很复杂的表达式,并且告诉我们这个需求是不合理的,完美的语法检测得要实现一个语法分析器,而不是正则表达式。

这里我完善了我的需求:我们在接入层的正则应该在乎精确率,忽略召回率,旨在尽早发现一部份错误,而不是全部错误:

图片

这一次的输出看上去还不错。但是我懒、不想仔细看,我又不放心它写。所以我要求它自己写个单测,进行充分的自测:

图片

ChatGPT4 写的单测非常 readability,它还知道表驱动的方式写测试数据。咱们把代码 run 起来:

图片

有一个测试用例没过,我们可以把这种情况告诉 ChatGPT4,让它自己解决:

图片

ChatGPT4 说:要解决这个问题,必须引入更复杂的表达式。然而这不是我们想要的结果,因此我们还是选择了更简单的正则表达式交付需求,做一些简单的检查,更复杂的检查就交给 promql 语法解析器去做。

所以我花5分钟,发现了需求的不合理,选择了最符合业务需求的方案,并且还写完了我们想要的正则表达式。并且代码非常 readability,同时有单测。

02、场景二:重构代码

我们写代码的过程中,往往会因为疏忽,而产出各种「bug 和坏味道」。我们来试试 ChatGPT4 能帮我们做什么。下面随机找了一段我们代码仓库里面的不涉密基础代码,发给ChatGPT4:

package strings  
import (  
"fmt"  
"regexp"  
"strconv"  
)  
var reOfByte = regexp.MustCompile(`(\d+)([GgMmKkBb]?)`)  
// ParseByteNumber 解析带有容量的字符串  
func ParseByteNumber(s string) int64 {  
  arr := reOfByte.FindAllStringSubmatch(s, -1)  
if len(arr) < 1 || len(arr[0]) < 3 {  
return -1  
  }  
  n, err := strconv.Atoi(arr[0][1])  
if err != nil {  
return -2  
  }  
if n <= 0 {  
return -3  
  }  
switch arr[0][2] {  
case "G", "g":  
return int64(n) * (1024 * 1024 * 1024)  
case "M", "m":  
return int64(n) * (1024 * 1024)  
case "K", "k":  
return int64(n) * (1024)  
case "B", "b", "":  
return int64(n)  
default:  
return -4  
  }  
}

先让ChatGPT看一眼代码:

图片

ChatGPT4 表示它看懂了。接下来我们给 ChatGPT4 提一下重构的需求,看看ChatGPT4 的表现:

图片

ChatGPT4 这些优化,使得代码 readability 了很多。特别是错误码返回的模块,原来的代码真是天坑。但同时我们也发现这个函数实现是不太符合需求的——它只匹配了 substring。例如 XXXX100KBXXX 这类参数也会被错误匹配。我们把这些情况告诉 GPT4,看看它的表现:

图片

这里我们看到:

GPT4 不仅仅完成了需求,它还做到了兼容浮点数输入,使得返回的精度更高了。例如 1.5MB 实际是 1536B ,按我们最初的实现确实会丢失精度,变成1024B。此外,还帮我们发现了个 BUG。

照例,让它补充一下单测:

图片

通过15分钟的简单交流,我和 ChatGPT 一起完成了这次代码重构。

03、场景三:实现业务逻辑

虽然要求 chatGPT4 一次性给我们交付整个完整需求有点过分,但我们依然可以把需求拆分成小的逻辑单元给chatGPT实现,并要求它编写单测。

这次,我们找了我们项目里面最新的需求来做个实验,让 ChatGPT 帮我们完成需求——做一个事件的聚合能力。我们的可观测平台(伽利略)会收集各个平台的事件数据,聚合之后以更加可视化的方式给用户展示:

图片

图片

图片

图片

在我不断的追加需求细节之后,chatGPT4交付了一个还算可以的成果。但是这里我们发现这段代码有个BUG。当然,我是不会自己动手修复的,让GPT4自己来吧:

图片

其交付的整体代码虽然不算特别清晰,但做一些修改还是可以用的。当然我觉得这跟我个人没把需求描述的太清楚也有关系。

04、场景四:改BUG

我们的可观测平台(伽利略)支持自定义指标,底层识别的变量类型是$1,$2,$3这种形式,UI为了用户可读性,是表现为A,B,C。最近出现了一个BUG,A+B+C+D+E+F+G+H+I+J+K配置下去再加载上来之后编程A+B+C+D+E+F+G+H+I+J+B0。

原因K是$11,但是前端转码的实现,是 for 循环遍历处理的,所有处理两位数字有 BUG,转回来识别成了$1和0:

图片

我们把这个问题给ChatGPT,看它怎么解决:

图片

===

图片

此外,各位开发者通过上面的例子应该能感受到 GPT4 写单测的能力了。它不管是表驱动、测试用例的构造能力、代码的 readability 能力都非常强!此处我们不进行展开赘述了。

05、场景五:取名字

我们知道取变量名和函数名是工程师们最头疼的问题。

这个 ChatGPT4 非常擅长,毕竟这是它的母语呀。例如上面的解析存储容量的函数,它给的建议确实比原名好太多了。

图片

06、总结

说一说我个人关于GPT3和GPT4的使用体验。

当被输入需求,GPT3 仿佛是从网上搜了一些代码组合给我,而 GPT4更能理解我的需求,而且它能根据我的反馈不断的优化它给我的代码。整体来说,GPT4 相比历代,在逻辑推理能力上有了很大的进步,它的代码生成能力更是让我非常震撼。

此外,它在视觉表达、跨领域能力、编程能力等等也有飞跃的进步,此处不展开赘述。如果各位感兴趣,可以在公众号(点👉这里👈进入开发者社区,右边扫码即可进入公众号)后台回复 「GPT-4」,查看完整的测评报告。了解其能力的边界,将有助于各位更好应用。

虽然 GPT 等工具不能完全替代工程师编码,但在很多繁琐且不需要交代太多背景的独立工作上,GPT4 还是完成的非常不错的。作为一个技术人员,尝试下与GPT4结对编程的方式,有可能在某些方面真的能提升自身生产效率。欢迎各位开发者体验。以上是本次分享全部内容,欢迎大家在评论区分享交流。

-End-

原创作者|胡宸源

技术责编|胡宸源

图片

你有什么使用ChatGPT的小技巧和心得,欢迎在公众号(点👉这里👈进入开发者社区,右边扫码即可进入公众号)评论区分享讨论。我们将选取1则最有创意的分享,送出腾讯云开发者-文化衫1个(见下图)。5月18日中午12点开奖。

图片

图片

图片

图片

图片

想了解GPT-4完整能力测评(视觉表达、跨领域能力、编程能力等)?在腾讯云开发者公众号(点👉这里👈进入开发者社区,右边扫码即可进入公众号)后台回复「GPT-4」,查看完整测评报告。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/527824.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

元宇宙又“死”了!Epic老板:你当6亿用户是摆设?

“扎克伯格花了数年时间试图让Metaverse成为现实&#xff0c;但现在它已被AI取代&#xff0c;并走向科技创意的坟墓。”一篇表达“元宇宙已死”的文章近期在推特上引发热议&#xff0c;而游戏制作公司Epic Games CEO Tim Sweeney的还击更是让这个话题热上加热。 “搞一次在线守…

【SSL证书】使用mkcert创建局域网或单机可信任Windows格式证书

初学者对SSL证书的理解可能非常模糊。所谓SSL证书&#xff0c;其实它包含两个方面&#xff0c;一是根证书&#xff0c;二是HTTPS的证书&#xff0c;HTTPS证书合法性由其根证书来进行认定。几大证书供应商的根证书一般都预置在系统中了&#xff0c;所以给人的错觉就是只知HTTPS证…

深入解析 Facebook 分析工具,洞察用户行为和优化策略

作为一名 Facebook 运营者&#xff0c;了解用户行为和优化策略是至关重要的。在本文中&#xff0c;我们将深入解析Facebook 分析工具&#xff0c;帮助你更好地洞察用户行为和优化策略。 1.Facebook 像素 Facebook 像素是一个重要的工具&#xff0c;可以帮助运营者了解用户在网…

SNMP简介

背景 简单网络管理协议SNMP&#xff08;Simple Network Management Protocol&#xff09;用于网络设备的管理。网络设备种类多种多样&#xff0c;不同设备厂商提供的管理接口&#xff08;如命令行接口&#xff09;各不相同&#xff0c;这使得网络管理变得愈发复杂。为解决这一…

新车推迟、裁员降本,沃尔沃被现实狠狠“扇了一个耳光”

汽车行业的魅力&#xff0c;或许就在于不断的给自己打气&#xff0c;然后被打脸。 今年&#xff0c;上海车展开幕前&#xff0c;沃尔沃汽车大中华区销售公司总裁钦培吉在新车发布会上直言&#xff1a;“新势力会的&#xff0c;我们三年就学会了&#xff1b;我们会的&#xff0c…

无影云桌面,搭建一个属于自己的云上主机

无影云桌面&#xff0c;搭建一个属于自己的云上主机 1.无影云桌面介绍2.无影云桌面试用3.无影云桌面尝鲜4.测试云桌面的连通性5.体验无影云的娱乐办公场景6.将无影云桌面作为服务器使用7.无影云桌面使用总结 1.无影云桌面介绍 无影云桌面是一种云计算技术&#xff0c;可以将用…

《LKD3粗读笔记》(12)内存管理

1、页 内核把物理页作为内存管理的基本单元内存管理单元&#xff08;MMU&#xff09;以页为单位来管理系统中的页表从虚拟内存的角度看&#xff0c;页就是最小单位。体系结构不同&#xff0c;支持页的大小也不尽相同。大多数32位体系结构支持4KB的页&#xff0c;而64位体系结构…

排序算法之堆排序的实现

一、堆的相关概念 堆一般指的是二叉堆&#xff0c;顾名思义&#xff0c;二叉堆是完全二叉树或者近似完全二叉树 1. 堆的性质 ① 是一棵完全二叉树 ② 每个节点的值都大于或等于其子节点的值&#xff0c;为最大堆&#xff1b;反之为最小堆。 2. 堆的存储 一般用数组来表示堆&…

网站域名查询地址-域名所有者查询

域名查询注册信息查询 147SEO域名查询是一款全能的域名查询注册信息查询软件。它不仅提供了单个域名的实时查询功能&#xff0c;还支持批量域名查询功能&#xff0c;可以快速查询多个域名的注册和到期信息。以下是147SEO域名查询的主要特点&#xff1a; 批量域名查询&#xff…

基于【EasyDL】【图像分类】实现农作物病害识别小程序

内容、数据集来源:基于飞桨的农作物病害智能识别系统 - 飞桨AI Studio 项目背景 联合国粮食及农业组织的一份报告表明&#xff0c;每年农业生产的自然损失中有三分之一以上是由农业病虫害造成的&#xff0c;使这些成为当前影响农业生产和农业生产的最重要因素。需要考虑的农业…

浅谈Vue响应式

什么是响应式 不管是自己面试还是八股文告诉你的是&#xff0c;响应式描述的是视图与数据变化之间的一种关系。但这不够准确。 要要了解什么是响应式&#xff0c;我们必须了解不管是React,还是Vue其实本质就是一个函数。 那么我们可以形象的说&#xff1a;响应式描述的就是函数…

编译C++ makefile ZXing-cpp生成条型码 二维码及识别 再试验证成功vs2022

下载ZXing-cpp源码及vs2022 cmake --help看看支持的vs 为什么没有win32呢 进到目录&#xff0c;//新建编译目录//生成vs工程 mkdir build & cd build cmake .. 中间提示opencv和qt等缺东西不要紧&#xff0c;我只用到生成条型码 release也正常。生成成功。 默认是MD 先…

记一次 .NET 某医院门诊软件 卡死分析

一&#xff1a;背景 1. 讲故事 前几天有位朋友找到我&#xff0c;说他们的软件在客户那边卡死了&#xff0c;让我帮忙看下是怎么回事&#xff1f;我就让朋友在程序卡死的时候通过 任务管理器 抓一个 dump 下来&#xff0c;虽然默认抓的是 wow64 &#xff0c;不过用 soswow64.…

FreeRTOS学习笔记(四)——应用开发(二)

文章目录 0x01 互斥量互斥量的优先级继承机制互斥量应用场景互斥量运作机制互斥量控制块互斥量接口函数xSemaphoreCreateMutex()xQueueCreateMutex()prvInitialiseMutex&#xff08;&#xff09;xSemaphoreCreateRecursiveMutex()vSemaphoreDelete()xSemaphoreTake()xQueueSema…

通过nginx配置 将vue项目运行到阿里云linux服务器上

先将 我们的vue项目打包起来 打包好之后 我们在项目根目录下 找到 dist 下的 index.html 保证这个文件要能正常运行 然后 我们将这个dist文件夹 压缩一下 然后 回到项目终端 执行 scp -r ./dist.zip 用户名(如果之前没设置过就是 root)服务器公网地址:/root然后 他会要求我…

多语言网站的外包开发流程

随着互联网/移动互联网的全球普及&#xff0c;越来越多的企业希望将产品卖向全球&#xff0c;这就首先需要有一个多语言的网站来宣传公司的产品&#xff0c;那设计和开发这样的网站需要注意什么呢&#xff0c;今天和大家分享这方面的知识。北京木奇移动技术有限公司&#xff0c…

C-函数栈帧

文章目录 函数栈帧栈帧创建栈帧销毁根据栈帧关系更改值拓展 可变参数列表基本原理整形提升 命令行参数打印环境变量 函数栈帧 int MyAdd(int a, int b) {int c 0;c a b;return c; } int main() {int x 0xA;int y 0xB;int z MyAdd(x,y);system("pause");return …

怎么隐藏回收站?3个方法轻松隐藏回收站!

案例&#xff1a;怎么隐藏回收站 【我不太想把回收站放到桌面上&#xff0c;想把它隐藏了&#xff0c;请问大家有什么好的方法可以隐藏回收站吗&#xff1f;】 回收站是一个非常常见的功能&#xff0c;允许用户恢复已删除的文件。然而&#xff0c;有些人可能不希望回收站一直…

SpringMVC高手进阶

&#x1f648;作者简介&#xff1a;练习时长两年半的Java up主 &#x1f649;个人主页&#xff1a;程序员老茶 &#x1f64a; ps:点赞&#x1f44d;是免费的&#xff0c;却可以让写博客的作者开兴好久好久&#x1f60e; &#x1f4da;系列专栏&#xff1a;Java全栈&#xff0c;…

【MySQL】-- 数据库基础

目录 MySQL概述 MySQL初期概念 小结 主流数据库 连接服务器 服务器&#xff0c;数据库&#xff0c;表关系 数据逻辑存储 MySQL架构 SQL分类 存储引擎 存储引擎 查看存储引擎 MySQL概述 #问&#xff1a;什么是数据库&#xff1f; MySQL初期概念 这个所谓的mysql严格…