6
10

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 2020-12-29

あらすじ

ある程度知見がたまってきたのでアウトプットします。

7年前の自分が見たら「お目目がキラキラする」ツールをまとめました。

AWS,GCP,Azure

クラウドコンピューティングの3強です。
現代のエンジニアはこれが使えて当たり前といっても過言ではありません。

image.pngimage.pngimage.png

現実世界でリアルの機材を購入するのと比べてたくさんサボれます。
現在人がクラウドコンピューティングでサクッと用意するものを、
お家や企業内のオンプレミスで用意しようとしたら、お金も時間も場所も必要です。
サボリーマンにはなくてはならないツールですね。

クラウドコンピューティングの登場により、お金がない学生たちや、
駆け出しフリーランスなどにも優しい世の中になりました。
このハードル低下により、門戸が広がったのではないでしょうか。

モジュールバンドラー

Webpack

https://webpack.js.org/
名前の通りWeb系のツールです。
プロジェクトが必要とするすべての静的モジュールをバンドルします。
C系の言語でいうコンパイラに近いものです。
image.png

jsモジュールをはじめ、Sassや、jpegなどでさえバンドルできてしまいます。
そのために、webpackでは、

  • angular, react, vue
  • sass, less
  • pug
  • gulp
  • browsify
  • typescript, babel, coffeescript
  • eslint

など様々なものをローダーモジュールとして扱うことができます。
もはや何でもありです。
そういう意味で、他の様々なツールの頂点に君臨します。

1ファイルにバンドルできるので、
ユーザーがページを読み込むときのファイルごとのオーバヘッドを減らせます。
Webの高速化には必須です。

このwebpackにより、いろんなツールを統合的に操ることができます。
いろんなツールあって管理をサボりたい人には特におすすめです。

webpack入門 | さくらのナレッジ
webpack入門 | ICS MEDIA

※2023年7月現在では筆者はvitevitestvoltaの環境を推します。
webpackで出来てviteに出来ないことは無さそうなので、速度の速いviteを使っています。

Linter,Formater,Refactorer

C# Linter,Formater,Refactorer

Web系では「Prettier」がおすすめです。

lang Formater Linter Refactorer
C# Resharper StyleCop Resharper
js Prettier eslint Prettier
python black pylint rope
python black pylint rope

「インテリセンス→フォーマッター→リンター→テスト→ランタイムデバッグ→ビルド」って順番かなと思ってます。

ペアプログラミング用ツール

LiveShare

https://visualstudio.microsoft.com/ja/services/live-share/
OSを問わず、vscodeでもvsでも、インターネット越しに複数人で一つのデバッグ画面を眺めることが出来ます。もちろん編集もできます。
image.png

ペアプログラミングを行って、自分より上級なエンジニアの手ほどきを受けたり、眺めたりすると素早く上達できそうです。また、自分なりに教えてみるのも勉強になります。

バージョン管理ツール

GitHub

image.png

Gitというソフトを使ってバージョンを管理することができるサービスです。
ここではコミットという単語が非常に多く使われます。
他にもGitBucketやGitLabなどがあります。
他の人と共同で作業するときに真価が発揮されます。もちろん一人でも使うと便利です。

Githubでは単なるバージョン管理ツールという枠を超えて、Issue Drivenなプロジェクト管理を行ったりすることもできたりします。
WikiやReadmeページ、GithubPagesなどを使って、アプリケーションのホームページとしてリポジトリページを公開したりすることもできます。

計画管理的な思考が身についたり、公に公開するという気概も生まれるので使ったほうがいいと思います。

また、Gitではない管理方法として、mercurial や subversion があります。Gitがすべてではない、ということを知るのは非常に重要です。gitとmercurial、subversion が選択できる、githubみたいなウェブサービスはないのでしょうか?

アプリケーション管理ツール

Chocolatey, Homebrew, Snapcraft

image.pngimage.png

世界シェアが分かる

