当前位置: 首页 > article >正文

CS146S课程解析:LLM上限就是开发者的上限

第 6 周AI 测试与安全安全编码在 AI 时代变得更加重要。本周覆盖 SAST、DAST、漏洞检测、AI 生成的测试用例以及如何用 Semgrep 等工具进行安全扫描。第 7 周现代软件支持AI 代码审查、智能文档生成、调试辅助。如何建立对 AI 生成代码的信任如何设置 Code Review 流程来捕捉 AI 的错误和Hallucination第 8 周自动化 UI 构建用一个 Prompt 生成完整的 Web App。快速原型、设计普惠化、端到端应用构建。第 9 周部署后的 Agent监控、可观测性、自动化事件响应。当 AI 参与到 DevOps 流程中会发生什么第 10 周AI 软件工程的未来软件开发者的角色将如何演变十年后的开发会是什么样子三、硅谷顶级嘉宾阵容这门课的另一个亮点是每周五的嘉宾分享。这些嘉宾不是学术界的教授而是正在定义 AI 开发工具未来的实践者Boris Cherney (Anthropic) — Claude Code 的创造者分享 AI 编程助手的幕后设计哲学Silas Alberti (Cognition) — Devin首个 AI 软件技术人背后公司的研究主管Zach Lloyd (Warp) — AI 终端的产品逻辑和创业经验Isaac Evans (Semgrep) — AI 时代的安全陷阱与应对策略Tomas Reimers (Graphite) — 代码审查自动化的前沿实践Gaspar Garcia (Vercel) — 一键构建应用的技术架构Mayank Agarwal Milind Ganjoo (Resolve) — 部署后 AI 运维的实战经验Martin Casado (a16z) — 投资视角下的 AI 工程未来能在一门课里听到这些正在塑造行业未来的人的第一手分享这本身就是斯坦福的独特资源。四、实战作业与开源资源课程的所有作业都开源在 GitHub 上任何人都可以自学作业仓库https://github.com/mihail911/modern-software-dev-assignments八周的实战作业覆盖Week 1: LLM Prompting PlaygroundWeek 2: First Steps in the AI IDEWeek 3: Build a Custom MCP ServerWeek 4: Coding with Claude CodeWeek 5: Agentic Development with WarpWeek 6: Writing Secure AI CodeWeek 7: Code Review RepsWeek 8: Multi-stack Web App Builds每个作业都基于真实的 AI 工具——Claude Code、Warp、Semgrep、Graphite——而不是玩具项目。课程主页https://themodernsoftware.dev这里有课程大纲、每周的 SlidesGoogle Slides 格式、以及嘉宾演讲的资料。2025 年秋季斯坦福计算机系出现了一门排课火爆的新课 —— CS146S: The Modern Software Developer现代软件开发者。这门课由 Mihail Eric 主讲他是斯坦福校友曾在 Amazon Alexa 担任技术主管创办过 YC 孵化的 AI 编程公司如今重返母校开设了斯坦福历史上第一门专注于 AI 软件开发的课程。课程从 9 月 22 日开始为期十周每周两次课。当大多数高校还在争论是否该禁止学生使用 AI 工具时这门课的态度截然相反——全面拥抱 AI。正如 Mihail Eric 在课堂上所说如果你能不写一行代码就完成整门课那更好。一、这门课独特在哪里传统的软件工程课教你如何写代码、如何设计系统、如何测试。CS146S 则教你一件完全不同的事如何成为 AI Agent 的管理者。课程开篇就提出了一个关键理念Human-agent engineering, not vibe coding. 人机协作工程而非氛围式编程什么意思纯粹靠感觉让 AI 生成代码所谓 vibe coding并不能产出生产级软件。真正的现代开发者需要学会像管理一群热情但稚嫩的 AI 实习候选人一样给它们提供清晰的上下文、明确的指令、合理的架构。另一个洞见同样犀利LLMs are only as good as you are. LLM 的上限就是你的上限如果有人说AI 在我的代码库上不好用通常意味着即便是一个人类新手进入这个代码库也会一头雾水。问题不在 AI在于代码本身缺乏清晰的结构和上下文。这种思维方式的转变正是这门课最独特的地方——它不是在教工具而是在教新时代的工作方式。二、十周课程从原理到实战课程设计覆盖了 AI 辅助开发的完整生命周期。以下是每周的关键主题第 1-2 周LLM 基础与 Agent 架构从 LLM 的工作原理讲起深入 Prompt Engineering 的实战技巧然后进入 Agent 架构的关键概念——工具调用、函数调用、Model Context Protocol (MCP)。第二周的作业是从零构建一个 Coding Agent并搭建自定义的 MCP Server。第 3-4 周AI IDE 与 Agent 管理探讨上下文管理的艺术如何让 AI 理解你的项目如何写好 PRD产品需求文档让 Agent 高效执行如何设置 AI 原生的开发环境第四周的重点是Agent 管理——如何在人机协作中找到平衡点既不过度依赖也不完全不信任。第 5 周现代终端AI 增强的命令行工具正在改变终端体验。本周深入 Warp 等工具学习终端自动化和 CLI 增强。开篇实战准备30分钟搞定环境1. 环境要求极简版Python 3.10 或 3.11推荐AnacondaVS Code 编辑器安装Python扩展一个OpenAI账号或国内通义千问、豆包等后面代码可一键切换2. 一键安装工具打开终端复制粘贴运行pip install openai1.35.0 streamlit1.38.0 gradio4.44.0 python-dotenv requests3. API申请2分钟打开 https://platform.openai.com/api-keys创建新Key复制保存到项目根目录新建的.env文件里OPENAI_API_KEYsk-你的key在这里4. 项目文件夹结构直接复制ai_systems/ ├── .env ├── requirements.txt ├── qa_assistant.py # 项目1 ├── copy_generator.py # 项目2 ├── chatbot.py # 项目3 └── utils.py # 公共工具把上面requirements.txt内容写成openai1.35.0 streamlit1.38.0 gradio4.44.0 python-dotenv环境搞定下面我们直接上手项目。为方便大家学习 这里给大家整理了一份详细的学习资料包 需要的同学 可以根据图片指示自取极简原理速通只讲项目必需的3个逻辑Prompt就是指令大模型像一个超级听话的助手你把需求写得越清晰它输出越准。核心模板角色 任务 格式 示例。API调用三步加载key → 创建client → 调用chat.completions.createtemperature0.7控制创意度。UI交互用Streamlit一行代码就能出网页st.text_input st.button st.chat_message零前端知识也能做。记住这三点就够了下面直接开干

