プロファイリング機能ツアーProfiling Feature Tour

Visual Studio にはさまざまなプロファイリング ツールがあります。各種アプリの多様な問題を診断できます。Visual Studio provides a variety of profiling tools to help you diagnose different kinds of performance issues depending on your app type.

[診断ツール] ウィンドウのプロファイリング ツールには、デバッグ セッション中にアクセスできます。The profiling tools that you can access during a debugging session are available in the Diagnostic Tools window. [診断ツール] ウィンドウは、オフにしていない限り自動的に表示されます。The Diagnostic Tools window appears automatically unless you have turned it off. このウィンドウを表示するには、[デバッグ]、[ウィンドウ]、[診断ツールの表示] の順にクリックします。To bring up the window, click Debug / Windows / Show Diagnostic Tools. ウィンドウを開いている状態で、データを収集するツールを選択できます。With the window open, you can select tools for which you want to collect data.

診断ツール ウィンドウDiagnostic Tools window

デバッグ中、[診断ツール] ウィンドウを利用し、CPU とメモリの使用状況を分析できます。また、パフォーマンス関連情報を示すイベントを閲覧できます。While you are debugging, you can use the Diagnostic Tools window to analyze CPU and memory usage, and you can view events that show performance-related information.

診断ツールの概要ビューDiagnostic Tools Summary view

[診断ツール] ウィンドウはアプリをプロファイリングする方法として人気がありますが、アプリの事後分析を行うこともできます。The Diagnostic Tools window is often the preferred way to profile apps, but you can also do a post-mortem analysis of your app instead. 各種手法の詳細については、「Running Profiling Tools With or Without the Debugger」 (デバッガーを使用して、または使用せずにプロファイリング ツールを実行する) を参照してください。If you want more information on different approaches, see Running Profiling Tools With or Without the Debugger.

CPU 使用率の分析Analyze CPU Usage

アプリのパフォーマンスを分析するとき、CPU 使用率ツールから始めると効率的です。The CPU Usage tool is a good place to start analyzing your app's performance. アプリが使用している CPU リソースについて理解できます。It will tell you more about CPU resources that your app is consuming. CPU 使用率ツールの詳しいチュートリアルについては、「パフォーマンス プロファイリングのビギナーズ ガイド」を参照してください。For a more detailed walkthrough of the CPU Usage tool, see Beginner's Guide to Performance Profiling.

診断ツールの [概要] ビューから、[CPU プロファイルの有効化] を選択します (デバッグ セッションに入っている必要があります)。From the Summary view of the Diagnostic Tools, choose Enable CPU Profiling (you must be in a debugging session).

診断ツールの CPU 使用率を有効にするEnable CPU usage in the Diagnostic Tools

このツールを最も効果的に使用するには、コードにブレークポイントを 2 つ設定します。関数の始めと終わりに 1 つずつ設定するか、分析するコードの領域に設定します。To use the tool most effectively, set two breakpoints in your code, one at the beginning and one at the end of the function or the region of code you want to analyze. 2 つ目のブレークポイントで止まったとき、プロファイリング データを調べます。Examine the profiling data when you are paused at the second breakpoint.

CPU 使用率ビューには、関数が実行時間順に一覧表示されます。実行時間が最も長い関数が一番上に表示されます。The CPU Usage view shows you a list of functions ordered by longest running, with the longest running function at the top. パフォーマンス上のボトルネックが発生している関数を見つけるのに役立ちます。This can help guide you to functions where performance bottlenecks are happening.

診断ツールの CPU 使用率ビューDiagnostic Tools CPU Usage view

調べたい関数をダブルクリックすると、3 つのウィンドウを持つ詳細な "バタフライ" ビューが表示されます。選択した関数がウィンドウの中央に、呼び出した関数が左に、呼び出された関数が右に表示されます。Double-click on a function that you are interested in, and you will see a more detailed three-pane "butterfly" view, with the selected function in the middle of the window, the calling function on the left, and called functions on the right. 関数本体セクションに、呼び出し元の関数と呼び出される関数にかかった時間を除き、関数本体にかかった時間の合計 (と時間のパーセンテージ) が表示されます。The Function Body section shows the total amount of time (and the percentage of time) spent in the function body excluding time spent in calling and called functions. このデータは、関数自体がパフォーマンスのボトルネックであるかどうかを判定するのに役立ちます。This data can help you evaluate whether the function itself is a performance bottleneck.

