发布时间:2025-06-24 19:37:50  作者:北方职教升学中心  阅读量:269


其它工具和平台里不能用,对于不常用VSCode开发的程序猿不友好。

1.2 Fitten Code

下载并注册FittenCode
1

2

注册完马上可以使用!

1.3 GitHub Copilot

开通GirHub Copilot

  • CSDN-GitHubCopilot优秀参考文章

2. 使用测评

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

3. 总结

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

Fitten Code 优缺点:
优点

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

缺点

  • 目前仅VSCode 1.84 以上版本能用。程序运行测试参考文章:
    腾讯云社区-VSCode配置JAVA环境参考文章

    VSCode 所需Java测试插件
    1

    2

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

    2.2 上下文理解

    测试需求

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

    GitHub Copilot
    5

    Fitten Code
    6

    上图结果不相上下,其中Fitten Code生的甚至多了一些,略不符合题意,看起来是忘了上文的内容了。

    至于更多的测试,篇幅有限,请读者自行发掘啦。建议读者将本文当作单纯的“Fitten Code的使用”参考文章。

    2.1 需求理解

    代码准备
    准备一个main方法。 当然,这里也忠心祝愿国产AI助手能更上一层楼,早日让国人用上性价比更高的国产AI助手

    推荐链接

    • VS插件商城
    • 非十科技
    • VSCode下载地址
    • 腾讯云社区-VSCode配置JAVA环境参考文章
    • CSDN-GitHubCopilot优秀参考文章
这一part 算是GitHub Copilot小优吧!

至于更多的测试,请读者自行发掘咯。此文就当是用户使用测评了!

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

因此,这一part,仅此需求的测试,Fitten Code 胜。 感谢我的大佬同学小金推荐,让我及时收到咨询,第一时间体验FittenCode!

截止至本文发文日期,FittenCode 可在 VSCode 商城下载并免费试用!借此契机,我索性将我自己的Copilot拿出来,与FittenCode做一个使用体验对比。一个测试类,用于验证代码是否正确。

Fitten Code
4

像模像样,对上述代码

