ホームページ  >  記事  >  開発ツール  >  VSCode のエンジニアリング上のハイライトは何ですか?

VSCode のエンジニアリング上のハイライトは何ですか?

青灯夜游
青灯夜游転載
2019-11-27 15:08:472658ブラウズ

VSCode のエンジニアリング上のハイライトは何ですか?

VSCode (Visual Studio Code) は近年爆発的な成長を遂げており、大部分の開発者のツール ライブラリに不可欠な成果物となっています。オープンソース プロジェクトとして、数え切れないほどのサードパーティ開発者やエンド ユーザーも魅了され、トップ オープン ソース プロジェクトの 1 つになりました。機能的にも便利で、体感的にも使いやすく、豊富なプラグインでシンプルかつスムーズに動作する点は、本当に賞賛に値します。

私は VS Code ユーザーであり、そのプラグインも開発しています。プラグイン マーケットの Java プラグイン の多くは、基本的に私たちのチームの作品です。エンジニアリングにおける VS Code のハイライトについて、以下で 1 つずつ説明します。

全体にわたる簡潔で焦点を絞った製品の位置付け

VS Code の開発チームは小規模であることをご存知ですか?信じられません。誰もが VS Code が全能であると考えています。なぜ、これほど少数の人がこのような強力なツールを作成できるのでしょうか?実際、特定のプログラミング言語やテクノロジの機能のほとんどはサードパーティのプラグインによって提供されているため、機能が豊富であるということは美しい幻想であり、VS Code のコアは常に非常に合理化されており、製品チームの能力が試されています。 :やりすぎると肥大化する、人手が足りない、仕事が少なすぎる、弱すぎる、誰も使えない。彼らのチームは、コア機能の開発に焦点を当て、ユーザーにシンプルでスムーズなエクスペリエンスを提供し、このアイデアを製品開発のあらゆる側面で実行することを選択しました。私の意見では、これが最初のハイライトです。

最初のハイライトは難しさでもあります。なぜなら、「シンプルさ」は最終的には製品の「形式」であり、より重要な問題は実際には前提条件となる問題、つまり製品の位置付けとそれが解決する問題だからです。この質問をユーザーの観点から見ると、次の点に変換できます。なぜ新しいツールが必要なのか?コードエディター (Editor) ですか、それとも統合開発環境 (IDE) ですか?プロジェクト リーダーの発言を見てみましょう:

ビデオ アドレス: https://www.youtube.com/watch?v=Vs3AGfeuNKU

VSCode のエンジニアリング上のハイライトは何ですか?#(ビデオのスクリーンショット - Erich が詳しく説明VS Code の位置づけ: エディター コードの理解とデバッグ)

ビデオを見ることができない学生のために、VS Code の位置づけ: エディター コードの理解とデバッグを説明しているこのスクリーンショットをご覧ください。これは、開発者が「最もよく使用する」機能に重点を置きながら、製品の形をシンプルかつ効率的にするよう努めた、非常に抑制されたバランスのとれた選択です。結果から判断すると、このポジショニングはかなり成功しています。

この位置付けの指針に基づいて、これらのエンジニアは VS Code を作成しました。比較的小規模な機能セットにより、開発者はコード品質の向上に努めることができ、エンド ユーザーも優れたパフォーマンスのツールを手に入れることができます。これが、VS Code が他のエディターよりも優れている重要な理由です。優れた点については、VS Code で Text Buffer を再実装するプロセスを記録し、思考プロセスも共有している

このブログ投稿 を参照してください。製品の位置付けとチームの責任が高度に制御されているからこそ、チーム メンバーはそのような問題に時間を費やし、テストに耐えられるコードを書くことができます。

同時に、チームが小さいことで、チーム メンバーが行動レベルで均一な行動を達成できるようになります。これは特にコミュニティの交流において顕著です。

GitHub にアクセスして問題を確認できます 、製品のポジショニングの範囲を超えたリクエストやフィードバックは、基本的に拒否されるか、サードパーティのプラグイン プロジェクトに転送されるため、非常に集中的であると言えます。

これを見ると、すべてがうまくいっているように見えますが、ここで問題が発生します。プログラマは何千人もいます。あなたは Node を使用し、私は Go を使用します。あなたはフロントエンドを担当し、私はバックエンドを担当します。方法VS Code はこれらのさまざまなニーズを満たしていますか?あなたは賢いので、すでに答えています - 大量のプラグイン。それでは、VS Code が巨大なプラグイン エコシステムをどのように運用しているかを詳しく見てみましょう。

プロセス分離のプラグイン モデル

プラグインを通じて機能を拡張するのは一般的ですが、プラグインがネイティブ機能と同等であることを確認する方法?歴史が教えてくれますが、保証はありません。 Eclipseを参照すると、プラグインモデルは機能レベルでは非常に完成度が高く万能と言えますが、不安定性、使いにくさ、遅さなどの厄介な問題がいくつかあるため、多くのユーザーがIntelliJに乗り換えています。成功もプラグインであり、失敗もプラグインであると言えます。問題の本質は情報の非対称性にあり、それにより、異なるチームが作成したコードのアイデアや品質の点で一貫性がなくなるのです。最終的に、ユーザーは厄介で遅延の多い製品を手に入れることになります。したがって、プラグインをネイティブ機能と統合することは、安定性、速度、操作性の点で望ましいことです。

他の IDE がどのように機能するかを見てみましょう。Visual Studio はすべての機能を単独で処理し、他の IDE が何もすることがないほどうまく機能します。このため、Visual Studio は「業界で No. 1 IDE」としても知られています。 IntelliJ と IntelliJ 同様に、箱から出してすぐに動作し、プラグインはオプションです。すべてを自分で行うのは良い方法のように思えますが、Visual Studio の背後には大規模なエンジニアリング チームがあることをご存知ですか? 明らかに、これは VS Code のような少数の人ができることではありません。彼らは誰もがプラグインを作成できるようにすることを選択しました。それでは、Eclipse が遭遇する問題をどのように解決するのでしょうか?

ここで少し知識を共有します。Eclipse のコア部分の開発者は、初期の VS Code チームです。そうですね、彼らは同じ川に二度入ることはありませんでした。 Eclipse とは異なり、VS Code はプラグインをボックスに入れることを選択します。

これによって解決される最初の問題は安定性であり、これは VS Code にとって特に重要です。 VS Code が Electron に基づいていることは誰もが知っていますが、これは基本的に単一スレッドを備えた Node.js 環境であり、コードがクラッシュすると壊滅的な結果をもたらします。したがって、VS Code は単純に誰も信頼せず、プラグインを別のプロセスに配置し、メイン プログラムが正常である間、それらをいじることができます。

VSCode のエンジニアリング上のハイライトは何ですか?
メインプロセスからのプラグインの分離

VSCode チームのこの決定には理由がないわけではありません。前述したように、チームの多くの人々は実際に元プロセスです。当然のことながら、私は Eclipse のプラグイン モデルについて深く考えています。 Eclipse の設計目標の 1 つは、コンポーネント化を極限まで推し進めることであり、多くのコア機能がプラグインの形式で実装されています。残念なことに、Eclipse プラグインはメイン プロセスで実行されます。プラグインのパフォーマンスの低下や不安定性は Eclipse に直接影響します。その結果、Eclipse が肥大化し、遅く、不安定であると誰もが不満を抱くことになります。 VS Code はプロセスに基づいて物理レベルの分離を実現し、この問題を首尾よく解決します。実際、プロセス レベルの分離では、インターフェイスとビジネス ロジックの分離という別のトピックも生じます。

UI レンダリングとビジネス ロジックの分離、一貫したユーザー エクスペリエンス

「不安定」の次の問題は「使いにくい」ことであり、特に混乱を招くインターフェースとプロセス、その理由は、プラグイン間のインターフェース言語の「不一致」です。これにより、学習曲線が非常に急になり、問題に直面したときに統一された解決策が得られなくなります。 VS Code のアプローチは、プラグインに新しいインターフェイスを「発明」する機会を与えることではありません。

上に示したように、プラグインは拡張ホスト プロセスにロックされ、UI はメイン プロセスにあるため、当然ながらプラグインはユーザー インターフェイスを直接操作できません。 VS Code はすべてのユーザー インタラクション ポータルを管理し、インタラクション標準を策定します。すべてのユーザー操作はさまざまなリクエストに変換され、プラグインに送信されます。プラグインができることは、これらのリクエストに応答し、ビジネス ロジックに重点を置くことだけです。しかし、最初から最後まで、プラグインはインターフェイス要素 (色、フォントなど) のレンダリング方法を「決定」したり「影響を与えたり」することはできません。ポップアップ ダイアログ ボックスに関してはさらに不可能です。

VS Code のユーザー インターフェイスの制御は非常に慎重であると言えます。プラグインを作成したことのある人なら誰でも理解できるでしょう。興味のある学生は、TreeView の歴史をさらに深く掘り下げて、より直感的なエクスペリエンスを得ることができます。一見すると、サードパーティの開発者は行き詰まっているように見えますが、これは全員の創造性を制限していませんか?私が言いたいのは、このアプローチはチームの背景と密接に関係しており、別のグループの人々が失敗する可能性が非常に高いということです。成功の理由は、チームが長年開発ツールの分野に深く関わってきたためであり、その経験を意見に変換し、最終的に VS Code のインターフェイス要素とインタラクティブ言語に実装したからです。 、とても人気があります。

インターフェイスとビジネス ロジックを完全に分離することで、すべてのプラグインが一貫した動作を行うことができ、ユーザーは均一なエクスペリエンスを得ることができます。それだけでなく、インターフェイスと動作レベルでのこの一貫性は、最終的には別の「優れた」機能である リモート開発 に形を変えました。これについては後で説明します。次に、VS Code-Language Server Protocol の別の取り組みについて話したいと思います。

LSP - テキストベースのプロトコル

VS Code の位置付けの上記の 2 つの機能、コードの理解とデバッグですが、そのほとんどはサードパーティのプラグによって提供されます。 ins これを実現するために、中間のブリッジは 2 つの主要なプロトコル、Language Server Protocol(LSP) と Debug Adaptor Protocol(DAP) です。この 2 つは設計の観点から非常に似ていますが、最も人気のある LSP に焦点を当てましょう。まず、なぜ LSP が必要なのでしょうか?

フルスタック開発がこの時代の主流になって久しく、ソフトウェア実務者はますます特定の言語やテクノロジーに制限されなくなり、それが私たちの手にあるダイヤモンドに新たな課題を突きつけています。たとえば、フロントエンドには TypeScript と node.js を使用し、バックエンドの作成には Java を使用します。データ分析には Python を使用することもあります。その場合、おそらく複数のツールの組み合わせが必要になります。これに関する問題は次のとおりです。ツール間でデータ分析を行う必要があるため、頻繁に切り替えることは、システム リソースの消費とユーザー エクスペリエンスの観点から非効率的です。

では、同じワークスペースで 3 つの言語すべてを処理できるツールはあるのでしょうか?そう、それは VS Code です。多言語をサポートする開発環境です。多言語サポートの基礎となるのは Language Server Protocol(LSP) です。このプロトコルはわずか数年で前例のない成功を収め、これまでにマイクロソフトなどの大手メーカーやコミュニティから 百件の実装が行われており、基本的にすべての主流プログラミング言語をカバーしています。同時に、Atom、Vim、Sublime、Emacs、Visual Studio、Eclipse などの他の開発ツールでも採用されており (ここをクリックして完全なリストを表示します)、その優秀性は次の点から証明されています。別の視点。さらに重要なのは、プロトコルが軽量かつ高速であることです。これは VS Code のキラー機能とも言え、Microsoft の最も重要な IP の 1 つでもあります。 。 。すごい、強力で軽量ですが、詐欺のように見えるので、どのように機能するかを見てみましょう。

最初の焦点: 1. 適度なデザイン 2. 合理的な抽象化 2. 徹底した詳細。

最初に

デザイン (デザイン) について話しましょう。大規模で包括的なものであることは非常に一般的な問題です。すべてのプログラミング言語をサポートするものを設計するように頼まれた場合、私の最初の反応はおそらく、すべての言語機能をカバーする スーパーセット を作成することでしょう。 Microsoft は、C# および VB.NET コンパイラのベースとなる言語中立のコンパイラである Roslyn など、そのような試みを行っています。 C# が言語機能の点で非常に豊富であることは誰もが知っていますが、C# をサポートする Roslyn の能力はその威力を示しています。そこで問題は、なぜそれがコミュニティで広く使用されないのかということです。私は、根本的な理由は「権力」の副作用、つまり複雑さと主観性(独断的)にあると考えています。構文ツリーだけでもすでに非常に複雑ですが、その他のさまざまな機能とそれらの関係はさらに複雑で、一般の開発者が簡単にこのような巨大なものに触れることはできません。

