Skip to content

Instantly share code, notes, and snippets.

@nkt217
Forked from joepie91/asynchronous.js
Created February 23, 2018 11:41
Show Gist options
  • Save nkt217/7abff34fde9d8ad33807668dc308d9db to your computer and use it in GitHub Desktop.
Save nkt217/7abff34fde9d8ad33807668dc308d9db to your computer and use it in GitHub Desktop.
PHP vs Node.js: Synchronous vs Asynchronous
console.log("Before the first file is read.");
hypotheticalFileGetContents("sample.txt", function(fileContents){
// fileContents now contains the file contents, this function is only called when the file read in the background has finished
console.log("After the first file has completed reading.");
});
// You've now told it to start the first read, but it won't 'block' your script execution. It will do the read in the background, and immediately move on with the rest of your code.
console.log("Before the second file is read.");
hypotheticalFileGetContents("sample2.txt", function(fileContents){
// fileContents now contains the file contents, this function is only called when the file read in the background has finished
console.log("After the second file has completed reading.");
});
/* Output could look something like this:
Before the first file is read.
Before the second file is read.
After the first file has completed reading.
After the second file has completed reading.
*/
<?php
echo("Before the first file is read.");
$fileContents = file_get_contents("sample.txt"); // You can't do anything while the file is being read, your script is 'stuck'.
echo("After the first file has completed reading.");
echo("Before the second file is read.");
$fileContents = file_get_contents("sample2.txt"); // You can't do anything while the file is being read, your script is 'stuck'.
echo("After the second file has completed reading.");
/* Output always looks like this:
Before the first file is read.
After the first file has completed reading.
Before the second file is read.
After the second file has completed reading.
*/
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment