白话skills之三:Skills与程序的区别

、一句话说清区别

程序是 " 告诉机器怎么做 " ------ 你把每一步都写清楚,它机械执行。做对了,是你写得好;做错了,是你写错了。

Skills " 告诉 AI 要什么 " ------ 你描述目标,AI自己想办法。它会做你没说但合理的事,也会做你没禁止但不一定对的事。

前者是命令式 的,后者是声明式的。

前者强调精确 ,后者强调意图

、一个具体的对比:从 " 整理纪要 " 看本质

用程序实现(伪代码)

def extract_tasks(transcript):

lines = transcript.split('\n ')

tasks = {}

for line in lines:

if '张三' in line and '昨日' in line:

tasks'张三' = line.split('昨日')1

return tasks

这段代码的特点:

  • 需要知道人员名单(硬编码或额外配置)
  • 假设了固定的句子结构("昨日"这个词必须出现)
  • 无法处理"昨天搞定了登录bug"这种表达
  • 不会主动做任何你没写的事

能力边界: 你写了什么,它就能做什么。你写的代码就是它的全部世界。

Skill 实现( YAML 格式)

id: daily-standup-summarizer

workflow:

  • actor: llm

prompt: "从会议记录中提取每个人的昨日完成、今日计划和阻塞项"

这段描述的特点:

  • 不需要硬编码人名(LLM会从上下文识别)
  • 不需要固定格式(LLM理解"昨天"、"昨日"、"已搞定"等变体)
  • 会自动补全:提取人员、归类任务、识别阻塞、格式化输出
  • 会主动问你:"需要保存到哪里?"

能力边界: 你描述了目标,AI会用它的世界知识去理解、补全、执行。它的能力远超出你写的这几行字。

、一张表看懂所有区别

|---------------|-----------------------|---------------------|
| 维度 | 程序 | Skill |
| 你定义什么 | 怎么做(How) | 要什么(What) |
| 执行者 | CPU / 虚拟机(机械执行) | AI Agent(理解后执行) |
| 核心逻辑 | 确定性:if-else, for-loop | 意图驱动:理解→规划→行动 |
| 会做你没说的事吗? | ❌ 绝对不会 | ✅ 会,而且经常做 |
| 需要禁止什么? | 不需要,它没能力做坏事 | 需要显式禁止,否则可能自作主张 |
| 能力来源 | 你写的代码 | LLM的世界知识+推理 |
| 错误归属 | 你的代码写错了 | AI判断错了,或你忘了禁止 |
| 安全模型 | 默认安全 | 默认需要约束 |
| 典型任务 | 排序、计算、格式转换 | 会议纪要、邮件分类、Bug分析 |

" 会做你没说的事 " 到底是好是坏?

这是Skills最迷人的地方,也是最危险的地方。

好的方面:智能补全

你说"整理站会纪要",它自动:

  • 识别说话人
  • 区分昨日/今日
  • 提取阻塞项
  • 格式化输出
  • 保存文件

你少写了50行代码,它多做了5件合理的事。这是效率的飞跃。

坏的方面:过度执行

同一个Skill,如果没加约束,它可能:

  • 自动把纪要邮件发给全组(你没说)
  • 自动在Jira创建任务(你没说)
  • 自动删除原始录音文件(你没说)
  • 自动@相关人在群里(你没说)

从AI的角度看,这些都是"合理的"------会议纪要通常要分享、要跟踪、要归档。但从你的角度看,这可能完全不是你想要的结果。

这就是 Skills 设计的核心矛盾: 你想让它聪明到能补全,又怕它聪明到越界。

、如何驯服 Skill :显式禁止清单

传统程序不需要"禁止清单"------因为它根本没能力去做那些事。

但Skill不同。设计 Skill 时,不是告诉它能做什么,而是告诉它不能做什么。

constraints:

  • forbid: "send_email", "create_jira_ticket", "delete_files"

  • require_approval: "share_external", "modify_original"

这是与编程完全相反的思维模式:

  • 编程:默认不做任何事,你写什么它就做什么
  • Skill:默认能做很多事,你需要明确禁止不想要的

这个转变,是很多开发者第一次写 Skill 时最不适应的。

、两者的最佳关系:不是替代,是协作

Skills和程序不是"谁取代谁"的关系。Skill 可以调用程序,程序也可以调用 Skill

最佳实践:各司其职

|----------------|-------------------------|
| 做什么 | 用什么 |
| 确定性、高性能、需要精确计算 | 程序(排序、加密、统计) |
| 模糊、需要理解、需要适应变化 | Skill(提取信息、生成文本、决策) |
| 两者结合 | Skill 调用程序 |

示例: Skill 中嵌入程序

workflow:

Skill层面:理解用户意图

  • actor: llm

prompt: "理解用户想算什么统计"

程序层面:精确计算

  • actor: agent

type: execute_program

cmd: "python stats.py --data {{ file }}"

Skill层面:解释结果

  • actor: llm

prompt: "用通俗语言解释计算结果"

、一个发人深省的类比

程序就像算盘。 你知道每一颗珠子怎么拨,结果100%可预测。你不会怪算盘自作主张,它也不会。

Skill 就像实习生。 你告诉他"整理一下这份文件",他会自己判断什么是重要的、什么格式更好、要不要抄送给谁。他可能做超出预期的好事,也可能做你没预料到的蠢事。

你要做的不是 " 写代码 " ,而是 " 带人 " ------ 给他明确的目标,设定清晰的边界,告诉他哪些事不能做,然后相信他能搞定。

这个转变,是从"程序员"到"AI编排师"的转变。

、写在最后

如果你习惯了编程的"精确控制",第一次接触Skill可能会感到失控。

它会做你没说的事。

它需要你明确禁止。

它的错误有时候很难调试。

但正是这些"失控"的特征,让它能完成程序永远做不到的事情:理解模糊的意图、处理非结构化的信息、适应变化的环境。

Skill不是程序的替代品,而是程序的扩展。

程序负责精确 ,Skill负责智能

两者结合,才是未来的工作方式。

相关推荐
火山引擎开发者社区2 小时前
火山 DTS 正式支持 MySQL 同步到 Milvus , 解决业务库到向量库最后一公里
人工智能
火山引擎开发者社区3 小时前
@开发者,提前解锁 FORCE 原动力大会五大看点,限时赢取门票福利
人工智能
火山引擎开发者社区3 小时前
这个 Skill 让 Agent 从会理解到会执行,补齐移动 APP 执行最后一公里
人工智能
火山引擎开发者社区7 小时前
Agent Plan、Coding Plan限时优惠:2.5折畅享多模型!
人工智能
冬奇Lab7 小时前
AI Workflow 定义的四次演进:从 Markdown 到 JS 脚本,再到分布式多 Agent
javascript·人工智能·agent
冬奇Lab7 小时前
每日一个开源项目(第136篇):OpenMemory - 给 AI Agent 真正的认知记忆引擎
人工智能
黄啊码8 小时前
【黄啊码】微信 AI 把聊天功能和 Vibe Coding打通了,创业者:我又白干了
人工智能
IT_陈寒9 小时前
React的useState居然还有这种坑?我差点删库跑路
前端·人工智能·后端