診断ツールの呼び出し元/呼び出し先 "バタフライ" ビューDiagnostic Tools caller callee "butterfly" view

メモリ使用量の分析Analyze Memory Usage

診断ツール ウィンドウでは、アプリのメモリ使用量を測定することもできます。The Diagnostic Tools window also allows you to evaluate memory usage in your app. たとえば、ヒープのオブジェクトの数とサイズと数を確認できます。For example, you can look at the number and size of objects on the heap. メモリの分析方法の詳細については、「Analyze Memory Usage (メモリ使用量の分析)」をご覧ください。For more detailed instructions to analyze memory, see Analyze Memory Usage.

メモリ使用量を分析するには、デバッグ中に少なくとも 1 枚のメモリ スナップショットを取得する必要があります。To analyze memory usage, you need to take at least one memory snapshot while you are debugging. 多くの場合、メモリを分析する最良の方法は 2 枚のスナップショットを取得することです。疑われるメモリ問題の発生直前に 1 枚、発生直後に 1 枚取得します。Often, the best way to analyze memory is to take two snapshots; the first right before a suspected memory issue, and the second snapshot right after a suspected memory issue occurs. それから、2 枚のスナップショットの違いを表示し、厳密に何が変化しているのか確認します。Then you can view a diff of the two snapshots and see exactly what changed.

診断ツールでスナップショットを取得するTake a snapshot in the Diagnostic Tools

矢印リンクの 1 つを選択すると、ヒープの差分ビューが与えられます (赤い上向き矢印メモリ使用量増加は、オブジェクト数の増加 (左) とヒープ サイズの増加 (右) を示します)。When you select one of the arrow links, you are given a differential view of the heap (a red up arrow Memory Usage Increase shows an increasing object count (left) or an increasing heap size (right)). 右のリンクをクリックすると、差異ヒープ ビューが表示されます。ヒープ サイズが多い順でオブジェクトが表示されます。If you click the right link, you get a differential heap view ordered by objects that increased the most in heap size. メモリ問題の厳密な場所の発見に役立ちます。This can help you pinpoint memory problems. たとえば、次の図では、ClassHandlersStore オブジェクトで使用されているバイトが 2 枚目のスナップショットで 3,492 バイト増えています。For example, in the illustration below, the bytes used by ClassHandlersStore objects increased by 3,492 bytes in the second snapshot.

診断ツールのヒープ差分ビューDiagnostic Tools heap diff view

[メモリ使用量] ビューで代わりに左のリンクをクリックすると、ヒープ ビューがオブジェクト数で整理されます。最も増えたオブジェクトが一番上に表示されます ([数の相違] 列で並べ替えられます)。If you click the link on the left instead in the Memory Usage view, the heap view is organized by object count; the objects of a particular type that increased the most in number are shown at the top (sorted by Count Diff column).

パフォーマンス イベントを調べるExamine Performance Events

診断ツールの [イベント] ビューには、デバッグ中に発生したさまざまなイベントが表示されます。ブレークポイントの設定やコードのステップ実行操作などです。The Events view in the Diagnostic Tools shows you different events that occur while you are debugging, such as the setting of a breakpoint or a code stepping operation. イベントの継続時間などの情報を確認できます (この時間はデバッガーが最後に一時停止したところから、あるいはアプリが開始したところから計測されます)。You can check information such as the duration of the event (measured from when the debugger was last paused, or when the app started). たとえば、コードをステップ実行すると (F10、F11)、[イベント] ビューには、前のステップ操作から現在のステップまでのアプリランタイムが表示されます。For example, if you step through code (F10, F11), the Events view shows you the app runtime duration from the previous step operation to the current step.

診断ツールのイベントビューDiagnostic Tools Events view

注意

Visual Studio Enterprise をご利用の場合、このタブの [IntelliTrace イベント] も参照してください。If you have Visual Studio Enterprise, you can also see IntelliTrace events in this tab.