対照的に、LSP は明らかにコンパクトさを設計目標の 1 つと考えており、チームの一貫したモデレーション スタイルを実装する

最小サブセット を作成することを選択しました。ユーザーがコードを編集するときに最も頻繁に扱う物理的なエンティティ (ファイル、ディレクトリなど) と状態 (カーソル位置) を考慮します。言語の特性をまったく理解しようとはせず、コンパイルも気にしていないため、当然構文ツリーなどの複雑な概念も扱いません。これは 1 つのステップで完了するのではなく、VS Code 関数を繰り返すことで徐々に開発されます。そのため、誕生以来、小規模なサイズを維持し、理解しやすく、導入の敷居が低く、すぐにコミュニティで幅広い支持を得て、さまざまな言語の Language Server (LS) が開花しました。どこにでも。

Small は小さいですが、機能が欠けているわけにはいかないため、

Abstract は非常に重要です。 LSP の最も重要な概念はアクションとロケーションであり、LSP のリクエストのほとんどは「指定された場所で指定されたアクションを実行する」ということを表現します。たとえば、ユーザーはクラス名の上にマウスを置くと、関連する定義やドキュメントが表示されます。この時点で、VS Code は 'textDocument/hover' リクエストを LS に送信します。このリクエストの最も重要な情報は、現在のドキュメントとカーソルの位置です。 LS はリクエストを受信すると、一連の内部計算 (カーソル位置に対応するシンボルの特定と関連ドキュメントの検索) を実行して関連情報を見つけ出し、それをユーザーに表示するために VS Code に送り返します。このやり取りをLSPでは要求(Request)と応答(Response)に抽象化し、その仕様(スキーマ)もLSPで規定されています。開発者の観点から見ると、概念はほとんどなく、対話形式は非常にシンプルで、実装は非常に簡単です。

これを見れば、誰もが LSP についてよりよく理解できるはずです。本質的に、LSP はさまざまな言語の VS Code と LS を結び付ける接着剤です。しかし、それは普通の接着剤ではなく、非常に味のある接着剤であり、その味は細部に反映されています。

まず第一に、これはテキストベースのプロトコルであるため、テキストによって理解とデバッグの難しさが軽減されます。 HTTP や REST の成功を例に挙げると、これがバイナリ プロトコルだったらどうなるかを想像するのは難しく、同じテキスト プロトコルである SOAP ですらすでに消滅しており、構築における「シンプルさ」の重要性を示しています。開発者のエコシステム。

第二に、これは JSON に基づいたプロトコルです。JSON は最も読みやすい構造化データ形式であると言えます。各コード ウェアハウスの構成形式を見れば、それが正しい判断であることがわかります。今でも新しいプロジェクトで XML を使用している人はいますか?繰り返しますが、「シンプル」です。

繰り返しますが、これは JSONRPC に基づくプロトコルです。JSON の人気により、すべての主要な言語が JSON をサポートしているため、開発者はシリアル化や逆シリアル化などの問題に対処する必要がありません。これは実装レベルでは「単純」です。

これらのことからも、VS Code チームは今日の技術トレンドを非常に正確に把握しており、「分かりやすさ」を十分に考慮した意思決定がコミュニティ開発者の心をしっかりと掴んでいることが分かります。重要なことは 3 回言います:

デザインするときはシンプルになる傾向があります。

デザインするときは、シンプルにする傾向があります。

デザインするときは、シンプルにする傾向があります。

統合リモート開発

今年 5 月、VS Code は リモート開発 (VSCRD) をリリースしました。環境内の VS Code ワークスペース (仮想マシン、コンテナーなど)、ローカル VS Code を使用して作業に接続します。次の図は、その動作モードを示しています:

VSCode のエンジニアリング上のハイライトは何ですか?