@Override@SuppressWarnings("unchecked")publicbooleanaddAll(List<T>list){if(list ==null||list.size()==0){returnfalse;}Object[]source =getElements();Object[]tar =newObject[this.getLength()+list.size()];inttarLength =tar.length;if(this.length >=0){System.arraycopy(source,0,tar,0,this.length);}for(inti =this.length-1;i <tarLength;i++){tar[i]=list.get(tarLength-i);}SequenceTable<T>ns =newSequenceTable<T>((T[])tar,tarLength);setElements(ns.getElements());setLength(ns.length);returntrue;}

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

  • 目前一天一个版本,几乎每天上号第一天就要点击更新,略显麻烦
  • GitHub Copilot 优缺点:
    优点

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

    缺点

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

    好啦,个人对这两个AI编码助手的体验测评大概就是这些啦,若您是VSCode忠实用户,恭喜您,有 GitHub Copilot 的平替方案啦,甚至说,对某些代码的理解更胜一筹。

    当然了,还得事先说明,由于个人非专业测评工程师,样本有限,测评结果仅代表个人观点,轻喷。

    需求
    以下是一个顺序表

    packagecn.sharry.structure.linearlist;importcn.sharry.structure.util.GenericTypeChangeUtil;importjava.util.Arrays;importjava.util.List;importjava.util.Objects;/** * 顺序表的实现 * @author Sharry * @since 2023/9/16 */publicclassSequenceTable<T>implementsISequenceTable<T>{/**     * init length : 0     */publicfinalintINIT_LENGTH=0;/**     * hash code constant     */publicfinalintHASH_TIMES=31;/**     * array to store sequence data     */privateObject[]elements;/**     * this sequence table's length     */privateintlength;publicSequenceTable(T[]elements){this.elements =elements;this.length =elements.length;}publicSequenceTable(intlength){this.elements =newObject[length];this.length =length;}publicSequenceTable(){this.elements =newObject[INIT_LENGTH];this.length =INIT_LENGTH;}publicSequenceTable(T[]elements,intlength){if(length <elements.length){thrownewArrayIndexOutOfBoundsException();}this.elements =elements;this.length =length;}publicObject[]getElements(){returnelements;}publicvoidsetElements(Object[]elements){this.elements =elements;this.length =elements.length;}publicintgetLength(){returnlength;}publicvoidsetLength(intlength){this.length =length;}@Overridepublicbooleanequals(Objecto){if(this==o){returntrue;}if(!(o instanceofSequenceTable)){returnfalse;}SequenceTable<?>that =(SequenceTable<?>)o;returngetLength()==that.getLength()&&Arrays.equals(getElements(),that.getElements());}@OverridepublicinthashCode(){intresult =Objects.hash(getLength());result =HASH_TIMES*result +Arrays.hashCode(getElements());returnresult;}@OverridepublicStringtoString(){return"SequenceTable{"+"elements="+Arrays.toString(elements)+", length="+length +'}';}@OverridepublicbooleanisEmpty(){if(elements.length ==0){returnthis.getLength()==INIT_LENGTH||this.getElements()==null;}for(Objectelement :elements){if(null!=element){returnfalse;}}returntrue;}@Overridepublicintsize(){returngetLength();}@OverridepublicTget(inti){if(i <INIT_LENGTH||i >length-1){thrownewArrayIndexOutOfBoundsException();}returnGenericTypeChangeUtil.typeConversion(getElements()[i],getElements()[i].getClass());}@Overridepublicbooleanset(inti,Tx){if(isOutOfBounds(i)){thrownewArrayIndexOutOfBoundsException();}Object[]eArr =getElements();Objecte =getElements()[i];if(e ==null||!e.equals(x)){eArr[i]=x;setElements(eArr);returntrue;}returnfalse;}@Overridepublicintinsert(inti,Tx){if(isOutOfBounds(i)){thrownewArrayIndexOutOfBoundsException();}Object[]resource =getElements();Object[]target =newObject[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);returni;}@Overridepublicintinsert(Tx){returninsert(length-1,x);}@OverridepublicTremove(inti){if(isOutOfBounds(i)){thrownewArrayIndexOutOfBoundsException();}Objecte =getElements()[i];Object[]eArr =getElements();eArr[i]=null;setElements(eArr);returnGenericTypeChangeUtil.typeConversion(e,e.getClass());}@Overridepublicintsearch(Tkey){Object[]eArr =getElements();for(inti =0;i <eArr.length ;i++){booleanifNull =eArr[i]!=null&&eArr[i]==key;if(ifNull ||Objects.equals(eArr[i],key)){returni;}}return-1;}@Overridepublicbooleancontains(Tkey){returnsearch(key)!=-1;}@OverridepublicintinsertDifferent(Tx){if(contains(x)){return-1;}insert(x);returnlength-1;}@OverridepublicTremove(Tkey){Telement;if(!contains(key)){returnnull;}else{element =GenericTypeChangeUtil.typeConversion(getElements()[search(key)],getElements()[search(key)].getClass());set(search(key),null);}returnGenericTypeChangeUtil.typeConversion(element,element.getClass());}@Override@SuppressWarnings("unchecked")publicbooleanaddAll(List<T>list){if(list ==null||list.size()==0){returnfalse;}Object[]source =getElements();Object[]tar =newObject[this.getLength()+list.size()];inttarLength =tar.length;if(this.length >=0){System.arraycopy(source,0,tar,0,this.length);}for(inti =this.length-1;i <tarLength;i++){tar[i]=list.get(tarLength-i);}SequenceTable<T>ns =newSequenceTable<T>((T[])tar,tarLength);setElements(ns.getElements());setLength(ns.length);returntrue;}privatebooleanisOutOfBounds(inti){returni <INIT_LENGTH||i >length -1;}}
    • 对该顺序表进行代码优化,尽可能简洁

    GitHub Copilot
    3

    显然,稍微复杂的一些代码Copilot并不能理解其意思。

    工具

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

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

    文章目录

    • 前言
    • 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。

    测评维度

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

    1. 工具准备

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

    1.0 事先说明

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

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

    1.1 VSCode

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

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

    安装完成后,插件下载、