同じイベントがコード エディターにも表示されます。これはパフォーマンスのヒントとして閲覧できます。The same events also show up in the code editor, which you can view as PerfTips.

プロファイルのパフォーマンスのヒントProfiling Tour PerfTips

UI のパフォーマンスとアクセシビリティのイベントを調べる (UWP)Examine UI Performance and Accessibility Events (UWP)

UWP アプリで、[診断ツール] ウィンドウで [UI 分析] を有効にできます。In your UWP apps, you can enable UI Analysis in the Diagnostic Tools window. このツールはパフォーマンスとアクセシビリティに関する一般問題を探し出し、デバッグ中に [イベント] ビューに表示します。The tool searches for common performance or accessibility issues and displays them in the Events view while you are debugging. イベントの説明に、問題解決に役に立つ情報があります。The event descriptions provide information that can help resolve issues.

診断ツールで UI 分析イベントを表示するView UI Analysis events in the Diagnostic Tools

デバッガーなしのプロファイル リリース ビルドProfile Release Builds without the Debugger

CPU 使用量やメモリ使用量などのプロファイリング ツールはデバッガーと併用できます (前のセクションを参照してください)。あるいは、パフォーマンス プロファイラーを利用してプロファイリング ツールを実行できます。パフォーマンス プロファイラーは、リリース ビルドを分析するためのものです。Profiling tools like CPU Usage and Memory Usage can be used with the debugger (see earlier sections), or you can run profiling tools using the Performance Profiler, which is intended to provide analysis for Release builds. パフォーマンス プロファイラーでは、アプリの実行中に診断情報を収集し、アプリの停止後に収集した情報を調査できます。In the Performance Profiler, you can collect diagnostic info while the app is running, and then examine the collected information after the app is stopped. 各種手法の詳細については、「Running Profiling Tools With or Without the Debugger」 (デバッガーを使用して、または使用せずにプロファイリング ツールを実行する) を参照してください。For more information on these different approaches, see Running Profiling Tools With or Without the Debugger.

パフォーマンス プロファイラーPerformance Profiler

[デバッグ]、[パフォーマンス プロファイラー] の順に選択し、パフォーマンス プロファイラーを開きます。Open the Performance Profiler by choosing Debug / Performance Profiler.

このウィンドウでは、シナリオによっては、複数のプロファイリング ツールを選択できます。The window will allow you to select multiple profiling tools in some scenarios. CPU 使用率などのツールでは、補足データを提供できることがあります。分析に役立てることができます。Tools such as CPU Usage may provide complementary data that you can use to help in your analysis.

リソース消費量を分析する (XAML)Analyze Resource Consumption (XAML)

Windows デスクトップ WPF アプリや UWP アプリなど、XAML アプリでは、アプリケーション タイムライン ツールを利用してリソース消費を分析できます。In XAML apps, such as Windows desktop WPF apps and UWP apps, you can analyze resource consumption using the Application Timeline tool. たとえば、アプリケーションが UI フレームの準備 (レイアウトとレンダリング) やネットワークとディスクの要求の処理を実行することで、およびアプリケーションの起動、ページの読み込み、ウィンドウのサイズ変更などのシナリオにおいて使用した時間を分析することができます。For example, you can analyze the time spent by your application preparing UI frames (layout and render), servicing network and disk requests, and in scenarios like application startup, page load, and Window resize. ツールを使用するには、パフォーマンス プロファイラーで [アプリケーションのタイムライン] を選択し、[開始] を選択します。To use the tool, choose Application Timeline in the Performance Profiler, and then choose Start. アプリで、リソース消費問題が疑われるシナリオを進め、[コレクションの停止] を選択してレポートを生成します。In your app, go through the scenario with a suspected resource consumption issue, and then choose Stop collection to generate the report.

