我承担了一项相当具有挑战性的任务。也就是说,将一些丑陋的企业 C# 代码转换为 Python。在深入研究之前,我觉得我需要做一些解释。
这个 C# 项目充当某些机器学习模型的数据管道层。听到数据,你首先想到的应该是Python。不幸的是,情况并非如此,为了使它更好,它使用了 Apache Spark 的 .NET 扩展。将其迁移到 Python 是有道理的,因为它使用相当非标准的技术来解决问题,这使得招聘未来的人才相当困难。还有其他明显的问题,在其他企业 OOP 语言中也很常见,例如多层抽象、无处不在的继承、控制反转,以及您在数据管道中不做的事情。为了进一步助长魔鬼,原来的承包商/顾问团队(因为除了一些企业顾问之外,还有谁会使用 C#)将于下个月离开。
顺便说一句,我使用 Neovim,自从我拿到预览版本以来,我已经使用 Github Copilot 近两年了,还有 Copilot Chat(技术上是 ChatGPT),所以我绝不是一个完全的新手,当它涉及法学硕士和代码。
使用 Claude 3.5 编写代码感觉如何,有好的、坏的和丑陋的部分。但大多数情况下,即使您能够从头开始编写相同的功能,您也不知道发生了什么。
Claude 3.5 往往会产生令人惊讶的正确结果,但是,有时它会尝试变得聪明,但会失败,但您可以指导它解决问题。总的来说,它是提问的好伙伴,对我来说,因为我有严格的工作流程,而且我确实付出了很多努力来制作带有大量示例和边缘情况的复杂提示,所以我非常满意。我可以学习 C# 课程并将重要部分翻译成 Python,只需要很少的额外指令。
我通常可以写 12 个小时的代码,偶尔上厕所,补充我的水壶。是的,当我真正投入其中时,我不会感到饥饿。和克劳德在一起时,我确实进入了心流状态,但大约三个小时后,我感觉死了。在这 3 小时内,我确实生成了很多代码,而且我感觉很有成效,但这就像不停地进行代码审查、要求更改,而且大多数情况下,如果生成的内容有效,则不会查找文档。
如果您是一名编码员,您可能在某种程度上熟悉您编写的代码。这种熟悉感往往会随着时间的推移而消失,但如果您在代码库上工作了足够长的时间,您就会熟悉周围的情况。使用 LLM 生成的代码,这种情况就不会发生。我对发生的事情知之甚少。几天来,我确实编写了很多代码,审查了每一行,时不时地要求进行一些更改,但最终我几乎不知道到底发生了什么。最后,代码库感觉就像一个陌生人,不是我写的。更糟糕的是,实际的代码风格不一致,你可以告诉appart哪些文件是同一天写的,感觉像是不同的人写的。
我花了很多时间来审查、重新设计、调整这个完整的 LLM 编码方法,但是大多数时候的结果只是代码,这在某种程度上有效,但你不知道为什么或如何。最大的问题是:
最终得到一个你几乎没有依恋的代码库是否值得,它立即感觉就像你一年前与一次想象中的同事一起写的。
总而言之,我确实觉得我生成了更多代码,但质量比平常低。在某些情况下,这种较低的质量是合理的,特别是如果您不在乎的话。但我担心的是,时间即将到来,每个代码库都将在创纪录的时间内成为“遗产”。
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3