【国产之光】开年尝鲜——优秀的AI编码助手 Fitten Code

文章目录

  • 前言
  • 1. 工具准备
    • 1.0 事先说明
    • 1.1 VSCode
    • 1.2 Fitten Code
    • 1.3 GitHub Copilot
  • 2. 使用测评
    • 2.1 需求理解
    • 2.2 上下文理解
  • 3. 总结
  • 推荐链接

开年尝鲜高质量国产AI编码助手——FittenCode

前言

2024年刚刚开局,清华大学 与 非十科技 就发布了全新的 VSCode AI 编码助手—— FittenCode。 感谢我的大佬同学小金推荐,让我及时收到咨询,第一时间体验FittenCode!

截止至本文发文日期,FittenCode 可在 VSCode 商城下载并免费试用!借此契机,我索性将我自己的Copilot拿出来,与FittenCode做一个使用体验对比。此文就当是用户使用测评了!

由于我本人只是渣渣 Java 开发,并不懂很多AI知识,目前工作与生活中对AI仅略懂皮毛,日常仅使用AI而并无细致研究,因此本文只讨论如何使用FittenCode及Copilot,并不深入探究其原理。

当然了,还得事先说明,由于个人非专业测评工程师,样本有限,测评结果仅代表个人观点,轻喷。建议读者将本文当作单纯的“Fitten Code的使用”参考文章。

工具

  • VSCode 1.84 以上
  • GitHub Copilot
  • 一个项目或一段代码

由于本人目前 是 Java 方向, 本文就用Java 演示啦。

测评维度

  • 同一需求场景下,对同一个需求注释生成的代码对比
  • 同一代码注释,对上下文的理解生成的代码对比

1. 工具准备

这一小节,介绍如何准备相关工具,包括:下载对应 VSCode 版本,FittenCode 插件下载,注册;Copilot 购买;

1.0 事先说明

我们在使用FittenCode前,由上文提到的小金大佬指导,需要事先了解FittenCode现阶段如下几点:

  • 目前仅支持 VSCode 插件
  • VSCode 版本需要在 1.84 以上
  • 目前免费试用,以后是否收费,要看开发商非十科技的战略

1.1 VSCode

首先我们下载 VSCode,并配置所需的基础环境:

下载安装及配置
下载地址:
VSCode下载地址
https://code.visualstudio.com/download

安装完成后,插件下载、程序运行测试参考文章:
腾讯云社区-VSCode配置JAVA环境参考文章

VSCode 所需Java测试插件
1

2

这里我个人使用的是免安装解压版,除了要注意VsCode默认的插件安装位置是C:\用户\当前用户.vscode\extensions这一点外,其它基本是可插拔,开箱即用(手动狗头[doge]),不需要额外太多配置,除非有一些特别的需求要配置环境等。

1.2 Fitten Code

下载并注册FittenCode
1

2

注册完马上可以使用!

1.3 GitHub Copilot

开通GirHub Copilot

  • CSDN-GitHubCopilot优秀参考文章

2. 使用测评

以下基于同一段代码,分别使用 FittenCode 与 GitHub Copilot,体验能力区别。

2.1 需求理解

代码准备
准备一个main方法。一个测试类,用于验证代码是否正确。

需求
以下是一个顺序表

package cn.sharry.structure.linearlist;import cn.sharry.structure.util.GenericTypeChangeUtil;import java.util.Arrays;
import java.util.List;
import java.util.Objects;/*** 顺序表的实现* @author Sharry* @since 2023/9/16*/
public class SequenceTable<T> implements ISequenceTable<T> {/*** init length : 0*/public final int INIT_LENGTH = 0;/*** hash code constant*/public final int HASH_TIMES = 31;/*** array to store sequence data*/private Object [] elements;/*** this sequence table's length*/private int length;public SequenceTable(T[] elements) {this.elements = elements;this.length = elements.length;}public SequenceTable(int length) {this.elements = new Object[length];this.length = length;}public SequenceTable() {this.elements = new Object[INIT_LENGTH];this.length = INIT_LENGTH;}public SequenceTable(T[] elements, int length) {if(length < elements.length){throw new ArrayIndexOutOfBoundsException();}this.elements = elements;this.length = length;}public Object[] getElements() {return elements;}public void setElements(Object[] elements) {this.elements = elements;this.length = elements.length;}public int getLength() {return length;}public void setLength(int length) {this.length = length;}@Overridepublic boolean equals(Object o) {if (this == o) {return true;}if (!(o instanceof SequenceTable)) {return false;}SequenceTable<?> that = (SequenceTable<?>) o;return getLength() == that.getLength() && Arrays.equals(getElements(), that.getElements());}@Overridepublic int hashCode() {int result = Objects.hash(getLength());result =HASH_TIMES * result + Arrays.hashCode(getElements());return result;}@Overridepublic String toString() {return "SequenceTable{" +"elements=" + Arrays.toString(elements) +", length=" + length +'}';}@Overridepublic boolean isEmpty() {if (elements.length == 0){return this.getLength() == INIT_LENGTH || this.getElements() == null;}for (Object element : elements) {if (null != element) {return false;}}return true;}@Overridepublic int size() {return getLength();}@Overridepublic T get(int i) {if(i < INIT_LENGTH || i > length-1){throw new ArrayIndexOutOfBoundsException();}return GenericTypeChangeUtil.typeConversion(getElements()[i], getElements()[i].getClass());}@Overridepublic boolean set(int i, T x) {if(isOutOfBounds(i)){throw new ArrayIndexOutOfBoundsException();}Object[] eArr = getElements();Object e = getElements()[i];if ( e == null || !e.equals(x)) {eArr[i] = x;setElements(eArr);return true;}return false;}@Overridepublic int insert(int i, T x) {if(isOutOfBounds(i)){throw new ArrayIndexOutOfBoundsException();}Object[] resource = getElements();Object[] target = new Object[this.length+1];if(i == 0){System.arraycopy(resource,0,target,i+1,resource.length);target[i] = x;}else{System.arraycopy(resource,0,target,0,i);target[i] = x;System.arraycopy(resource,i,target,i+1,resource.length-i);}setElements(target);return i;}@Overridepublic int insert(T x) {return insert(length-1,x);}@Overridepublic T remove(int i) {if(isOutOfBounds(i)){throw new ArrayIndexOutOfBoundsException();}Object e = getElements()[i];Object[] eArr = getElements();eArr[i] = null;setElements(eArr);return GenericTypeChangeUtil.typeConversion(e,e.getClass());}@Overridepublic int search(T key) {Object[] eArr = getElements();for (int i = 0 ; i < eArr.length ; i++){boolean ifNull = eArr[i] != null && eArr[i] == key;if(ifNull || Objects.equals(eArr[i], key)){return i;}}return -1;}@Overridepublic boolean contains(T key) {return search(key) != -1;}@Overridepublic int insertDifferent(T x) {if(contains(x)){return -1;}insert(x);return length-1;}@Overridepublic T remove(T key) {T element;if (!contains(key)) {return null;} else {element = GenericTypeChangeUtil.typeConversion(getElements()[search(key)],getElements()[search(key)].getClass());set(search(key), null);}return GenericTypeChangeUtil.typeConversion(element,element.getClass());}@Override@SuppressWarnings("unchecked")public boolean addAll(List<T> list) {if (list == null || list.size() == 0){return false;}Object[] source = getElements();Object [] tar = new Object[this.getLength() + list.size()];int tarLength = tar.length;if (this.length >= 0) {System.arraycopy(source, 0, tar, 0, this.length);}for(int i = this.length-1; i < tarLength; i++){tar[i] = list.get(tarLength-i);}SequenceTable<T> ns = new SequenceTable<T>((T[])tar,tarLength);setElements(ns.getElements());setLength(ns.length);return true;}private boolean isOutOfBounds(int i) {return i < INIT_LENGTH || i > length - 1;}}
  • 对该顺序表进行代码优化,尽可能简洁

GitHub Copilot
3

显然,稍微复杂的一些代码Copilot并不能理解其意思。这种情况,不如暂时关一下Copilot。

Fitten Code
4

像模像样,对上述代码

@Override@SuppressWarnings("unchecked")public boolean addAll(List<T> list) {if (list == null || list.size() == 0){return false;}Object[] source = getElements();Object [] tar = new Object[this.getLength() + list.size()];int tarLength = tar.length;if (this.length >= 0) {System.arraycopy(source, 0, tar, 0, this.length);}for(int i = this.length-1; i < tarLength; i++){tar[i] = list.get(tarLength-i);}SequenceTable<T> ns = new SequenceTable<T>((T[])tar,tarLength);setElements(ns.getElements());setLength(ns.length);return true;}

这一段进行了重写,看起来比Copilot更靠谱些,甚至看起来确实优化了点代码。

因此,这一part,仅此需求的测试,Fitten Code 胜。

至于更多的测试,篇幅有限,请读者自行发掘啦。

2.2 上下文理解

测试需求

  • 在中间插入一段,该线性表参数进行希尔排序

GitHub Copilot
5

Fitten Code
6

上图结果不相上下,其中Fitten Code生的甚至多了一些,略不符合题意,看起来是忘了上文的内容了。这一part 算是GitHub Copilot小优吧!

至于更多的测试,请读者自行发掘咯。