相关文章:

CS146S课程解析:LLM上限就是开发者的上限

第 6 周:AI 测试与安全 安全编码在 AI 时代变得更加重要。本周覆盖 SAST、DAST、漏洞检测、AI 生成的测试用例,以及如何用 Semgrep 等工具进行安全扫描。 第 7 周:现代软件支持 AI 代码审查、智能文档生成、调试辅助。如何建立对 AI 生成代码…...

RobotStudio避坑指南:ScreenMaker自定义界面常见6大报错解决(基于ABB 6.0+)

RobotStudio避坑实战:ScreenMaker自定义界面开发全链路解决方案 在工业机器人自动化领域,ABB的RobotStudio平台已成为工程师们不可或缺的开发工具。特别是其内置的ScreenMaker模块,让非专业程序员也能快速构建FlexPendant示教器的自定义操作界…...

从冯·诺伊曼到杨振宁:那些改变世界的科学家们,他们的故事与精神遗产

从冯诺伊曼到杨振宁:科学巨匠的精神图谱与当代启示 在人类文明的长河中,科学家的思想火花如同璀璨星辰,照亮了认知的边界。当我们回望二十世纪的科学版图,会发现一个令人惊叹的现象:那些真正改变世界的科学突破&#x…...

Android离屏渲染:从原理到性能优化的全景解析

1. 什么是Android离屏渲染? 离屏渲染(Offscreen Rendering)是图形处理中的一个重要概念。简单来说,当系统无法直接在屏幕上绘制某些复杂视觉效果时,会先在内存中创建一个临时缓冲区进行绘制,然后再将这个缓…...

别再让电机白费电了!手把手教你用MTPA算法在STM32上实现节能控制(附代码)

电机节能控制实战:基于STM32的MTPA算法实现与优化 电机控制系统中的能耗问题一直是工业应用中的痛点。传统控制方法往往忽视了电机内部磁阻转矩的潜力,导致电流利用率低下。本文将带你深入理解MTPA(最大转矩电流比)算法的核心思想…...

告别手写脚本!用Frida-Trace自动Hook Android App的Java方法(附实战Demo)

告别手写脚本!用Frida-Trace自动Hook Android App的Java方法(附实战Demo) 逆向分析Android应用时,手动编写Hook脚本往往耗时费力——尤其是面对未知应用,开发者需要反复尝试类名、方法签名,甚至逐行调试参数…...

如何用STM32CubeMX快速验证你的硬件设计:以UART通信为例

如何用STM32CubeMX快速验证你的硬件设计:以UART通信为例 在嵌入式开发中,硬件验证往往是最耗时且最容易出错的环节之一。想象一下,当你精心设计的电路板终于到手,却发现某个外设无法正常工作,那种挫败感足以让任何开发…...

