DEV Community


Posted on


One Good Reason Why You Should Not Use Async Void

Let's take a look at this little example.

class Program
    static void Main(string[] args)
            Console.WriteLine("No exception is thrown!");
        catch (Exception e)

    private static async void AsyncVoidMethod()
        throw new Exception("BOOM!");
Enter fullscreen mode Exit fullscreen mode

What we have here is a method AsyncVoidMethod, which throws an exception and returns async void instead of async Task.

Since it's void, we cannot await it. What it also means that exception from an async call could not be saved anywhere because there is no Task object which could save it.


No exception is thrown!

It's a dangerous problem: an exception is not handled!


I wouldn't like to describe a solution here, because John Thiriet already did a great job doing so, and you know, that duplication is evil, right?

Check this fantastic article for solution:

Top comments (1)

roubachof profile image
Jean-Marie Alfonsi

Hey man! Great subject!
I also created my own component to handle async void and process global error handler, statistic, ...

An Animated Guide to Node.js Event Loop

>> Check out this classic DEV post <<