3. 总结

经过本次测试,我个人对 Fitten Code 插件 与 GitHub Copilot 的比较,体验结果:

Fitten Code 优缺点:
优点

  • 免费
  • 某些业务,理解比GitHub Copilot好一些
  • 更新,更年轻

缺点

  • 目前仅VSCode 1.84 以上版本能用。其它工具和平台里不能用,对于不常用VSCode开发的程序猿不友好。
  • 目前一天一个版本,几乎每天上号第一天就要点击更新,略显麻烦

GitHub Copilot 优缺点:
优点

  • 多个工具里均可使用
  • 重复性代码,生成能力很强,减少程序猿重复性工作
  • 有GitHub数据投喂,可获得非常多开源方案参考

缺点

  • 贵,学生包申请有条件限制
  • 有时略显笨拙,生成的不是咱想要的,还不如停掉

好啦,个人对这两个AI编码助手的体验测评大概就是这些啦,若您是VSCode忠实用户,恭喜您,有 GitHub Copilot 的平替方案啦,甚至说,对某些代码的理解更胜一筹。 当然,这里也忠心祝愿国产AI助手能更上一层楼,早日让国人用上性价比更高的国产AI助手

推荐链接

  • VS插件商城
  • 非十科技
  • VSCode下载地址
  • 腾讯云社区-VSCode配置JAVA环境参考文章
  • CSDN-GitHubCopilot优秀参考文章

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

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

相关文章

并发编程(十)

带有Scheduled的基本都是定时器 Executor框架的成员 &#xff08;1&#xff09;ThreadPoolExecutor ThreadPoolExecutor通常使用工厂类Executors来创建。Executors可以创建3种类型的ThreadPoolExecutor&#xff1a;SingleThreadExecutor、FixedThreadPool和CachedThreadPool…

2024软件测试该如何发展?测试员怎样在内卷中走出来?

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 1、行业现状 目前…

2024.1.22

今天主要是写了一个项目——通讯录&#xff0c;然后做了一下学校的C语言的期末复习题&#xff0c;已经开始准备C的期末了。通讯录目前是我写过最长的代码&#xff0c;但其实实现不是最复杂的&#xff0c;是因为我为了让用户友好&#xff0c;所以说加了一些很多重复的代码&#…

MySQL 8.0中新增的功能(九)

FROM_UNIXTIME()、UNIX_TIMESTAMP()和CONVERT_TZ()的64位支持 根据MySQL 8.0.28版本的更新&#xff0c;FROM_UNIXTIME()、UNIX_TIMESTAMP() 和 CONVERT_TZ() 函数现在在支持64位的平台上处理64位值。这包括64位版本的Linux、MacOS和Windows。在兼容的平台上&#xff0c;UNIX_T…

Java并发Condition 详解

1.引言 在Java并发编程中&#xff0c;线程间的协作是一个核心话题。为了实现线程间的协作&#xff0c;Java提供了多种机制&#xff0c;其中等待/通知机制是最常见的一种。在早期版本中&#xff0c;我们通过Object类提供的wait、notify和notifyAll方法来实现这种机制。然而&…

前端规范扩展

前端编程规范是基于原有vue2基础上那套《编码风格及标准》上&#xff0c;应用于vue3、typescript、vite2基础上延伸出来的扩展补充&#xff0c;持续完善 一、编码规范 ESLint 代码检测工具 Pretter 代码格式化工具配合双校验代码 Git 规范 - 编码工具 vscode 同步参考文档中…

kylin集群使用nginx反向代理

前文已经提到&#xff0c;我安装了kylin集群。 kylin3集群问题和思考&#xff08;单机转集群&#xff09;-CSDN博客文章浏览阅读151次&#xff0c;点赞3次&#xff0c;收藏6次。由于是同一个集群的&#xff0c;元数据没有变化&#xff0c;所以&#xff0c;直接将原本的kylin使用…

基础篇_开发命令行程序(输入输出,类型、变量、运算符,条件语句,循环语句,方法,package与jar)

文章目录 一. 输入输出1. System.out2. System.in3. Scanner4. 变量名5. 关键字 二. 类型、变量、运算符1. 字符与字符串字符值与字符串值转义字符文本块 2. 类型何为类型数字类型字符类型 3. 变量与运算符变量运算符 4. 练习 - 房贷计算器Math.pow()数字格式化查阅 Javadoc 三…

什么是云服务器CVM?

腾讯云服务器CVM提供安全可靠的弹性计算服务&#xff0c;腾讯云明星级云服务器&#xff0c;弹性计算实时扩展或缩减计算资源&#xff0c;支持包年包月、按量计费和竞价实例计费模式&#xff0c;CVM提供多种CPU、内存、硬盘和带宽可以灵活调整的实例规格&#xff0c;提供9个9的数…

