이 페이지는 아직 영어로 제공되지 않습니다. 번역 작업 중입니다.
현재 번역 프로젝트에 대한 질문이나 피드백이 있으신 경우 언제든지 연락주시기 바랍니다.

Metadata

ID: csharp-best-practices/completed-task-not-null

Language: C#

Severity: Warning

Category: Best Practices

Description

This rule emphasizes the importance of always returning a Task from asynchronous methods in C#, instead of null. Returning null from an async method can lead to NullReferenceException errors at runtime when the returned task is awaited. This can make debugging more difficult and can lead to unexpected behavior or bugs in your application.

The importance of this rule stems from the fact that it’s a common best practice in asynchronous programming. It ensures that your asynchronous methods always return a valid task that can be awaited, regardless of the execution path of your method. This can make your asynchronous code easier to understand and maintain.

How to Remediate

To fix this issue, always return a completed Task or Task<T> from your asynchronous methods instead of null. You can use Task.CompletedTask to return a completed task without a result, or Task.FromResult(result) to return a completed task with a result. For example: return Task.FromResult<object>(null); This will ensure that your asynchronous methods are always returning a valid task that can be awaited.

Non-Compliant Code Examples

public class {
    Task<object> GetAsync()
    {
        return null;
    }
}
Task<object> GetAsync()
{
    return null;
}

Compliant Code Examples

Task<object> GetAsync()
{
    return Task.FromResult<object>(null);
}
https://static.datadoghq.com/static/images/logos/github_avatar.svg https://static.datadoghq.com/static/images/logos/vscode_avatar.svg jetbrains

Seamless integrations. Try Datadog Code Security

PREVIEWING: guacbot/translation-pipeline