106
122

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

【読書】『独学プログラマー』の心得

Last updated at Posted at 2022-08-18

優れたプログラマーは、金銭的な報酬や人々から賞賛を浴びる目的でコードを書くのではない。単純にプログラミングを楽しむためにコードを書くんだ。
リーナス・トーバルズ(Linuxカーネル開発者)

コーリー・アルソフ氏の『独学プログラマー Python言語の基本から仕事のやり方まで』(清水川貴之氏、新木雅也氏による邦訳は2018年発行)を読んだので、本のタイトルの通り独学でプログラマーを目指している方や、新人エンジニアの方に一読をお薦めできると感じたので紹介します。

かく言う私もソフトウェアエンジニアリングを独学し、肩書きとしてエンジニアの職を得て2年目の身。
『独学プログラマー』を読んで初心に返り、至らぬ点を内省できました。
(エンジニアとして就業できてからも独学は続くので、経験を重ねてからでもこの本を読む価値はあると思います!)

本書の対象となる方

プロのプログラマーになる際に必要な知識や技術について、メタ視点で全体像を把握したい方。
プログラマーなりたての方で、ある程度の基礎知識(ターミナルでコマンド叩ける等)のある方。

著者について

アメリカのクレムソン大学で政治学を専攻。
大学時代にプログラミング入門コースを履修したが難しすぎて断念。
卒業後にシリコンバレーに住みながら独学でプログラミングを習得。
一年後にeBayのソフトウェア・エンジニアとして就職。
その後、シリコンバレーにて複数のスタートアップに参画し、フルスタック・エンジニアとして活躍。

という、おつよい方です(←語彙力)。

本書に関する情報は以下でも得られます。
THE SELF-TAUGHT PROGRAMMER
著者のブログなどはこちら。
Cory Althoff – Medium
Learn The Skills You Need To Succeed | Self-Taught

この記事で紹介しない本書の内容

  • 実践的なプログラミング基礎知識
    • 本書ではPythonに関連して、プログラミングの重要概念の基礎が丁寧に解説されています。各章の最後に用語集も付いていて、新しい用語を覚えるのに最適です。
    • プログラミングパラダイム、オブジェクト指向プログラミング、bash、正規表現、パッケージ管理、バージョン管理、データ構造、アルゴリズムなども取り上げられていて、幅広い内容についてベーシックな知識が得られます。
  • 例題プログラム
    • ハングマンという単語当てゲームや「戦争(War)」というカードゲームを遊べるコードもあって面白いです。
  • エンジニア就活
    • 職種の選び方、エンジニア経験の積み方、面接対策などに触れています。

独学プログラマーの心得

大事なところから学ぶ

まずプログラミングを学び、それがどんな理論で動いているのか知りたいと強く思ってから理論を学んだほうが効率が良いです。
コンピュータサイエンスの理論は大事ですが、プログラミングの経験があって初めて真価を発揮するのです。
(理論から始めてしまうと一向にプログラミングスキルを伸ばせないというのもあると思います。範囲が広すぎるので。。。)

あなただけじゃない

プログラミングを学校外で学ぶことはどんどん一般的になっています。
コンピュータサイエンスの学位を持たないプログラマーは少なくないです。
(本記事の筆者の私もそう)

独学の強み

著者がeBayで働き始めたときは、年下のチームメイトが何倍もプログラミングとコンピュータサイエンスについて知っていることが歯がゆかったそうです。
しかし、独学の強みは「誰かから命じられているのではなく、自分から学びたいという強い欲求」。
置かれた環境が歯がゆくても、この強みを忘れないでください。
Appleのスティーブ・ウォズニアック、Tumblerのデービッド・カープ、Twitterのジャック・ドーシー、Instagramのケビン・シストロムも独学プログラマーです。

プログラムを書くと良いこと

プログラミングスキルは、どんな職業に就いていても仕事の手助けになります。
プログラミングをマスターすることによる問題解決能力は多くの事柄に役立ちます。
繰り返しのつまらない作業をプログラムにさせることができます。
学ぶことが活力も与えてくれます。
プログラミングができれば、誰かにやってもらわなくても新しいアイデアを実現できます。

断固として継続しよう

よく言われるような「数学が得意」である必要はないが、学ぶ努力は必要です。
上達しないとすれば、継続して練習していないからです。
著者は、日々練習したことを確かめるためのチェックリストを使うと、集中力の維持に役立ったそうです。
他にもモチベーションを維持するテクニックに従ってみましょう。

プログラミングのベストプラクティス