可计算元认知:工程实现与封装说明——跨领域、跨语言文本对齐的开源工具箱

可计算元认知:工程实现与封装说明——跨领域、跨语言文本对齐的开源工具箱摘要本文系统记录可计算元认知框架的工程实现,提供完整的数据处理流水线、三步语义分析法(垂钓 → 撒网 → 熔炉)的代码实现、跨领域向量对齐的技术细…...

告别Swagger!用Apifox给苍穹外卖项目做接口测试,保姆级图文教程(含Token配置避坑)

从Swagger到Apifox:接口测试工具升级实战指南 在Java Web项目开发中,接口测试是不可或缺的一环。传统上,许多开发者习惯使用Swagger作为接口文档和测试工具,但随着项目复杂度提升,Swagger的局限性逐渐显现:…...

从曝光三要素到图像亮度:深入解析ISP中的AE算法核心

1. 从摄影三要素到数字图像处理 第一次拿起单反相机时,师傅教我的第一课就是"曝光三角":光圈、快门、ISO。这三个参数就像魔法旋钮,转动它们就能让照片变亮或变暗。但当我后来接触手机摄像头开发时,才发现这些物理参数在…...

JMeter实战:从零构建精准压力测试脚本

1. 压力测试入门:从概念到工具选择 第一次接触性能测试任务时,很多人会被各种专业术语搞得晕头转向。我刚入行那会儿也是这样,直到真正动手做了几个项目才明白,压力测试其实就是模拟真实用户对系统"施压"的过程。想象一…...

计算机视觉需要哪些数学基础?如何高效学习线性代数和概率论?|2024新手必看

计算机视觉需要哪些数学基础?如何高效学习线性代数和概率论?|2024新手必看 标签:#计算机视觉、#线性代数、#人工智能、#深度学习、#自然语言处理、#神经网络、#机器学习### 一、痛点引入:为什么很多人怕CV数学&#xf…...

.NET+AI | Agent Skills | File-based Agent Skills 帮你复用成千上万的开源技能

以下内容选自我精心打造的《.NETAI | 智能体开发进阶》课程,如需系统学习,不妨阅读原文了解详情。上一篇我们聊了 Inline Skill。它最大的优点是轻:写得快、调得快、验证也快,非常适合作为 Agent Skills 的第一站。但问题也很明显…...

STM32H743串口DMA+空闲中断实战:从MPU配置到HAL库‘锁’的坑,我都帮你踩完了

STM32H743串口DMA空闲中断实战:从MPU配置到HAL库状态机陷阱全解析 第一次将项目从STM32F407迁移到H743平台时,我遭遇了职业生涯中最诡异的调试经历——CubeMX生成的代码明明逻辑正确,串口却像中了邪一样时好时坏。深夜的实验室里,…...

基于STM32的智能宠物喂食系统设计与实现(完整项目)

基于STM32的智能宠物喂食系统设计与实现摘要针对传统宠物喂食方式繁琐、无法精准控制喂食量与喂食时间、缺乏实时状态监控、远程操控不便,难以满足现代宠物饲养精细化需求的痛点,本文设计一款基于STM32F103C8T6单片机的智能宠物喂食系统。系统以STM32F10…...

矩阵求逆算法的时间复杂度对比:从高斯消元到伴随矩阵法

1. 矩阵求逆:为什么我们需要关注时间复杂度 第一次接触矩阵求逆是在大学线性代数课上,当时只觉得这是个有趣的数学玩具。直到后来做图像处理项目时,我才真正意识到它的重要性——当我们需要解线性方程组或做坐标变换时,逆矩阵就像…...

别再只会sekurlsa::logonpasswords了:mimikatz的dpapi模块实战,解密Chrome密码和Windows凭据

深入探索mimikatz的DPAPI模块:解密Windows凭据与Chrome密码实战指南 在渗透测试和安全研究中,mimikatz早已成为提取Windows系统凭证的标配工具。大多数安全研究人员对sekurlsa::logonpasswords命令耳熟能详,却鲜少深入挖掘其更强大的功能模块…...

别再手搓代码了!用Webots 2023b快速搭建你的第一个机器人仿真环境(附官方Demo实操)

别再手搓代码了!用Webots 2023b快速搭建你的第一个机器人仿真环境(附官方Demo实操) 第一次打开Webots时,那个布满按钮的界面和复杂的场景树确实容易让人望而生畏。但别急着关掉软件——你可能不知道,这个看似复杂的仿真…...

基于STM32的智能家居安防系统设计与实现

