タグ

2019年7月21日のブックマーク (2件)

  • JavaScriptの同期、非同期、コールバック、プロミス辺りを整理してみる - Qiita

    対象 このあたりの理解があいまいな方: JavaScriptは非同期で処理できる!? 並行処理と非同期処理って同じ!? そもそも同期と非同期って何が違う!? 非同期の結果はコールバックで受け取る!? コールバックを多用するとコールバック地獄に陥る!? Promiseを使うとコールバック地獄を回避できる!? JavaScriptの基礎 大前提として、JavaScriptはシングルスレッドで動いています。 これはつまり、JavaScriptは並行処理はできないということです。 同期であろうと非同期であろうと2つ以上の処理を同時に行なうことはできません。 JavaScriptでは、キューに登録された関数が順番にひとつずつ実行されていきます。 でもキューに登録される順番が同期であったり非同期であったりします。 JavaScript以外(例えばデータベース等)に仕事を任せてる間、その処理を待たないで

    JavaScriptの同期、非同期、コールバック、プロミス辺りを整理してみる - Qiita
  • JavaScriptと非同期処理の話 - Qiita

    JavaScript歴史、それは非同期処理との戦いの歴史 プログラムの常識 コードは上から順に実行される const fs = require('fs'); var hoge = fs.readFile("hoge.txt") var fuga = fs.readFile("fuga.txt") var foo = fs.readFile("foo.txt") var bar = fs.readFile("bar.txt") console.log(hoge + fuga + foo + bar); 動かない なんで? 非同期処理だから ファイルの読み込みが終わる前に console.log() が走っちゃう なんで非同期なの? 同期的な処理だと、IOアクセスの待ち時間中に何もできなくなる DOMを操作するときはなにかと非同期で動かしたいことが多い(Ajaxのレスポンスを待っている間にプ

    JavaScriptと非同期処理の話 - Qiita