Visual C++ IntelliSense の機能

IntelliSense は、コード作成をより便利にするための一連の機能に与えられた名前です。 C++ 用の IntelliSense は、スタンドアロン ファイルおよび C++ プロジェクトの一部を成すファイルで使用することができます。 クロスプラットフォーム プロジェクトでは、いくつかの IntelliSense 機能が、Android や iOS のコンテキスト内にいるときでも共有コード プロジェクト内の .cpp および .c ファイルで使用できます。

この記事では、C++ IntelliSense 機能の概要について説明します。 IntelliSense 用にプロジェクトを構成する方法、および問題をトラブルシューティングする方法については、「IntelliSense の C++ プロジェクトを構成する」をご覧ください。

C++ の IntelliSense 機能

IntelliSense は、コード作成をより便利にするための一連の機能に与えられた名前です。 便利さについては、人によって考え方が違うので、ほぼすべての IntelliSense 機能を [テキスト エディター]>[C/C++]>[詳細][オプション] ダイアログボックスで有効または無効にできます。 [オプション] ダイアログ ボックスは、メニュー バーの [ツール] メニューから使用できます。

Tool Options dialog box

次の画像のメニュー項目とキーボード ショートカットを使用すると、IntelliSense にアクセスできます。

IntelliSense menu

ステートメント入力候補およびメンバーの一覧

キーワード、型、関数、変数名、またはコンパイラが認識するその他のプログラム要素の入力を開始すると、エディターがワードの入力候補を提供します。

Visual C++ Complete Word window

メンバーの一覧を最初に起動するときに、現在のコンテキストにアクセス可能であるメンバーだけが表示されます。 その後 Ctrl+J キーを押すと、アクセシビリティにかかわらず、すべてのメンバーが表示されます。 3 回目に実行すると、プログラム要素のより多くの一覧が表示されます。 [テキスト エディター]>[C/C++]>[ 全般]>[自動メンバー表示][オプション] ダイアログ ボックスでメンバーの一覧をオフに切り替えることができます。

Visual C++ Member List

パラメーターのヘルプ

関数呼び出しで左中かっこを入力するか、クラス テンプレートの変数宣言で山かっこを入力すると、エディターは関数またはコンストラクターの各オーバーロードのパラメーターの型を含む小さいウィンドウを表示します。 カーソルの場所に基づく "現在" のパラメーターは、太字で表示されます。 [テキスト エディター]>[C/C++]>[全般]>[パラメーター情報][オプション] ダイアログ ボックスでパラメーター情報をオフにすることができます。

Visual C++ Parameter Help

クイック ヒント

変数の上にマウス カーソルを移動すると、小さなウィンドウがインラインで表示され、型の情報と型が定義されているヘッダーが表示されます。 関数のシグネチャを表示するには、関数呼び出しの上にカーソルを置きます。 [テキスト エディター]>[C/C++]>[詳細]>[自動クイック ヒント][オプション]ダイアログ ボックスでクイック ヒントをオフにすることができます。

Visual C++ QuickInfo

エラーの波線

プログラム要素 (変数、キーワード、中かっこ、型名など) の下の波線は、コード内のエラーや潜在的なエラーに注意を引くためのものです。 まだ実装を記述する必要があることを通知するために、事前宣言を記述するときに、緑の波線が表示されます。 Windows のコンテキストで作業しているものの、Android のコンテキストではエラーになる内容を入力するなど、現在アクティブでないコードにエラーがある場合、共有プロジェクトに紫の波線が表示されます。 赤の波線は、コンパイラ エラーまたは警告が現在のコードにあり、対処する必要があることを示します。

Visual C++ error squiggles

コードの色付けとフォント

[環境]>[フォントおよび色][オプション] ダイアログ ボックスで既定の色とフォントを変更することができます。 ここでは、エディターだけでなく、多数の UI ウィンドウのフォントを変更することができます。 C++ に固有の設定は "C++" で始まり、その他の設定はすべての言語で利用できます。

クロスプラットフォームの IntelliSense

共有コード プロジェクトでは、Android のコンテキストを使用している場合でも、波線などのいくつかの IntelliSense 機能を使用できます。 非アクティブなプロジェクトでエラーになるいくつかのコードを記述すると、IntelliSense が波線を表示しますが、現在のコンテキストでのエラーの波線とは色が異なります。

Android や iOS 用にビルドするように構成されている OpenGLES アプリケーションを検討してみましょう。 この図は編集中の共有コードを示します。 この図では、アクティブなプロジェクトは iOS.StaticLibrary です。

iOS is selected as the active project.

次に注意してください。

  • __ANDROID__ が iOS プロジェクトに対して定義されていないため、6 行目の #ifdef 分岐は淡色表示で非アクティブ領域として表示されています。

  • 11 行目のあいさつの変数は、HELLO 識別子で初期化され、赤の波線で表示されています。 これは現在アクティブな iOS プロジェクトに、HELLO 識別子が定義されていないためです。

  • 12 行目の BYE 識別子は、(現在) 非アクティブな Android.NativeActivity プロジェクトでは定義されていないため、紫の波線で表示されています。 この行は、iOS がアクティブなプロジェクトの場合にはコンパイルされますが、Android がアクティブなプロジェクトの場合にはコンパイルされません。 これは共有コードのため、現在アクティブな構成でコンパイルする場合でも、コードを修正する必要があります。

アクティブなプロジェクトを Android に変更すると、波線は次のように変化します。

  • __ANDROID__ が Android プロジェクトに対して定義されているため、8 行目の #else 分岐は淡色表示で非アクティブ領域として表示されています。

  • 11 行目のあいさつの変数は HELLO 識別子で初期化され、紫の波線で表示されています。 これは現在アクティブではない iOS プロジェクトに、HELLO 識別子が定義されていないためです。

  • 12 行目の BYE 識別子は、アクティブなプロジェクトで定義されていないため、赤の波線で表示されています。

スタンドアロン ファイルの IntelliSense

プロジェクトの外部で 1 つのファイルを開いても、やはり IntelliSense を取得します。 [テキスト エディター]>[C/C++]>[詳細設定][オプション] ダイアログ ボックスで特定の IntelliSense 機能を有効または無効にすることができます。 プロジェクトの一部ではない 1 つのファイルに IntelliSense を構成するには、IntelliSense を表示し、非プロジェクト ファイルのセクションを確認します。

Visual C++ single file intellisense

既定では、単一ファイルの IntelliSense は標準のインクルード ディレクトリだけを使用してヘッダー ファイルを検索します。 他にディレクトリを追加するには、次の図に示すとおり、ソリューション ノードのショートカット メニューを開き、[デバッグ ソース ファイル] リストにディレクトリを追加します。

Adding a path to a header file.

検索を有効または無効にする

便利さについては、人によって考え方が違うので、ほぼすべての IntelliSense 機能を [テキスト エディター]>[C/C++]>[詳細][オプション] ダイアログボックスで有効または無効にできます。 [オプション] ダイアログ ボックスは、メニュー バーの [ツール] メニューから使用できます。

Tool Options dialog box