1. 为什么选择STM32做智能家居安防系统 第一次接触STM32是在五年前的一个智能门锁项目上,当时就被它的性价比震惊了。相比常见的Arduino,STM32F103系列不仅价格相当(核心板不到20元),还自带12位ADC、多个定时器和USART…...

解决Simulink中S-Function模块缺失问题:以NREL FAST风力发电机模拟为例

1. 当Simulink提示S-Function模块缺失时该怎么办 遇到Simulink报错"S-Function模块不存在"时,很多工程师的第一反应是怀疑模型文件损坏。但根据我处理NREL FAST风力机模拟的经验,90%的情况其实是环境配置问题。就像你买了一台新电脑却打不开游…...

从无人机航拍到手机AR:聊聊相机标定为啥是三维重建的‘地基’

从无人机航拍到手机AR:相机标定如何成为三维重建的隐形支柱 当你用手机AR应用测量家具尺寸时,可曾想过为什么虚拟尺子能精准贴合现实物体?当无人机自动生成建筑三维模型时,又是什么保证了砖墙缝隙的毫米级还原?这些技术…...

扣子(Coze)实战:10万+治愈奶奶图文,Coze一键生成

大家好,我是专注于AI的咕咕姐。最近一股治愈系银发IP的风暴席卷了抖音、小红书、视频号等平台——以温暖笑容的老奶奶为主角的图文和短视频,频频斩获10万点赞,成为现象级流量密码。这类内容通过卡通形象与治愈文案的巧妙融合,精准…...

C语言内存释放:何时需要手动释放内存

c语言为什么要释放内存 释放内存是什么意思 C语言:什么情况下需要释放内存?C管理内存大致可以理解为两种,一种是在堆栈上分配的,另一种是在堆上分配的。临时变量,动态变量,分布在堆栈上,运行时…...

别再死磕NeRF了!从体素到点云,聊聊2024年三维重建的5种主流技术选型与实战避坑

别再死磕NeRF了!从体素到点云,聊聊2024年三维重建的5种主流技术选型与实战避坑 当你在深夜盯着屏幕,反复调整NeRF的视角采样参数却依然无法解决场景边缘模糊问题时;当项目Deadline临近,而体素模型的内存占用已经让显卡…...

从几何视角理解Givens旋转:为什么它能完美解决QR分解?

几何动画拆解Givens旋转:QR分解的视觉化通关指南 想象你手里握着一根倾斜的多节天线,如何通过最简单的旋转操作让它完全竖直?这个看似简单的物理问题,恰恰揭示了Givens旋转在矩阵分解中的核心思想——通过一系列精心设计的平面旋…...

StructBERT开源大模型部署教程:WebUI访问权限控制(Basic Auth)安全加固

StructBERT开源大模型部署教程:WebUI访问权限控制(Basic Auth)安全加固 1. 项目概述与安全需求 StructBERT是一个基于百度开源技术的高精度中文句子相似度计算模型,能够准确判断两个中文句子在语义上的相似程度。这个工具在文本…...

复古CRT界面×流式输出|像素剧本圣殿TextIteratorStreamer实战

复古CRT界面流式输出|像素剧本圣殿TextIteratorStreamer实战 1. 项目概览 像素剧本圣殿(Pixel Script Temple)是一款专为剧本创作者设计的AI辅助工具,基于Qwen2.5-14B-Instruct大模型深度微调开发。这款工具最显著的特点是采用了…...

2026海洋经济产业链图谱全解析:11万亿背后,藏着哪些机会?

海洋经济是指开发、利用和保护海洋的各类产业活动,以及与之相关联的活动的总和。 2026年3月,中商产业研究院发布了《2026年中国海洋经济产业链图谱及投资布局分析报告》。这不是一份学术论文,而是一张清晰的“产业地图”——它把海洋经济拆成…...

Vivado+Vitis双剑合璧:从零构建Zynq-7020的SD卡固化系统(避坑‘导出硬件平台’与‘FSBL’)

Vivado与Vitis协同设计:Zynq-7020 SD卡启动全流程精解 在嵌入式系统开发中,Xilinx Zynq系列SoC因其ARM处理器与FPGA的紧密结合而广受欢迎。然而,从硬件设计到最终系统启动的完整流程中,Vivado与Vitis工具链的协同工作往往成为开发…...

从Cortex-M4寄存器到流水线:手把手拆解ARM微处理器执行一条指令的全过程

从Cortex-M4寄存器到流水线:手把手拆解ARM微处理器执行一条指令的全过程 在嵌入式系统开发中,理解处理器如何执行指令是突破性能瓶颈的关键。当我们面对一个简单的ADD R0, R1, R2汇编指令时,表面上看只是将两个寄存器值相加,但背后…...