🐷

初心者のためのWeb開発講座 レッスン01 プログラミング言語と開発ツール入門

2020/11/23に公開

MicrosoftがWeb-Dev-For-Beginnersという、Web開発初心者向けの講座を公開しています。
全24章からなる大作のレッスン講座となっています。

以下はそのうち最初の第一章、Introduction to Programming Languages and Tools of the Tradeの日本語訳です。

プログラミング言語と開発ツール入門

このレッスンでは、まずプログラミング言語の基礎を学びます。
ここで取り上げた特徴は、最新のプログラミング言語のほとんどに当てはまります。
次にツールセクションでは、開発者にとって有用なソフトウェアを紹介します。

Intro Programming

Sketchnote by Tomomi Imura

事前クイズ

・コードを書かなくてもプログラムを作ることはできる?

はい / いいえ

・低レベル言語がポピュラーな分野はどこですか?

Webサイト / ハードウェア / ゲームソフト

・Web開発者と最も関連性の高いツールはどれでしょう?

Raspberry Piのようなハードウェア / ブラウザ開発者ツール / OSドキュメント

Introduction

この講座には以下が含まれています。

  • プログラミングとは何か?
  • プログラミング言語の種類
  • プログラムの基本要素
  • 開発ツール

プログラミングとは何か?

プログラミング(コーディングとも表されます)とは、コンピュータやモバイル機器などのデバイスに対して、命令を出すことです。
命令はプログラミング言語で書かれており、そしてデバイスはその命令を解釈して実行します。
この命令は色々な名称で呼ばれることがありますが、プログラムコンピュータプログラムアプリケーション(アプリ)実行可能ファイル、などが一般的に使われています。

プログラムとは、コードで書かれている何かです。
Webサイトも、ゲームも、スマホアプリも、全てがプログラムです。
コードを書かずにプログラムを作ることも可能ですが、作り上げたロジックは実際にはコードで書かれていて、実際にデバイスが解釈するのはコードです。
プログラムはコードを実行し、デバイスに命令を出します。
あなたが今このレッスンを読んでいるということは、文字を画面に表示するというプログラムをデバイスが実行しているということです。

✅ ちょっと調べてみましょう:世界初のコンピュータプログラマは誰でしょうか?

プログラミング言語

プログラミング言語の主な目的は、開発者がデバイスに対して命令を送信する手助けをすることです。
デバイスはバイナリ(要するに0と1)しか理解することができず、そしてほとんどの開発者にとってバイナリはあまり効率的な命令手段ではありません。
プログラミング言語は、人間とコンピュータがコミュニケーションを取るための手段なのです。

世の中には様々な目的のために様々なプログラミング言語が存在しています。
たとえばJavaScriptは主にWebアプリケーションのために、Bashは主にOSとの対話のために使われます。

低レベル言語とは、デバイスが命令を解釈するために必要なステップ数が、高レベル言語より少ない言語のことです。
高レベル言語が人気であるのは、その読みやすさとサポート能力によるものです。
JavaScriptは高レベル言語とされています。

次のコードは、高レベル言語であるJavaScriptと、低レベル言語であるARMアセンブリの違いを表したものです。

let number = 10
let n1 = 0, n2 = 1, nextTerm;

for (let i = 1; i <= number; i++) {
    console.log(n1);
    nextTerm = n1 + n2;
    n1 = n2;
    n2 = nextTerm;
}
 area ascen,code,readonly
 entry
 code32
 adr r0,thumb+1
 bx r0
 code16
thumb
 mov r0,#00
 sub r0,r0,#01
 mov r1,#01
 mov r4,#10
 ldr r2,=0x40000000
back add r0,r1
 str r0,[r2]
 add r2,#04
 mov r3,r0
 mov r0,r1
 mov r1,r3
 sub r4,#01
 cmp r4,#00
 bne back
 end

信じられないかもしれませんが、両者は同じ処理をしています。
いずれもフィボナッチ数を順番に10個出力します。

フィボナッチ数とは、各数がその手前の二つの値の和である値の集合です。

プログラムの基本要素

プログラムにおいてひとつの命令はと呼ばれ、文は通常は改行などの区切り文字で分かたれます。
プログラムの区切り文字は言語によって異なります。

多くのプログラムは、ユーザや他から来た入力データによって出力が変わります。
データによってプログラムの動作を変えるため、プログラミング言語にはデータを一時的に保存しておく方法が用意されています。
そのデータは変数と呼ばれています。
変数とは、デバイス内のメモリにデータを保存する文のことです。
プログラムにおける変数は数学における変数と似ていて、変数には固有の名称があり、その値は処理の経過に伴って変化することがあります。

プログラムには、実行されない文が現れることがあります。
これは、そうなるように開発者が設計して制御されたものであるか、予期せぬエラーが発生したかのいずれかです。
アプリケーションの制御は、堅牢で信頼性の高いプログラムを書くために必要なことです。
制御は、何らかの条件が満たされたことによって発生することが一般的です。
最近のプログラミング言語には、実行される文を制御するためにif...elseのような文が存在します。

✅ これら文については次のレッスンで詳しく学びます。

開発ツール

Tools of the Trade

