m02-resource
219
总安装量
216
周安装量
#1244
全站排名
安装命令
npx skills add https://github.com/zhanghandong/rust-skills --skill m02-resource
Agent 安装分布
opencode
177
codex
159
gemini-cli
151
claude-code
146
github-copilot
139
amp
95
Skill 文档
Resource Management
Layer 1: Language Mechanics
Core Question
What ownership pattern does this resource need?
Before choosing a smart pointer, understand:
- Is ownership single or shared?
- Is access single-threaded or multi-threaded?
- Are there potential cycles?
Error â Design Question
| Error | Don’t Just Say | Ask Instead |
|---|---|---|
| “Need heap allocation” | “Use Box” | Why can’t this be on stack? |
| Rc memory leak | “Use Weak” | Is the cycle necessary in design? |
| RefCell panic | “Use try_borrow” | Is runtime check the right approach? |
| Arc overhead complaint | “Accept it” | Is multi-thread access actually needed? |
Thinking Prompt
Before choosing a smart pointer:
-
What’s the ownership model?
- Single owner â Box or owned value
- Shared ownership â Rc/Arc
- Weak reference â Weak
-
What’s the thread context?
- Single-thread â Rc, Cell, RefCell
- Multi-thread â Arc, Mutex, RwLock
-
Are there cycles?
- Yes â One direction must be Weak
- No â Regular Rc/Arc is fine
Trace Up â
When pointer choice is unclear, trace to design:
"Should I use Arc or Rc?"
â Ask: Is this data shared across threads?
â Check: m07-concurrency (thread model)
â Check: domain-* (performance constraints)
| Situation | Trace To | Question |
|---|---|---|
| Rc vs Arc confusion | m07-concurrency | What’s the concurrency model? |
| RefCell panics | m03-mutability | Is interior mutability right here? |
| Memory leaks | m12-lifecycle | Where should cleanup happen? |
Trace Down â
From design to implementation:
"Need single-owner heap data"
â Use: Box<T>
"Need shared immutable data (single-thread)"
â Use: Rc<T>
"Need shared immutable data (multi-thread)"
â Use: Arc<T>
"Need to break reference cycle"
â Use: Weak<T>
"Need shared mutable data"
â Single-thread: Rc<RefCell<T>>
â Multi-thread: Arc<Mutex<T>> or Arc<RwLock<T>>
Quick Reference
| Type | Ownership | Thread-Safe | Use When |
|---|---|---|---|
Box<T> |
Single | Yes | Heap allocation, recursive types |
Rc<T> |
Shared | No | Single-thread shared ownership |
Arc<T> |
Shared | Yes | Multi-thread shared ownership |
Weak<T> |
Weak ref | Same as Rc/Arc | Break reference cycles |
Cell<T> |
Single | No | Interior mutability (Copy types) |
RefCell<T> |
Single | No | Interior mutability (runtime check) |
Decision Flowchart
Need heap allocation?
ââ Yes â Single owner?
â ââ Yes â Box<T>
â ââ No â Multi-thread?
â ââ Yes â Arc<T>
â ââ No â Rc<T>
ââ No â Stack allocation (default)
Have reference cycles?
ââ Yes â Use Weak for one direction
ââ No â Regular Rc/Arc
Need interior mutability?
ââ Yes â Thread-safe needed?
â ââ Yes â Mutex<T> or RwLock<T>
â ââ No â T: Copy? â Cell<T> : RefCell<T>
ââ No â Use &mut T
Common Errors
| Problem | Cause | Fix |
|---|---|---|
| Rc cycle leak | Mutual strong refs | Use Weak for one direction |
| RefCell panic | Borrow conflict at runtime | Use try_borrow or restructure |
| Arc overhead | Atomic ops in hot path | Consider Rc if single-threaded |
| Box unnecessary | Data fits on stack | Remove Box |
Anti-Patterns
| Anti-Pattern | Why Bad | Better |
|---|---|---|
| Arc everywhere | Unnecessary atomic overhead | Use Rc for single-thread |
| RefCell everywhere | Runtime panics | Design clear ownership |
| Box for small types | Unnecessary allocation | Stack allocation |
| Ignore Weak for cycles | Memory leaks | Design parent-child with Weak |
Related Skills
| When | See |
|---|---|
| Ownership errors | m01-ownership |
| Interior mutability details | m03-mutability |
| Multi-thread context | m07-concurrency |
| Resource lifecycle | m12-lifecycle |