ビジュアル スループット でグラフのフレームレートが低い場合は、アプリの実行時に観察されるビジュアルの問題に関連している可能性があります。Low framerates in the Visual throughput graph may correspond to visual problems that you see when running your app. 同様に、UI スレッド使用状況グラフの数値が高いと、UI の応答性問題に関連している可能性があります。Similarly, high numbers in the UI thread utilization graph may also correspond to UI responsiveness issues. レポートでは、パフォーマンス問題が疑われる期間を選択し、タイムライン詳細ビュー (下のウィンドウ) で UI スレッド アクティビティを詳しく調査できます。In the report, you can select a time period with a suspected performance issue, and then examine the detailed UI thread activities in the Timeline details view (lower pane).

アプリケーションのタイムラインのプロファイリング ツールApplication Timeline profiling tool

タイムライン詳細ビューでは、アクティビティの種類 (あるいは、関連している UI 要素) などの情報とアクティビティの継続時間を確認できます。In the Timeline details view, you can find information such as the type of activitiy (or the UI element involved) along with the duration of the activity. たとえば、この図では、グリッド コントロールのレイアウト イベントに 57.53 ミリ秒かかっています。For example, in the illustration, a Layout event for a Grid control takes 57.53 ms.

詳細については、アプリケーションのタイムラインに関するページを参照してください。For more information, see Application Timeline.

GPU の使用状況を分析する (Direct3D)Analyze GPU Usage (Direct3D)

Direct3D アプリ (Direct3D コンポーネントは C++ である必要があります) では、GPU 上のアクティビティを調査し、パフォーマンス問題を分析できます。In Direct3D apps (Direct3D components must be in C++), you can examine activity on the GPU and analyze performance issues. 詳細については、「GPU 使用率」を参照してください。For more information, see GPU Usage. ツールを使用するには、パフォーマンス プロファイラーで [GPU 使用量] を選択し、[開始] を選択します。To use the tool, choose GPU Usage in the Performance Profiler, and then choose Start. アプリで、プロファイリングしたいシナリオを実行し、[コレクションの停止] を選択してレポートを生成します。In your app, go through the scenario that you're interested in profiling, and then choose Stop collection to generate a report.

グラフで期間を選択し、[詳細の表示] を選択すると、下のウィンドウに詳細ビューが表示されます。When you select a time period in the graphs and choose view details, a detailed view appears in the lower pane. 詳細ビューで、CPU と GPU でそれぞれ、どの程度のアクティビティが行われているのか調査できます。In the detailed view, you can examine how much activity is happening on each CPU and GPU. 一番下のウィンドウでイベントを選択すると、タイムラインにポップアップ表示されます。Select events in the lowest pane to get popups in the timeline. たとえば、Present イベントを選択すると、Present 呼び出しポップアップが表示されます。For example, select the Present event to view Present call popups. (薄い灰色の垂直同期線を参照すると、特定の Present 呼び出しで垂直同期に失敗しているかどうかを理解できます。(The light gray vertical Vsync lines can be used as a reference to understand whether certain Present calls missed Vsync. アプリが安定的に 60 FPS をヒットするには、2 つの垂直同期の間に Present が 1 つ存在する必要があります。)There must be one Present call between every two Vsyncs in order for the app to steadily hit 60 FPS.)

GPU 使用率プロファイリング ツールGPU Usage profiling tool

また、グラフを利用し、CPU バインドまたは GPU バインドのパフォーマンス問題があるかどうかを判断できます。You can also use the graphs to determine whether there are CPU bound or GPU bound performance bottlenecks.

パフォーマンスの分析 (JavaScript)Analyze Performance (JavaScript)

Windows ユニバーサル HTML アプリの場合、JavaScript メモリ ツールと HTML UI 応答性ツールを利用できます。For Windows Universal HTML apps, you can use the JavaScript Memory tool and the HTML UI Responsiveness tool.

JavaScript メモリ ツールは、その他の種類のアプリで使用できるメモリ使用量ツールに似ています。The JavaScript Memory tool is similar to the Memory Usage tool available for other app types. このツールを利用してメモリ使用量を理解し、アプリのメモリ リークを発見できます。You can use this tool to understand memory usage and find memory leaks in your app. このツールの詳細については、「JavaScript メモリ」を参照してください。For more details about the tool, see JavaScript Memory.

JavaScript メモリのプロファイリング ツールJavaScript Memory profiling tool

