次の方法で共有


Visual Studio 2013 のデバッガーの新機能

目次

Asynchronous Debugging in Windows Store Apps

Just My Code for C++ and JavaScript Debugging

64-bit Edit and Continue for the .NET Framework

Return value inspection for .NET Framework Methods

.NET Framework Memory Analysis with Dump Files

Debug with Debugging Tools for Windows

Code Map Debugging

IntelliTrace Debugging

Windows ストア アプリでの非同期デバッグ

デバッガーでは Windows ランタイムの非同期プログラミング モデルのサポートが強化されています。.NET Framework の言語では、このモデルは async/await キーワード (Visual Basic では Async/Await) を使用して表現されています。C++ と C++/Cx では、このモデルは task オブジェクトと .then 連結文字を使用してサポートされています。さらに JavaScript では、promise オブジェクトと .then 連結文字が使用されます。

  • [呼び出し履歴] ウィンドウでは、非同期関数を呼び出すメソッドが [Async Call] 情報フレームに表示されます。

  • [タスク] ウィンドウ (以前の [並列タスク] ウィンドウ) には、新しいモデルがタスクとして表示され、タスクに関するより詳細な情報も示されます。「[タスク] ウィンドウの使用」を参照してください。

  • C++ の Windows ストア アプリに関するより詳細な例外レポート Visual Studio デバッガーにより、Windows ランタイム コンポーネントで発生した C++ 例外のスタック トレースをキャプチャできるようになりました。それらのキャプチャされたスタック トレースは、Platform::Exception から派生した例外オブジェクトで使用可能であればいつでも表示できます。

    初回例外でデバッガーによって表示される例外ダイアログ ボックスには、例外が発生した時点でのスタック トレースが示されます。

    $exceptionstack ウィンドウに[ウォッチ]擬似変数を追加することで、デバッグ セッションで今後の Windows ランタイムの例外を調べることができます。例外が現在のスレッドで発生した場合は、[ウォッチ] ウィンドウでエントリを展開し、スタック トラック トレースを表示して、例外の原因となったソース コードに移動できます。例外ダイアログ ボックスで $exceptionstack[例外スタック トレースをウォッチ対象に追加] リンクを選択することで、 を観察することもできます。

    詳細については、Visual Studio ALM + Team Foundation Server のブログでこの投稿を参照してください。

C++ および JavaScript の [マイ コードのみ] デバッグ

[マイ コードのみ] では、非ユーザー コード (システムや Win.JS、サード パーティ ライブラリのコードなど) は [呼び出し履歴] ウィンドウで非表示になります。[マイ コードのみ] により、非同期コードのデバッグや、JavaScript と C++ の混合モードでのデバッグで、自分のメソッドをはるかに見つけやすくなります。

[マイ コードのみ] は Visual Studio 2013 では既定で有効になっています。[呼び出し履歴] のすべてのコードを表示するには、[デバッグ] メニューの [オプションと設定] をクリックし、[マイ コードのみを有効にする] チェック ボックスをオフにします。この設定は [マイ コードのみ] をサポートしているすべてのプログラミング言語に適用されることに注意してください。

.NET Framework 用の 64 ビット エディット コンティニュ

デバッガーで、64 ビット プラットフォームを対象とするアプリ用にエディット コンティニュがサポートされるようになりました。

.NET Framework メソッドの戻り値の検査

[自動変数] ウィンドウでメソッドの戻り値を表示できるようになりました。この機能は特に組み込みメソッド (別の関数にパラメーターとして渡されるメソッド) に便利です。

コード エディター内の埋め込みメソッド[自動変数] ウィンドウに表示されている、メソッドの戻り値

メソッド呼び出しの戻り値の調査」を参照してください。

ダンプ ファイルによる .NET Framework のメモリ分析

稼動環境で実行中の .NET アプリケーションに頻繁に影響する問題の 1 つが、アプリケーションおよびコンピューター全体に影響する可能性があるメモリ使用の問題です。Visual Studio 2013 では、.NET Framework の Web、データベース、およびデスクトップ アプリケーションでのメモリ リーク、非効率的なメモリの使用、不要な割り当てを検出できるように、ダンプ ファイル分析ツールが拡張されています。

[!メモ]

.NET Framework のダンプ ファイルのメモリ分析は、Windows ストア アプリではサポートされません。JavaScript アプリについては、「Windows ストア アプリのメモリ使用量の分析 (JavaScript)」を参照してください。

.NET メモリ分析ツールの詳細については、Visual Studio ALM + Team Foundation Server のブログで「この投稿」を参照してください。ダンプ ファイルの詳細については、「ダンプ ファイルを使用したアプリのクラッシュとハングのデバッグ」を参照してください。

Windows 対応のデバッグ ツールによるデバッグ

[!メモ]

WinDbg でマネージ プログラムをデバッグするのに役立つ SOS.dll (SOS デバッガー拡張) は、Visual Studio IDE では使用できません。「Windows デバッガーを使ったマネージ コードのデバッグ」を参照してください。

Visual Studio IDE では、Windows 対応のデバッグ ツールを使用できます。Windows Driver Kit (WDK) に含まれているデバッグ ツールをインストールする必要があります。詳細については、「Windows 用のキットとツールのダウンロード」を参照してください。

コード マップ デバッグ

コード マップを作成することで、Visual Studio Ultimate でのデバッグ中の呼び出し履歴が視覚化されます。また、コード マップを使用して、コード内を視覚的に移動することもできます。「Visual Studio でデバッグを行うときの呼び出し履歴に対するメソッドのマップ」を参照してください。

コード マップの呼び出し履歴を使用したデバッグ

IntelliTrace デバッグ

  • 配置の問題に関してアプリを監視します。

    Microsoft Monitoring Agent により (単独または System Center 2012 と連携して)、IIS Web アプリを例外とパフォーマンス イベントについてローカルで監視します。Visual Studio Ultimate でこれらの問題を詳しく調査し、特定のイベントからデバッグを開始するときに配置されたコードに移動できるように、IntelliTrace ログにこれらのイベントを記録できます。

    パフォーマンス イベント詳細を表示する

    メソッド呼び出しからデバッグを開始する

    パフォーマンス イベントからアプリケーション コードに移動する

  • 配置内の SharePoint 2010 および SharePoint 2013 アプリケーションからの診断イベントを Microsoft 監視エージェントで記録します。

    Visual Studio Ultimate でこれらの問題をさらに調査し、IntelliTrace で特定のイベントからデバッグを開始できるように、ユーザー プロファイル イベント、Unified Logging System (ULS) イベント、および IntelliTrace イベントを IntelliTrace ログに保存できます。

    IntelliTrace ログ ファイル - Web 要求とイベントの表示

配置後に問題を診断するためのリリースのセットアップ」および「System Center 2012 R2 Operations Manager の新機能」を参照してください。

参照

概念

デバッガーのセキュリティ

その他の技術情報

Visual Studio でのデバッグ