コードを書くときはいつも、あなたのコードをメンテするのが凶暴なサイコパスで、しかもあなたの住所を知っている、と考えよう。
ジョン・ウッズ

(こんなこと考えながら落ち着いて開発できる気がしないですが、、、笑)

コードを書くのは最後の手段

ソフトウェアエンジニアとしての仕事は、できるだけ少ないコードで書くことです。
問題を前に最初に考えるべきは
「どうやってこれを解こうか」
ではなく、
「他の誰かがすでにこの問題を解決しているだろうか?
その解決方法は自分も使えるだろうか?」
解決策をネットで探しましょう。
誰も解決していないことがわかって初めて解き始めましょう。

DRY

Don't Repeat Yourselfの原則です。
コードを書くときに、同じような作業を繰り返してはいけないという意味です。
コードを関数に入れれば、何度でも使えます。

直交性

「aはbに影響するべきではない」と覚えましょう。
2つのモジュールa, bがあるとき、aはbの中身に変更を加えるべきではないです。
逆も同様になります。
片方の変更が他方に影響を与えるような設計にすると、コードが秩序をなくし、制御不能になります。
例えば、データベースとユーザー・インターフェースも直交性を保つべき組み合わせです。

どのデータも一カ所で定義しよう

何らかのデータを扱うとき、そのデータは複製などせずに1ヶ所だけに持ちましょう。
データを複製してしまうと、修正箇所があちこちに分散してしまいます。
また、変更するときにどこで複製していたかを全て覚えておかないといけません。

1つの関数には1つのことだけをさせよう

とても長い関数を見つけたとき、複数のタスクを達成しようとしていないか再確認しましょう。
1つのタスクだけ行うようにすると、関数名が目的をよく表すようになり、コードが読みやすくなります。
コードがうまく動かない時も、その関数は1つの目的しか持っていないので、どこがうまく動かないのか見つけてデバッグするのが簡単になります。
ソフトウェアの複雑さは、1つのことに2つのことをさせてしまうことから生じます。

時間がかかりすぎるなら、たぶん何かを間違えている

膨大なデータを扱うような明らかな場合を除き、プログラムの処理に時間がかかりすぎるときは何か実装がおかしいと疑いましょう。

最初に良い方法で実装しよう

プログラミングをしている最中に、より良いやり方があることを知っているなら、コーディングを中断し、より良いやり方を選んでその場で実装しましょう。
後で改修せずに済みます。
(早く終わらせたいときには少し辛いですが、のちのち楽になりますね。。。)

慣例に従おう

プログラミングの慣例を学ぶことでその言語のコードを早く読めるようになります。
PythonならPEP8(コーディング規約)をぜひ読みましょう。

強力なIDEを使おう

Pythonであれば、PyCharmというIDE(統合開発環境)を著者は利用しているようです。
(私も使っています)
おすすめ機能は以下です。

  • 変数や関数、オブジェクトの定義位置にジャンプできるショートカットキー
  • 自動のファイル編集履歴機能。gitなどのバージョン管理システム代わりに利用できる
  • PyCharmからコマンドラインに代わってgitも使える
  • コマンドライン、対話型シェルが組み込まれている
  • デバッガー

ロギング

ロギングとはソフトウェアの動作を記録することです。
プログラムをデバッグするための情報を得たり、プログラムの実行中に内部で何が起きているかの詳細を得られます。
Pythonではloggingモジュールを使えばコンソールやファイルにログを記録できます。
プログラムで何か異常が起きているなら、後で確認できるよう何が起きたかの情報をログに残しましょう。
ウェブサイトのデータを収集し分析するようなときにもログは役立ちます。

テスト

テストとは、プログラムの動作を確認することです。
プログラマーはプログラムをテストするためのプログラムを書きます。
プログラムを製品として出すのであれば、テストはやってもやらなくてもいいものではありません。
一度しか使わない短いプログラムのためにテストを書いて時間を無駄にする必要はないですが、他の人が利用するプログラムのテストは書きましょう。
Pythonではunittestモジュールが使えます。

コードレビュー

コードレビューでは、誰かにコードを読んでもらい、フィードバックをもらいます。
できるだけ多くコードレビューをしましょう。
特に独学プログラマーには重要です。
コードを改善するには、あなたのコードを読み、何が間違っているかを意見してくれる経験者が必要です。
レビューを受けられるコミュニティサイトもあります。
Code Review Stack Exchange

セキュリティ