MySQL 图书管理系统

1.需求分析 1.1项目需求分析简介 1.1.1信息需求分析 (1) 图书信息&#xff1a;包括书籍编号&#xff0c;书籍名称&#xff0c;出版社&#xff0c;作者&#xff0c;库存量&#xff0c;出版日期&#xff0c;价格&#xff0c;库存&#xff0c;剩余量&#xff0c;类别等&#xf…

rhel 9 mysql 无法远程访问(linux)

1.防火墙开启3306端口 firewall-cmd --add-port3306/tcp2.防火墙生效 firewall-cmd --runtime-to-permanent3.其他命令(停止和启动防火墙) systemctl stop firewalld systemctl start firewalld4.检查防火墙状态 firewall-cmd --check-config5.查看防火墙开启端口 firewal…

Android Retrofit使用详情

一、 Retrofit是什么 Retrofit是Android用来接口请求的网络框架&#xff0c;内部是基于OkHttp实现的&#xff0c;retrofit负责接口请求的封装&#xff0c;retrofit可以直接将接口数据解析为Bean类、List集合等&#xff0c;直接简化了中间繁琐的数据解析过程 二、 Retrofit的简单…

必须掌握的100+个Linux命令大全【持续更新中】

别有一番风趣的alias … note:: 寒蝉凄切&#xff0c;对长亭晚&#xff0c;骤雨初歇。 柳永《雨霖铃》 Linux alias命令用于设置指令的别名&#xff0c;可以将比较长的命令进行简化。 默认情况下会输出当前的设置&#xff1a; $ alias lls -lah lals -lAh llls -lh lsls --…

C++学习笔记——多态与静态联编和动态联编

目录 一、多态 二、静态联编&#xff08;Static Binding&#xff09;和动态联编&#xff08;Dynamic Binding&#xff09; 2.1静态联编 2.2动态联编 一、多态 是C中面向对象编程的一个核心概念&#xff0c;它允许派生类对象替代其基类对象&#xff0c;从而实现代码重用和扩…

ARM CCA机密计算架构软件栈(下)

三、Realm管理 本节描述软件组件中引入的软件组件如何在Realm的创建和执行期间进行交互。 3.1 资源管理 领域资源管理的基本原则是主机保持控制。这意味着主机决定使用哪个物理内存来支持给定的领域中间物理地址(IPA),或者存储RMM使用的Realm元数据的给定片段。 主机始终…

Pandas实战100例 | 案例 7: 数据分组与聚合 - 使用 `groupby` 进行分析

案例 7: 数据分组与聚合 - 使用 groupby 进行分析 知识点讲解 数据分组和聚合是数据分析中的强大工具&#xff0c;它们使我们能够按照某个或某些特定的列将数据分组&#xff0c;并对每个分组应用聚合函数&#xff0c;以便进行分析。 示例代码 基本分组与聚合 # 按照某列分…

基于昇腾910B搭建多节点K8s集群

自从 2013 年 Docker 诞生以来&#xff0c;容器一跃成为 IT 界最热门的话题。而 Kubernetes 趁着容器的东风&#xff0c;击败众多竞争对手&#xff0c;成为了“容器编排”领域的King。可以说&#xff0c;现在 Kubernetes 已经没有了实际意义上的竞争对手&#xff0c;它的地位就…

代码随想录算法训练营第17天 | 110.平衡二叉树 + 257. 二叉树的所有路径 + 404.左叶子之和

今日内容 110.平衡二叉树 257. 二叉树的所有路径 404.左叶子之和 110.平衡二叉树 - Easy 题目链接&#xff1a;. - 力扣&#xff08;LeetCode&#xff09; 给定一个二叉树&#xff0c;判断它是否是高度平衡的二叉树。 本题中&#xff0c;一棵高度平衡二叉树定义为&#xff1…

springboot注解@PropertySource作用

简介 PropertySource 是 Spring 框架中的一个注解&#xff0c;用于指定一个或多个属性文件&#xff08;通常是.properties文件&#xff09;这些文件包含了应用程序需要的配置信息。当你在 Spring 的配置类中使用此注解时&#xff0c;Spring 容器会加载这些属性文件&#xff0c…

01.坦克大战项目-Java绘图坐标体系

01.坦克大战项目- Java绘图 01. Java绘图坐标体系 1. 坐标体系介绍 ​ 下图说明了java坐标系。坐标原点位于左上角&#xff0c;以像素为单位。在Java坐标系中&#xff0c;第一个是x坐标系&#xff0c;表示当前位置为水平方向&#xff0c;距离坐标原点x个像素&#xff1b;第二…