Async vs sync code
The difference between running code synchronously or asynchronously
You might have heard that Node.js is fast because it provide asynchronous APIs for all expensive operations, like network access or filesystem.
What does having an asynchronous API mean?
If you anticipate an operation can take a lot of time, it makes sense to run it asynchronously, so other code can run in the meantime, and have a hook that’s called when that operation ends.
This is how Node.js can handle a lot more traffic than, say, PHP or Rails without using async libraries.
Most programming languages that were not traditionally async today do have 3rd party libraries that implement ways to call asynchronous code.
Otherwise what usually happens for example in PHP or Python code is that the thread blocks until the sync operation (reading from the network, writing a file..) ends.
If the code runs asynchronously, the CPU is not idle waiting for the process to complete, but it can go on with other tasks queued up until the original process is ready to move on.
→ I wrote 17 books to help you become a better developer, download them all at $0 cost by joining my newsletter
→ JOIN MY CODING BOOTCAMP, an amazing cohort course that will be a huge step up in your coding career - covering React, Next.js - next edition February 2025