このセクションでは、プロの開発者としての道を歩き始めるときに役立つであろうソフトウェアについて紹介します。

開発環境とは、開発者がソフトウェアを作成する際に頻繁に使用するツールや機能のセットのことです。
開発環境は、開発者が特定のニーズに合わせてカスタマイズしたり、優先順位を変更したり、異なるプログラミング言語を使用したりといった理由で次々と変わっていくこともあります。
開発環境は、それを使用する開発者の数と同じくらい千差万別です。

エディタ

ソフトウェア開発において最も重要なツールのひとつが、エディタです。
エディタはコードを書く場所であり、時にはコードを実行する場所であることもあります。

開発者がエディタを使う理由は、それ以外にも多々あります。

  • デバッグ
    コードを1行1行ステップ実行することで、バグやエラーを発見しやすくします。
    デバッグ機能を備えたエディタや、特定のプログラミング言語用にカスタマイズすることができるエディタも存在します。

  • シンタックスハイライト
    コードに色や書式を設定することで、コードを読みやすくします。
    多くのエディタはシンタックスハイライトをカスタマイズすることもできます。

  • 拡張機能
    デフォルトでは含まれない、一部の開発者向けに特化された拡張機能を追加することができます。
    例えば、コードをドキュメント化してどのように動作するかを確認したいユーザがいて、タイプミスのチェックのためにスペルチェックを行いたいユーザがいて、各自が自分のほしい拡張機能をインストールすることができます。
    ほとんどの拡張機能は特定のエディタでのみ動作するもので、そしてほとんどのエディタは拡張機能を検索する方法を用意しています。

  • カスタマイズ
    ほとんどのエディタは幅広いカスタマイズが可能で、開発者は自分のニーズに合わせた開発環境を作ることができます。
    さらに多くのエディタでは、開発者が自分で拡張機能を作ることも可能です。

有名なエディタとWeb開発向けのエクステンション

ブラウザ

もうひとつの重要なツールはブラウザです。
Web開発者は、自分のコードがWeb上でどのように実行されるかを確認するため、そしてHTML要素を視覚的に確認するためにブラウザを必要とします。

多くのブラウザには開発者ツールが付属しており、アプリケーションの動作を収集・分析するために便利な機能や情報があります。
たとえば開発者ツールを使って、Webページにエラーがあった場合に、いつどこでエラーが発生したかを把握することができます。

有名なブラウザ

コマンドラインツール

開発者の中には、日常の作業をGUIで行うことを好まず、コマンドラインに多くを頼る人もいます。
コードの開発には多量のタイピングが必要となるため、マウスを使うためにキーボードから手を外すことで作業の流れを中断されることを避け、キーボードショートカットを駆使して複数のファイルを操作したり複数のツールを併用したりします。

多くのタスクはマウスだけでも実行可能です。
しかし、コマンドラインの利点のひとつが、マウスとキーボードで行ったり来たりせずにキーボードだけで作業を完結できるというものです。
またコマンドラインのもうひとつの利点が、カスタム設定を登録しておくことが可能ということです。
さらにマシンを新調したときに設定を移動することもできます。

開発環境は個人個人によって非常に異なるため、コマンドラインの使用を避ける人もいれば、完全にコマンドラインだけしか使わない人もいます。
両方とも使う人も多いでしょう。

有名なコマンドラインオプション

コマンドラインオプションは、OSによって異なります。

💻はOSにプリインストールされているものです。

Windows

MacOS

Linux

有名なコマンドラインツール

ドキュメント

何か新しいことを学びたいと思ったとき、その使い方を学ぶためには大抵ドキュメントに頼ることになるでしょう。
開発者は、ツールや言語を適切に使用する方法を学んだり、その仕組みについて深く調べる場合、まずはドキュメントを参照します。

Web開発者向けの有名なドキュメント

✅ Web開発者の開発環境の基礎を理解したところで、Webデザイナーの開発環境との違いを見てみましょう。


🚀 チャレンジ

いくつかのプログラミング言語について比較してみましょう。
JavaScriptとJavaの特徴は?
COBOLとGoについては?

事後テスト

・Webサイトを作るときに最もよく使われるプログラミング言語はどれでしょう?

機械語 / JavaScript / Bash

・開発環境は開発者ごとに異なる?

はい / いいえ

・バグだらけのコードを修正するため、開発者は何をしますか?

シンタックスハイライト / デバッグ / コードフォーマット

レビュー & 自習

プログラマーが利用できる様々な言語について、少しだけかじってみましょう。
ひとつの言語で1行書いて実行したら、次は別のふたつの言語で同じことをやってみてください。
なにかわかりましたか?

感想

初心者向け講座の最初のレッスンだけあって、一切コードは出てこず紹介だけの内容です。
本当に初めての人向けの講座ですね。
次のレッスンからはいよいよJavaScriptか、と思えば先にGitHubの使い方アクセシビリティの話があって、その後ようやくJavaScriptというなかなか変わった構成になっています。

そんなペースで大丈夫か?と思えば後半は色々なプロジェクトを作ったりしています。
全24レッスンを踏破したころには、きっといっぱしのWeb開発者になっていることでしょう。

Discussion