idea Ai工具通义灵码,Copilot我的使用方法以及比较

我用过多个idea Ai 编程工具,大约用了1年时间,来体会他们那个好用,以下只是针对我个人的一点分享,不一定对你适用 仅作参考。

介于篇幅原因我觉得能说上好用的 目前只有两个 一个是阿里的通义灵码和Copilot,我用它来干什么,他们官方的定义是 提高开发效率,帮助你节省一些开发时间,说白了就是协助,但是我觉得他们 还有其他用处,我举个例子,我写代码,我让他帮我检查一下有没有问题,或者有没有什么隐藏风险,这个通义灵码 大部分都是 标准化输出 ,但是有一次还真帮我检查出一个问题,因为粗心导致下边是代码 ,对

复制代码
if (SpringContextUtil.existBean(beanCommonServiceName)) 少了一个判断

我让 通义灵码,Copilot 分别给我检查 但是 只有通义灵码检查出来了,Copilot没有检查到。

2,我用它帮我提高代码水平,我平时写完代码之后,会让通义灵码 帮我规范一下,(毕竟阿里系的标准化还是很高的),其次我让Copilot 帮我 用另外一种方式实现一下。

我在工作中遇到一个问题,大体是这样, 有两个json 报文,报文是集合列表,我要对比每一个集合中的数据是否一致,你可以理解为,这两个集合中的报文数据是否每一个参数都一致,不一致的情况下把它展示出来,你可能觉得这有啥难的,但是在实际开发中确实有难度,我无非想到的就是见招拆招,遇到啥问题就 if else,不行就再来一个swich 还不是行 继续if,我把这个问题抛给 Copilot没想到 他给我写了一段代码,类似于排序的 我当时没在意,以为他给错了,后来耐心看下来发现 实现的非常 巧妙我把代码 贴出来你们看下,

复制代码
    private static void test1() {
        List<DscCompareResultDto> files = new ArrayList<>();
        files.add(new DscCompareResultDto("NEW", "dog", "test.txt"));
        files.add(new DscCompareResultDto("OLD", "dog", "test.txt"));

        files.add(new DscCompareResultDto("NEW", "egg", "egg1.pdf"));
        files.add(new DscCompareResultDto("OLD", "egg", "bbb1.pdf"));

        files.add(new DscCompareResultDto("OLD", "lll", "jxd.txt")); //新的

        files.add(new DscCompareResultDto("NEW", "aaaa", "example01.pdf"));
        files.add(new DscCompareResultDto("OLD", "aaaa", "example-1.pdf"));

        files.add(new DscCompareResultDto("OLD", "aaaa", "example.pdf"));
//        List<DscCompareResultDto> inconsistentFiles = findInconsistentFiles(files);


//        for (DscCompareResultDto file : inconsistentFiles) {
//            System.out.println("File Name: " + file.getFileName() + ", class: " + file.getFileClass() + "  " + file.getRule());
//        }

    }
复制代码
public  List<DscCompareResultDto> findInconsistentFiles(List<DscCompareResultDto> files) {
    Map<String, Map<String, List<DscCompareResultDto>>> fileMap = new HashMap<>();

    for (DscCompareResultDto file : files) {
        String fileName = file.getFileName();
        String fileClass = file.getFileClass();

        // 使用文件名作为第一层 key,文件大小作为第二层 key
        fileMap.computeIfAbsent(fileClass, k -> new HashMap<>())
                .computeIfAbsent(fileName, k -> new ArrayList<>())
                .add(file);
    }
    // 收集不一致的文件
    List<DscCompareResultDto> inconsistentFiles = new ArrayList<>();
    for (Map<String, List<DscCompareResultDto>> sizeMap : fileMap.values()) {
        for (List<DscCompareResultDto> fileList : sizeMap.values()) {
            if (fileList.size() == 1) { // 大于一个说明不一致
                inconsistentFiles.addAll(fileList);
            }
        }
    }
    return inconsistentFiles;
}

3.代码书写规范和优雅,我接收一个公司项目,代码是这样的,你看下 map1 map2 ...

这只是冰山一角有的事map 100了

我让通义灵码 做一些重构 这是重构之后的

总结,我会让规范,代码可复用,检查代码有误风险 我 会选择 通义灵码, 比如遇到一些思考方法,或者换一种思路解决问题 我会选择Copilot。希望对你有帮助

相关推荐
T风呤12 分钟前
位深和位宽的区别
图像处理·人工智能·计算机视觉
声网14 分钟前
AI 重塑宗教体验,语音 Agent 能否成为突破点?
人工智能
liruiqiang0530 分钟前
机器学习 - 进一步理解最大似然估计和高斯分布的关系
人工智能·机器学习·概率论
我很好请走开谢谢31 分钟前
大语言模型prompt -Template
人工智能
bylander37 分钟前
【AI学习】LLM的发展方向
人工智能·gpt·学习
North_D39 分钟前
ML.NET库学习005:基于机器学习的客户细分实现与解析
人工智能·深度学习·神经网络·目标检测·机器学习·数据挖掘·mlnet
老六哥_AI助理指南42 分钟前
嵌入式AI革命:DeepSeek开源如何终结GPU霸权,开启单片机智能新时代?
人工智能·单片机·开源
一 铭1 小时前
Onyx(DAnswer)总体实现架构
人工智能·语言模型·大模型·llm
小高Baby@1 小时前
Deepseek
人工智能·笔记
Amarantine、沐风倩✨1 小时前
区块链技术未来发展趋势(人工智能和物联网领域)
人工智能·物联网·区块链