myHotTake

Tag: async vs sync

  • Synchronous vs Asynchronous: How Do They Differ in JavaScript?

    Hey there! If you find this story helpful or entertaining, feel free to give it a like or share it with your friends.


    Let’s go through my day as a post office worker, where my job is to deliver letters. In the world of synchronous API operations, I picture myself standing at a customer’s doorstep, ringing the bell, and waiting patiently until they open the door, read the letter, and give me a response right then and there. It’s a straightforward process, but I can’t move on to the next delivery until I finish this interaction. This means if the person takes a long time to respond, my entire schedule slows down.

    Now, let’s switch to asynchronous API operations. In this scenario, I’m more like a super-efficient mailman with a twist. I drop the letter in the mailbox and move on to my next delivery without waiting for the door to open. The recipient can read and respond to the letter whenever they have time. Meanwhile, I’m already off delivering the next letter, making my rounds without any waiting involved.

    If a response comes in, it’s like getting a notification on my phone, letting me know that I can now see their reply whenever I have a moment. This way, I keep things moving smoothly without being held up by any single delivery.

    This analogy helps me grasp the essence of synchronous versus asynchronous operations: one involves waiting for each task to complete before moving on, while the other allows for multitasking and handling responses as they come in.


    Part 2: Tying It Back to JavaScript

    In the JavaScript world, synchronous operations are like our patient mailman, waiting at each door. Here’s a simple example:

    // Synchronous example
    function greet() {
        console.log("Hello!");
        console.log("How are you?");
    }
    
    greet();
    console.log("Goodbye!");

    In this synchronous code, each line waits for the previous one to complete before moving on. So, it prints “Hello!”, then “How are you?”, and finally “Goodbye!”—in that exact order.

    Now, let’s look at an asynchronous example using setTimeout, which behaves like our efficient mailman who drops off letters and moves on:

    // Asynchronous example
    function greetAsync() {
        console.log("Hello!");
        setTimeout(() => {
            console.log("How are you?");
        }, 2000);
        console.log("Goodbye!");
    }
    
    greetAsync();

    In this asynchronous version, “Hello!” is printed first, followed almost immediately by “Goodbye!” because setTimeout schedules “How are you?” to be printed after 2 seconds, allowing the rest of the code to continue running in the meantime.

    Key Takeaways

    1. Synchronous Code: Executes line-by-line. Each line waits for the previous one to finish, much like waiting at the door for a response before moving to the next task.
    2. Asynchronous Code: Allows tasks to be scheduled to complete later, enabling other tasks to run in the meantime—similar to dropping off letters and continuing the delivery route without waiting for an immediate reply.