概要
エンジニアとして最低限覚えなければいけないことはたくさんある。
必要な知識は必要になったときに覚えればいいけれど、基礎中の基礎と呼ばれるものはあって、しかも結構量が多い。
ただ未経験の人にとっては自走するにも何が基礎なのか、業務の開発をするのに何の知識がどれくらい必要なのかわからないかと。
なので新卒2年目の僕が思う、身につけておくといい基礎知識をリンクベースで提示します。
朝30分とか決めて、自分のペースで進めていくといいと思います。進めるときは、
- コマンドやショートカット系は普段から意識して使って、さっさと手に馴染ませる
- 知識系はがっちりと理論を覚えるのではなく大枠のイメージを掴む、概念を理解する
- わからないことはそのままにせずメモしておき、後で調べるなり先輩に聞くなりする
の3つを意識すること。
対象読者
- 未経験の新人エンジニア
1. Macの設定や各種基本操作
Macのセットアップ
僕がMacを買い換えてすぐにいれるツール&すぐにする初期設定【2016年9月版】 | dotstudio
上記記事のシステム環境設定のところだけでいい。
ショートカット
Mac のキーボードショートカット - Apple サポート
普段からいかに速くPCを操作できるか意識するといい。
エディタ
【今日から携わる】はじめてのVisual Studio Code入門(オススメの設定・プラグイン・使い方) - Qiita
エディタは色々あるが、僕は開発用はSublime, 各種メモ用にAtomを使用している。
最初は何使っても変わらないので、今人気のVSCodeを使っておけばいい。
ちなみにviというターミナル上で使える標準搭載のエディタは、ある程度使えた方がいい。
サーバーで作業するとき、viしか使えないという状況があるため。
最初はとっつきづらいので、基本的な操作(ファイル編集して、検索できて、保存できる)ができるようになっておけばOK。
ちなみにviを強化したのがvimで、vimを使いこなす人をvimmerと呼ぶ。
エンジニア界ではメモはマークダウンという形式で取られることが多いので、これは使えるようになっておくといい。
2. ターミナルの設定、操作
iterm2
MacのターミナルアプリはiTerm2で決まり!!自分の設定と基本機能 | Webrandum
mac標準のターミナルではなく、強化版のこのアプリを使いましょう。
シェル
シェルってなに?
シェル (shell)とは|「分かりそう」で「分からない」でも「分かった」気になれるIT用語辞典
CPUに命令を伝えるためのものと認識しておけばいい(ざっくり)
macは標準でbashを使用しているが、zshをオススメする。
zshの設定はzshrcに書いてあるので、いい感じにカスタマイズしてる先輩がいたらzshrcを共有してもらうといい。
コマンド操作
上に書いてあるコマンドはすぐに使えるように何回も打つべし。
3. Webの仕組み
ざっくりとWebサイトがどういう風に表示されてるかの仕組みを知っておく。
Webサービスの仕組みを図解。Webサービスの裏側はこうなっている! | Torteo Magazine
HTML5 & CSS3入門第1回〜Webサイトの仕組み〜 - Qiita
この本がオススメ。
Webを支える技術 -HTTP、URI、HTML、そしてREST (WEB+DB PRESS plus) | 山本 陽平 |本 | 通販 | Amazon
余談
現在はSPA(Single Page Application)というJavaScriptを用いて表示を高速化するような技術がメジャーになりつつある。
ゼロから学ぶ! Single Page Applicationの特徴と主なフレームワーク5選 (1/2):モダンなフロントエンド開発者になるためのSPA超入門(1) - @IT
4. Webアプリケーションの構成要素
HTML, CSS
これらは静的なWebページを構成する基本要素。
Mozilla様がすごく良質なドキュメントを用意してくれてる。
HTML: HyperText Markup Language | MDN
情報量が多いので、とりあえず初心者向けのところを読んで大枠理解したら触ってみる。
ネット上で綺麗なサイトを見つけたら右クリックをして 検証(or Inspect)
でソースコードが見れるので、
真似をしたり色々いじってみると面白い。
JavaScript
HTMLで作られたWebページに動きをつけるために使われたり、Webサーバとして使われたり、色々用途がある。
使えると役立つことが多い言語。
高度なトピックをやったり、要素やメソッドを覚えたりしなくてもよくて、
- どういうものか知っておく
- 実際に使うときに調べればすぐ使える状態にしておく
って感じでおk。
CodePen: Online Code Editor and Front End Web Developer Community
このサイトで遊んでみるといい。
Ruby, Ruby on Rails
所謂動的なWebアプリケーションを作成するために必要。様々あるが、2019年現在もよく使われており、比較的初心者も理解しやすいこれらをチョイス。
Rubyはプログラミング言語、Ruby on RailsはRubyを使ったフレームワーク。実際に使ってみるのが一番わかりやすい。
Ruby on Rails チュートリアル:実例を使って Rails を学ぼう
長くて挫折しやすいけれど、無料のチュートリアルとしては良質なのでぜひ頑張って欲しい。
ちなみにRubyそのものもフォローしてくれる。
サクッと全体像を理解したい人は Progate がオススメ(有料)
-
Rubyのドキュメント
オブジェクト指向スクリプト言語 Ruby -
Railsのドキュメント
Railsドキュメント
RailsGuideは役立つ知識が多いので読み物として読んでもいい。
Ruby on Rails ガイド:体系的に Rails を学ぼう
ある程度理解できたらチュートリアルを何周もするんじゃなくて、自分ですごく小さいアプリ作ってみるか業務をゴリゴリやった方が理解が深まると個人的には思います。
DB, SQL
概念と基礎さえ押さえておけばおk。
我らがCTOの中野さんが作ってくれた記事。一読するといい。
5. Git, GitHub
サルでもわかるGit入門 〜バージョン管理を使いこなそう〜【プロジェクト管理ツールBacklog】
個人開発でもチーム開発でもバージョン管理は大切。
最低でも、変更をpush~最新版をpullすることはできるようにしておきましょう。
大枠が理解できたら、細かいコマンドは都度しらべればいいのでサクッと。
6. 情報収集
勉強会
connpass - エンジニアをつなぐIT勉強会支援プラットフォーム
エンジニア向け勉強会のメジャーなサービス。
最初は勉強会出ても何言ってるかわからないことが多いと思うけど、エンジニアの知り合いを作るのは結構大事。
よちよち.rbとか、初心者向けもくもく会とか同じくらいのレベルのエンジニアが集まるコミュニティもある。
興味があるならば勇気をだして参加してみるが吉。
エンジニア向け情報発信サイト
毎日でもみて欲しい
Twitterで有名なエンジニアフォローして眺めてるだけでも結構知ることがある。
Rubyをメインで使ってたり使ってなかったりする企業の技術ブログ
- Mercari Engineering Blog
- クックパッド開発者ブログ
- クラスメソッド発「やってみた」系技術メディア | Developers.IO
- Engineers' Blog | マネーフォワード エンジニアブログ
たまに見ると有益な記事があったりする。
技術書
新卒ソフトウェアエンジニアのための技術書100冊 - クックパッド開発者ブログ
良書ばかり載ってる。
ただ技術書ばっかり読んでもしょうがなくて、実際に自分で考えて手を動かすのが大事。
全く知らない概念とかを体系的に学ぶには技術書が手っ取り早いことが多い。
おまけ
何度も言いますが全部をがっちりと覚える必要はないです。
概念さえ知っていればいくらでも応用がききます。
上記にあげたものが全てというわけではないですし。
気になったことはどんどん自分で調べて深掘りしましょう!
新人のみなさん頑張ってください♪(๑ᴖ◡ᴖ๑)♪