(https://chocolatey.org/packages)で検索すると、
世界中でいろんな人がどのくらいそのアプリを使っているのかが分かります。
例えば、「JRE」で検索すると、「OpenJDKは1500回くらいダウンロードされているけど、AdoptOpenJDKは540回くらいか」という数字が見えてきます。ほかにもTrendsなどで見る方法がありますが、これは実際の利用数にとても近いと言えます。(もちろん企業ユーザーは社内HUBサーバーがあるので実際の値よりも少なめかと思います。)
image.png

インストールが爆速

アプリケーションインストールを行う時のブラウザ操作をかなりサボれます。
パッケージ名を覚えていると
「思い立ったら秒でアプリをインストール」できます。

例えば、windowsでvscodeをインストールしたい場合。

通常のインストール手順

  1. 「Windows」キー
  2. chromeと入力して「Enter」キー
  3. 「Ctrl」+「e」してアドレスバーにカーソル移動
  4. vscodeと入力して「Enter」キー
  5. ウェブページタイトルをクリック
  6. ダウンロードボタンをクリック
  7. ダウンロードしたインストーラーをダブルクリック
  8. UAC画面で管理者権限に昇格
  9. 次へボタンを押す
  10. 利用許諾を承認
  11. インストールを開始ボタンをクリック

Chocolateyを利用したインストール手順

  1. 「Windows」キーでスタートメニュー
  2. powershellと検索して「Ctrl」+「Enter」キー
  3. choco install vscode -yと入力して「Enter」キー
  4. refreshenvと入力して「enter」キーです。

次にMacでvscodeをインストールしたい場合。

Homebrewを利用したインストール手順

  1. 「command」+「space」キーでスポットライト検索を起動
  2. termと検索して「Enter」キー
  3. brew cask install visual-studio-codeと入力して「Enter」キー

とても短い手順になりますね。

DB管理ツール

DBeaver

  • DBに関しての万能ツールです。ほぼ何でもできます。最強。
  • クロスプラットフォーム対応でどこでも使える
    • Windows
    • Mac
    • Linux
  • 思いつくデータベースはたいてい使える
    image.png

これを眺めているだけでいろんなデータベースが使える気になってきます。
「このデータベースなんだろ?」って気になるのもいいところですね。

仮想化

QEMU

かなり低レイヤーのハードウェアから仮想化してくれるっぽいです。
ゲームキューブとか携帯ゲーム機でLinux走らせたり、ラズピコでゲームソフト走らせたりしてる人や、OS自作してる人が好んで使っている印象です。

k8s

Kubernates。Wikiにもある通り、サイバネティクス(Cybernetics)の語源であるギリシャ語の操舵手(κυβερνήτης)を英語表記にしたものです。
Systemctlで管理するようなサービスを、DockerであればON・OFFするだけのところ、Kubernetesであればタイミングや個数管理やサイズ管理など様々できます。

HashiCorpのツール群

https://www.creationline.com/hashicorp
image.png
上記のクラウドコンピューティング3強を全部混ぜて使うときや、AWSで構築するけど後で簡単にGCPに移行できるようにしておきたいときなどに効果を真価を発揮します。

興味、まずはvagrantでvirtualboxを動かしてみるのがいいかもしれませんね。

OpenStack

http://openstack.org/
HashiCorpと何が違うのか分かりにくいですが、
こちらもクラウドコンピューティングのためのフリーソフト群です。
AWSを使うのではなく、AWSを作りたいときに使ったりします。
image.png

情報収集発信ツール

人に聞いたり、教えたりすると、情報が集まってきやすいです。
むしろそうしないと独善的になりがちです。
積極的にコミュニケーションをとって、
自分の思考をアップデートしていきたいです。

また、自分で考えると時間が足りないことを、
他の人に考えてもらって自分はサボります。

具体的には、

  • 日本のブログ制作サイト→はてなブログ
    • エンジニアに特化→Qiita
  • 日本のQ&Aサイト→Yahoo!知恵袋
    • エンジニアに特化→Teratail
  • 日本の動画発信者のためのサイト→ニコニコ動画
    • エンジニアに特化→まだない

みたいな感じですね。

Qiita

ここです。
日本のエンジニアが集うブログ系SNSとして最大級のサービスです。

Teratail

image.png

Teratailは日本のエンジニアが集うQ&A系のサービスです。
強みは回答率が高いことです。しかし回答率を求めすぎたためか、回答の質が微妙な気がします。
(2020/11/03現在の回答率 88%)

Stackoverflow

image.png
image.png

超大規模なQ&Aサイト「StackExchange」の子供です。子供たちの中でも、ひときわ大きいのが、プログラマー向けの「Stackoverflow」です。

ユーザー数の多さから見て、英語で質問したほうがいいです。

英語慣れするために、SNSはRedditを使うのもありだと思います。

エディター

VSCode

image.png
homepage : https://code.visualstudio.com/
repository : https://github.com/Microsoft/vscode/
image.png

近年、vscodeに勝るエディターはないと言って差し支えないでしょう。
その軽量さゆえに、早く案件を片付けてサボりたい私にはピッタリです。
愛用しております。

文句なしに最強のエディターです。特にスクリプト系のエディターとして優れています。
C#やJAVAのようなコンパイルが必要な言語では、専用のIDEを用いたほうが賢明な場合があります。

というのも、リソースの使用率など高度なデバッグをVScodeで行うには、設定が難解なためです。

拡張機能が豊富というのも売りですが、その多くは有志によるものです。
出来る限り公式がサポートしている拡張機能だけを利用したほうがバグに悩まなくて済みます。

競合はeclipsesublimexcodeatomなど。

VisualStudioとVisualStudioCodeの使い分けは難しいです。
初心者にはどちらでも大差ありませんので、モチベーションが落ちないためにも軽量なVSCodeをオススメします。
VisualStudioは多すぎる機能に混乱し、VisualStudioCodeは多すぎる拡張機能に混乱することでしょう。
ただし、GUIアプリケーションを制作する場合に限りIDEがおすすめです。

GUIでもUnityでスマホ向けの開発をするときなどはVisualStudioCodeです。
なぜなら、この場合にはUnityでコンパイルするので、エディターには高度なデバッグ機能が求められないからです。

Neovim(Vim)

※2023年7月追記

VSCodeがコードエディターのシェアをほぼ独占してから普及し始めたCUIエディターです。

「GUIのVSCodeが市場で一人勝ちしている中で、どうして今更CUIのエディターなのか?」という問いに全てが詰まっている気がします。

VSCodeにある程度慣れてくると、ショートカットキーを多用することになると思います。
そうなってくる頃には、キーボード・マウス間の持ち替えの発生が煩わしくなってくるでしょう。
その究極系がVim系エディターであり、ブラインドタッチのホームポジションから手を動かす必要が無くなります。

Vimに慣れても、3DCG・CAD・2DCGを扱う場合はマウスが引き続き必要ですが、それ以外では必要なくなります。TUIやCLIツールと呼ばれるものを欲するような思考に切り替わっていくと思います。

VSCodeのキーバインドをNeovimにすることもできます。

この追記もNeovimを使って書きました。

JetBrainsによるツール群

Android OS 用 の公式言語「kotlin」を開発していることでも有名な企業「JetBrains」が提供するツール群です。
image.png

包括しているツールは、Rider・PhpStorm・PyCharm・WebStorm・CLion・RubyMine・GoLand・IntelliJ など。
ツール群の名前がかっこよすぎです。それだけでも使いたくなります。

ただし、有料です。オープンソースプロジェクトに対しては無償提供されたりもするそうです。
また、多くのブログで、有料の価値があるとの紹介が行われているのも特徴的です。
「レベルが高い人はこういうツールを使うんだな」と知ることに価値があります。

まとめ

がんばれ過去の自分!
そして今の自分!

6
10
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
6
10

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?