UI の応答性、遅い読み込み時間、Windows ユニバーサル HTML アプリの遅い表示更新を診断するには、HTML UI 応答性ツールを使用します。To diagnose UI responsiveness, slow loading time, and slow visual updates in Windows Universal HTML apps, use the HTML UI Responsiveness tool. 使用方法は、他の種類のアプリのアプリケーションのタイムライン ツールに似ています。Usage is similar to the Application Timeline tool for other app types. 詳細については、「HTML UI の応答性」を参照してください。For more information, see HTML UI responsiveness.

HTML UI の応答性プロファイリング ツールHTML UI Responsiveness profiling tool

ネットワーク使用量を分析する (UWP)Analyze Network Usage (UWP)

UWP アプリでは、Windows.Web.Http API を利用して実行されたネットワーク操作を分析できます。このツールは、アクセスと認証の問題、キャッシュの不適切な利用、ディスプレイとダウンロードの低いパフォーマンスなどの問題の解決に役に立つことがあります。In UWP apps, you can analyze network operations performed using the Windows.Web.Http API.This tool may help you to resolve issues like access and authentication problems, incorrect cache-use, and poor display and download performance. ツールを使用するには、パフォーマンス プロファイラーで [ネットワーク] を選択し、[開始] を選択します。To use the tool, choose Network in the Performance Profiler, and then choose Start. アプリで、Windows.Web.Http を使用するシナリオを実行し、[コレクションの停止] を選択してレポートを生成します。In your app, go through the scenario that uses Windows.Web.Http, and then choose Stop collection to generate the report.

ネットワーク使用率プロファイリング ツールNetwork Usage profiling tool

概要ビューで操作を選択すると、詳細が表示されます。Select an operation in the summary view to view more details.

ネットワーク使用率ツールの詳細情報Detailed information in the Network Usage tool

詳細については、「ネットワーク使用率」を参照してください。For more information, see Network Usage.

パフォーマンス分析 (レガシー ツール)Analyze Performance (Legacy Tools)

CPU 使用量ツールやメモリ使用量ツールに現在入っていないインストルメンテーションのような機能が必要なとき、デスクトップまたは ASP.NET アプリを実行している場合、プロファイリングにパフォーマンス エクスプローラーを利用できます。If you need features such as instrumentation that are not currently present in CPU Usage or Memory Usage tools, and you are running desktop or ASP.NET apps, you can use the Performance Explorer for profiling. (UWP アプリではサポートされていません。)(Not supported in UWP apps). 詳細については、「パフォーマンス エクスプローラー」を参照してください。For more info, see Performance Explorer.

パフォーマンス エクスプローラー ツールPerformance Explorer tool

使用するツールWhich Tool Should I Use?

次の表では、Visual Studio のさまざまなツールとそれらを使用できる各種プロジェクトをまとめています。Here is a table that lists the different tools Visual Studio offers and the different project types you can use them with:

パフォーマンス ツールPerformance Tool Windows デスクトップWindows desktop Windows ユニバーサル/ストアWindows Universal/Store ASP.NET/ASP.NET CoreASP.NET/ASP.NET Core
メモリ使用量Memory Usage yes yes yes
CPU 使用率CPU Usage yes yes yes
GPU 使用率GPU Usage yes yes nono
アプリケーションのタイムラインApplication Timeline yes yes nono
パフォーマンスのヒントPerfTips yes XAML の場合は可、HTML の場合は不可yes for XAML, no for HTML yes
パフォーマンス エクスプローラーPerformance Explorer yes nono 可 (ASP.NET Core の場合は no)yes (no for ASP.NET Core)
IntelliTraceIntelliTrace .NET Enterprise のみ.NET Enterprise only .NET Enterprise のみ.NET Enterprise only .NET Enterprise のみ.NET Enterprise only
ネットワーク使用率Network Usage nono yes nono
HTML UI responsivenessHTML UI responsiveness nono HTML の場合は可、XAML の場合は不可yes for HTML, no for XAML nono
JavaScript メモリJavaScript Memory nono HTML の場合は可、XAML の場合は不可yes for HTML, no for XAML nono

関連項目See Also

Visual Studio でのデバッグDebugging in Visual Studio