AgentSkillsCN

debug

全面的调试方法论,用于发现并修复 Bug(旧称“调试”)。当您需要调试代码、排查错误、故障排除、进行根本原因分析,或响应突发事件时,应使用此技能。它涵盖了系统性的复现流程、基于假设的调查方法,以及根因分析技术。当您遇到异常、堆栈跟踪、崩溃、段错误、未定义行为,或需要深入调查 Bug 报告时,均可运用此技能。

SKILL.md
--- frontmatter
name: debug
description: Comprehensive debugging methodology for finding and fixing bugs (formerly debugging). This skill should be used when debugging code, investigating errors, troubleshooting issues, performing root cause analysis, or responding to incidents. Covers systematic reproduction, hypothesis-driven investigation, and root cause analysis techniques. Use when encountering exceptions, stack traces, crashes, segfaults, undefined behavior, or when bug reports need investigation.

dot-skills Debugging Best Practices

Comprehensive debugging methodology guide for software engineers, containing 54 rules across 10 categories prioritized by impact. Based on research from Andreas Zeller's "Why Programs Fail" and academic debugging curricula.

When to Apply

Reference these guidelines when:

  • Investigating a bug or unexpected behavior
  • Debugging code during development
  • Code produces wrong results or crashes
  • Performance issues need root cause analysis
  • Triaging incoming bug reports and prioritizing fixes
  • Conducting root cause analysis for incidents
  • Reviewing debugging approaches or code for common bug patterns

Rule Categories by Priority

PriorityCategoryImpactPrefix
1Problem DefinitionCRITICALprob-
2Hypothesis-Driven SearchCRITICALhypo-
3Observation TechniquesHIGHobs-
4Root Cause AnalysisHIGHrca-
5Tool MasteryMEDIUM-HIGHtool-
6Bug Triage and ClassificationMEDIUMtriage-
7Common Bug PatternsMEDIUMpattern-
8Fix VerificationMEDIUMverify-
9Anti-PatternsMEDIUManti-
10Prevention & LearningLOW-MEDIUMprev-

Quick Reference

1. Problem Definition (CRITICAL)

  • prob-reproduce-before-debug - Reproduce the bug before investigating
  • prob-minimal-reproduction - Create minimal reproduction cases
  • prob-document-symptoms - Document symptoms precisely
  • prob-separate-symptoms-causes - Separate symptoms from causes
  • prob-state-expected-actual - State expected vs actual behavior
  • prob-recent-changes - Check recent changes first

2. Hypothesis-Driven Search (CRITICAL)

  • hypo-scientific-method - Apply the scientific method
  • hypo-binary-search - Use binary search to localize bugs
  • hypo-one-change-at-time - Test one hypothesis at a time
  • hypo-where-not-what - Find WHERE before asking WHAT
  • hypo-rule-out-obvious - Rule out obvious causes first
  • hypo-rubber-duck - Explain the problem aloud

3. Observation Techniques (HIGH)

  • obs-strategic-logging - Use strategic logging
  • obs-log-inputs-outputs - Log function inputs and outputs
  • obs-breakpoint-strategy - Use breakpoints strategically
  • obs-stack-trace-reading - Read stack traces bottom to top
  • obs-watch-expressions - Use watch expressions for state
  • obs-trace-data-flow - Trace data flow through system

4. Root Cause Analysis (HIGH)

  • rca-five-whys - Use the 5 Whys technique
  • rca-fault-propagation - Trace fault propagation chains
  • rca-last-known-good - Find the last known good state
  • rca-question-assumptions - Question your assumptions
  • rca-examine-boundaries - Examine system boundaries

5. Tool Mastery (MEDIUM-HIGH)

  • tool-conditional-breakpoints - Use conditional breakpoints
  • tool-logpoints - Use logpoints instead of modifying code
  • tool-step-commands - Master step over/into/out
  • tool-call-stack-navigation - Navigate the call stack
  • tool-memory-inspection - Inspect memory and object state
  • tool-exception-breakpoints - Use exception breakpoints

6. Bug Triage and Classification (MEDIUM)

  • triage-severity-vs-priority - Separate severity from priority
  • triage-user-impact-assessment - Assess user impact before prioritizing
  • triage-reproducibility-matters - Factor reproducibility into triage
  • triage-quick-wins-first - Identify and ship quick wins first
  • triage-duplicate-detection - Detect and link duplicate bug reports

7. Common Bug Patterns (MEDIUM)

  • pattern-null-pointer - Recognize null pointer patterns
  • pattern-off-by-one - Spot off-by-one errors
  • pattern-race-condition - Identify race condition symptoms
  • pattern-memory-leak - Detect memory leak patterns
  • pattern-type-coercion - Watch for type coercion bugs
  • pattern-async-await-errors - Catch async/await error handling mistakes
  • pattern-timezone-issues - Recognize timezone and date bugs

8. Fix Verification (MEDIUM)

  • verify-reproduce-fix - Verify with original reproduction
  • verify-regression-check - Check for regressions
  • verify-understand-why-fix-works - Understand why fix works
  • verify-add-test - Add test to prevent recurrence

9. Anti-Patterns (MEDIUM)

  • anti-shotgun-debugging - Avoid shotgun debugging
  • anti-quick-patch - Avoid quick patches without understanding
  • anti-tunnel-vision - Avoid tunnel vision on initial hypothesis
  • anti-debug-fatigue - Recognize debugging fatigue
  • anti-blame-tool - Don't blame the tool too quickly

10. Prevention & Learning (LOW-MEDIUM)

  • prev-document-solution - Document bug solutions
  • prev-postmortem - Conduct blameless postmortems
  • prev-defensive-coding - Add defensive code at boundaries
  • prev-improve-error-messages - Improve error messages

How to Use

Read individual reference files for detailed explanations and code examples:

Full Compiled Document

For the complete guide with all rules expanded: AGENTS.md