セキュリティは独学プログラマーが無視しがちです。
プログラミングの仕事に就いたら、書いたコードのセキュリティについて責任を持つことになります。
例えば、ユーザーの入力には悪意がある可能性を常に意識しましょう。
悪意ある攻撃のいくつかは、ユーザー入力を処理するプログラムの脆弱性の上に成り立っています。

ソフトウェアを安全に保つための戦略として、攻撃対象領域を最小限にする方法があります。
攻撃対象領域とは、攻撃者がデータを盗み出したり、システムを攻撃できたりするプログラムの様々な領域のことです。
攻撃対象領域を最小化するには、以下のような戦略があります。

  1. 不必要に機密性の高いデータを保存しない
  2. ユーザーに与えるアクセス権はできるだけ小さくする
  3. サードパーティライブラリの利用をできるだけ避ける(コードが少ないほど、脆弱性も少ない)
  4. 利用されなくなった機能を削除する(コードを減らし、脆弱性を減らす)

プログラムを安全に保つには、攻撃者がどうやってコードを悪用するかを考え、脆弱性を見過ごさないようにしましょう。

チームで働く

基本をマスターする

本書に書かれている範囲の技術や概念はマスターしていることがチームでは求められる。
基本的なことに助けが必要な状態でチームに参加するのは避けましょう。

Google検索できることを質問しない

質問するのは学ぶのに良い方法ですが、正しい質問ができているかは確認しておきましょう。
少なくとも5分は調べてから質問しましょう。
(Googleの人工知能チームには、問題が起きたときの「15分ルール」があるようですが)
自分で簡単に解決できるような質問をたくさんしてしまうと、チームメイトを煩わせてしまいます。

詐欺師症候群

プログラミングをすると、誰でもときに自分の能力や実績を自分で認められず、自己評価が異常に低い心理状態になることがあります。
スタンフォード大学のコンピュータサイエンス修士のエンジニアでもこう感じる時があるそうです。
すべてを知っている必要はないのです。そんな人はいません。
謙虚な姿勢を保ち、分からないことはしつこく学びましょう。継続が重要です。

さらに学ぼう

古典で学ぶ

必読といえるプログラミングの本がいくつかあります。

オンライン授業で学ぶ

邦訳で紹介されており、2022/08/18時点で受講可能なものは以下です。

他にもたくさんネットで公開されています。

ハッカーニュース

最新の技術やトレンドを知るのに役立つプラットフォームです。
スタートアップインキュベーターのYコンビネーターが運営しています。

邦訳では、サービスプロデュース事業を運営するニジボックスのエンジニア向けキュレーションメディア「POSTD」も紹介されています。

次のステップ

メンターを見つけよう

プログラムを学ぶときに難しいことの1つは、よく理解しないままでもいろいろなことができてしまうことです。
そのような問題はメンターによるコードレビューで避けられます。
コードレビューを通じ、プログラミング手順を改善したり、本を推薦したり、未知のプログラミングの概念を教えてくれたりします。

本質を探る努力をしよう

プログラミングを始めた時は全てのものがブラックボックス(使い方はわかるけど、どのように動いているかを理解していない事柄)でしょう。
プログラミング上達の1つの方法は、目に留まるあらゆるブラックボックスを開けて、どう動くかを理解してみることです。
ブラックボックスを開けることが、本質を探ることにつながります。
1つの答えだけで終わるのではなく、全ての説明を読むようにしましょう。
インターネット掲示板やチャットを利用して質問したり、別の意見を読むようにしましょう。
理解を深めたい事柄を実際に作ってみることも、本質を探る方法です。
例えば、シンプルなバージョン管理システムを時間をかけて自分で作ることは、十分に投資する価値があります。

アドバイスを得よう

良いプログラマーになるためには、プログラミング以外のことをする、という議論もあります。
邦訳では、次の本が参考になるとのことです。

また、他の人のコードを読むことにできるだけ多くの時間を費やしてください。
プログラミングを学ぶときは、コードを書くことと読むことのバランスをとりましょう。
最初は難しいことかもしれませんが、重要なことです。
他のプログラマーから学ぶことはとても多いです。

補章:訳者による独学に役立つ情報

Python関連の書籍やサイトの紹介を取り上げます。
ぜひ利用してみましょう。
ここで取り上げたもの以外の書籍やサイトも邦訳では紹介されています。

おわりに

プロのエンジニアになりたい方が、そのためのロードマップや心構えを知るのに向いている本だと感じました。
海外(アメリカ)のエンジニアが書かれている本なので、海外事情に興味のある方にも良いと思います。

106
122
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
106
122

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?