VSCRD本質的にリモート開発エクスペリエンスが向上します。一般的に使用されている リモート デスクトップ共有 と比較して、具体的な改善点は次のとおりです:

  1. 高速応答: VSCRD とのすべての対話が可能です。ローカル UI で完了し、迅速に応答します。リモート デスクトップはスクリーンショットを送信するため、データの往復遅延が非常に大きく、遅延が発生するのが常です。

  2. ローカル設定に従ってください。 VSCRD の UI はローカルで実行され、すべてのローカル設定に準拠しているため、使い慣れたショートカット キー、レイアウト、フォントを引き続き使用でき、作業効率のオーバーヘッドを回避できます

  3. 小規模なデータ送信オーバーヘッド: リモート デスクトップの送信はビデオ データですが、VS Code の送信は操作のリクエストと応答です。オーバーヘッドはコマンド ラインと同様であり、遅延状況はさらに改善されます

  4. 3 番目-パーティ プラグインが利用可能: リモート ワークスペースでは、VS Code のネイティブ機能が利用できるだけでなく、すべてのサードパーティ プラグインの機能も引き続き利用できます。リモート デスクトップの場合は、それらを 1 つずつインストールする必要があります

  5. リモート ファイル システムが利用可能です: リモート ファイル システムはローカルで完全にマップされています。この 2 つはほぼ同じです。

それでは、魔法のような操作が行われます。 VSCRDは上記の効果を達成するために何をするのでしょうか?そのアーキテクチャ図を見てみましょう:

VSCode のエンジニアリング上のハイライトは何ですか?

実際、答えはすべて前の記事で述べられています:

  1. プロセス-レベル分離プラグイン モデル

    拡張ホスト (つまり、図の VS Code サーバー) はメイン プログラムから物理的に分離されているため、拡張ホストをリモートで実行するかローカルで実行するかに本質的な違いはありません。

  2. UI レンダリングとプラグイン ロジックの分離、均一なプラグイン動作

    すべてのプラグイン UI は VS Code によって均一にレンダリングされるため、純粋なプラグイン UI のみが存在します。ビジネス ロジックがプラグインに組み込まれており、動作が高度に統一されているため、どこで実行しても使用できます。主要なプロトコル LSP と

    DAP
  3. は非常に合理化されており、ネットワーク遅延が高い状況に自然に適しており、リモート開発に最適です
  4. VS Code チームのアーキテクチャに関する決定は、間違いなく非常に優れています。先進的でありながら、細部への洞察力も完璧です。そういったエンジニアリングの基盤がしっかりしていたからこそ、VSCRDのような機能が生まれたので、これは傑作だと思います。 VSCRD をまだ試したことがない人のために、簡単なヒントを示します。これは次のシナリオで非常に役立ちます:

開発環境の構成は非常に面倒です。モノのインターネット開発など、さまざまなツールやプラグインを自分でインストールして設定する必要があります。 VSCRD では、リモート ワークスペース テンプレートで十分ですが、追加のツールをインストールする必要がある場合、つまり Dockerfile を変更する必要がある場合は、非常に簡単です。

ここでは、一般的に使用されるプログラミング言語とシナリオのテンプレートを見つけることができます

  1. ローカル マシンは弱すぎるため、機械学習などの特定の開発には使用できません。大量のデータとコンピューティング要件には、非常に優れたマシンが必要です。 VSCRD では、リモート ファイル システムを直接操作し、リモート コンピューティング リソースを使用できます。 ###############やっと######

    VS Code はまばゆいばかりの星のようなもので、何千人もの開発者を惹きつけて貢献します。 VS Code の成功から、私たちは優れた設計とエンジニアリングの実践がどれほど多くの奇跡を生み出すことができるかを知ってきました。ソフトウェア業界に目を向けると、あらゆるレベルのモデルが常に更新されており、これは刺激的なことですが、実務者は継続的にスキルを向上させる必要もあります。個人学習の観点から、これらのモデルの誕生の原因と結果を理解し、エンジニアリング実践における意思決定プロセスを理解することは、エンジニアリング能力の向上に非常に役立ちます。

    推奨チュートリアル: vscode チュートリアル

以上がVSCode のエンジニアリング上のハイライトは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はzhihu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。