csharp-async

github/awesome-copilot · updated Apr 8, 2026

$npx skills add https://github.com/github/awesome-copilot --skill csharp-async
0 commentsdiscussion
summary

Best practices guide for C# asynchronous programming patterns and pitfalls.

  • Covers naming conventions (Async suffix), return types (Task, ValueTask, avoid void), and exception handling strategies including ConfigureAwait and Task.FromException
  • Highlights performance optimization techniques: Task.WhenAll for parallel execution, Task.WhenAny for timeouts, and cancellation token usage
  • Documents critical pitfalls to avoid: blocking calls like .Wait() and .Result, async void methods outsi
skill.md

C# Async Programming Best Practices

Your goal is to help me follow best practices for asynchronous programming in C#.

Naming Conventions

  • Use the 'Async' suffix for all async methods
  • Match method names with their synchronous counterparts when applicable (e.g., GetDataAsync() for GetData())

Return Types

  • Return Task<T> when the method returns a value
  • Return Task when the method doesn't return a value
  • Consider ValueTask<T> for high-performance scenarios to reduce allocations
  • Avoid returning void for async methods except for event handlers

Exception Handling

  • Use try/catch blocks around await expressions
  • Avoid swallowing exceptions in async methods
  • Use ConfigureAwait(false) when appropriate to prevent deadlocks in library code
  • Propagate exceptions with Task.FromException() instead of throwing in async Task returning methods

Performance

  • Use Task.WhenAll() for parallel execution of multiple tasks
  • Use Task.WhenAny() for implementing timeouts or taking the first completed task
  • Avoid unnecessary async/await when simply passing through task results
  • Consider cancellation tokens for long-running operations

Common Pitfalls

  • Never use .Wait(), .Result, or .GetAwaiter().GetResult() in async code
  • Avoid mixing blocking and async code
  • Don't create async void methods (except for event handlers)
  • Always await Task-returning methods

Implementation Patterns

  • Implement the async command pattern for long-running operations
  • Use async streams (IAsyncEnumerable) for processing sequences asynchronously
  • Consider the task-based asynchronous pattern (TAP) for public APIs

When reviewing my C# code, identify these issues and suggest improvements that follow these best practices.

Discussion

Product Hunt–style comments (not star reviews)
  • No comments yet — start the thread.
general reviews

Ratings

4.650 reviews
  • Yusuf Rao· Dec 20, 2024

    We added csharp-async from the explainx registry; install was straightforward and the SKILL.md answered most questions upfront.

  • Yuki Okafor· Dec 20, 2024

    csharp-async fits our agent workflows well — practical, well scoped, and easy to wire into existing repos.

  • Ganesh Mohane· Dec 12, 2024

    Solid pick for teams standardizing on skills: csharp-async is focused, and the summary matches what you get after install.

  • Yuki Mensah· Dec 12, 2024

    Solid pick for teams standardizing on skills: csharp-async is focused, and the summary matches what you get after install.

  • Naina Kapoor· Nov 11, 2024

    Solid pick for teams standardizing on skills: csharp-async is focused, and the summary matches what you get after install.

  • William Bansal· Nov 11, 2024

    csharp-async has been reliable in day-to-day use. Documentation quality is above average for community skills.

  • Sakshi Patil· Nov 3, 2024

    We added csharp-async from the explainx registry; install was straightforward and the SKILL.md answered most questions upfront.

  • Zaid Gill· Nov 3, 2024

    We added csharp-async from the explainx registry; install was straightforward and the SKILL.md answered most questions upfront.

  • Yusuf Srinivasan· Nov 3, 2024

    csharp-async reduced setup friction for our internal harness; good balance of opinion and flexibility.

  • Zaid Mehta· Nov 3, 2024

    Registry listing for csharp-async matched our evaluation — installs cleanly and behaves as described in the markdown.

showing 1-10 of 50

1 / 5