SDK/Tools

Choose application
.NET Native Web
Choose application
VS Code Visual Studio
http:////www.brendangregg.com//FlameGraphs//memoryflamegraphs.html)/n
  • consumed memory size over time graph<\/li>\n<li>number of instances over time graph<\/li>\n<li>number of memory allocations over time graph<\/li>\n<li>size of memory allocated over time graph<\/li>\n<li>allocation histogram displaying the number of allocations (the total number and the several topmost code locations) belonging to one of the groups divided by allocation size (0 - 8 bytes, 9 - 16 bytes, ... , 512 bytes - 1 KB, more than 1 KB)<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<h3 id=\"content-managed-heap-view-sample\"><a href=https://samsungtizenos.com/"#content-managed-heap-view-sample\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Managed heap view sample<\/h3>\n<p><img src=https://samsungtizenos.com/"media//memory_profiler_gui_managed_heap.png/" alt=\"Managed heap view\" \/><\/p>\n<h3 id=\"content-flame-graph-view-sample\"><a href=https://samsungtizenos.com/"#content-flame-graph-view-sample\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Flame graph view sample<\/h3>\n<p><img src=https://samsungtizenos.com/"media//memory_profiler_gui_flame_graph.png/" alt=\"Flame graph view\" \/><\/p>\n<h3 id=\"content-memory-allocations-graph-view-sample\"><a href=https://samsungtizenos.com/"#content-memory-allocations-graph-view-sample\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Memory allocations graph view sample<\/h3>\n<p><img src=https://samsungtizenos.com/"media//memory_profiler_gui_allocations_graph.png/" alt=\"Memory allocations graph view\" \/><\/p>\n<h3 id=\"content-allocation-histogram-view-sample\"><a href=https://samsungtizenos.com/"#content-allocation-histogram-view-sample\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Allocation histogram view sample<\/h3>\n<p><img src=https://samsungtizenos.com/"media//memory_profiler_gui_allocation_histogram.png/" alt=\"Allocation histogram view\" \/><\/p>\n","table_of_content":"<ul class=\"table-of-contents\">\n<li><a href=https://samsungtizenos.com/"#content-get-started-with-core-profiler\">Get Started with Core Profiler<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-recording-profiling-sessions\">Recording Profiling Sessions<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-managing-profiling-sessions\">Managing Profiling Sessions<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-viewing-profiling-sessions\">Viewing Profiling Sessions<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-filters-panel\">Filters Panel<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-timeline-panel\">Timeline Panel<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-methods-panel\">Methods Panel<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-get-started-with-memory-profiling\">Get Started with Memory Profiling<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-step-1-running-memory-profiler\">Step 1. Running Memory Profiler<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-step-2-analyzing-the-results\">Step 2. Analyzing the results<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-managed-heap-view-sample\">Managed heap view sample<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-flame-graph-view-sample\">Flame graph view sample<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-memory-allocations-graph-view-sample\">Memory allocations graph view sample<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-allocation-histogram-view-sample\">Allocation histogram view sample<\/a><\/li>\n<\/ul>\n","title":"Get Started with Core and Memory Profiler","raw":null},{"class":"App\\Services\\Documentation\\Data\\RenderedMarkdown","s":"wrbl"}]},"memo":{"id":"Plfe8BhvYr0M1nd5IjKj","name":"documentation::article","path":"docs\/sdk-tools\/dotnet\/visual-studio\/vstools\/getting-started\/test-profile-app-profiling","method":"GET","release":"a-a-a","children":[],"scripts":[],"assets":[],"lazyLoaded":false,"lazyIsolated":true,"errors":[],"locale":"en","islands":[]},"checksum":"06de35c5b26761a750ae22064244b6f1132a1b7e5eaff6ba5960fe493af99e93"}" wire:effects="[]" wire:id="Plfe8BhvYr0M1nd5IjKj" wire:name="documentation::article" x-init="$wire.__lazyLoad('{"data":{"forMount":[{"markdown":[{"body":"<h1 id=\"content-get-started-with-core-and-memory-profiler\"><a href=\"#content-get-started-with-core-and-memory-profiler\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Get Started with Core and Memory Profiler<\/h1><div data-knowledge-base-metadata><\/div>\n<h2 id=\"content-get-started-with-core-profiler\"><a href=\"#content-get-started-with-core-profiler\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Get Started with Core Profiler<\/h2>\n<p>This tutorial will guide you on how to use profiler in Visual Studio for tizen projects<\/p>\n<h3 id=\"content-recording-profiling-sessions\"><a href=\"#content-recording-profiling-sessions\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Recording Profiling Sessions<\/h3>\n<p>To record a profiling session:<\/p>\n<ol>\n<li>\n<p>In the Visual Studio menu, select <strong>Tools &gt; Tizen &gt; Profiler &gt; Run Profiler<\/strong>.<br \/>\nThe profiler configuration dialog opens.<\/p>\n<\/li>\n<li>\n<p>Define the profiling options.<br \/>\n<img src=\"media\/profiler-config.png\" alt=\"Profiler configuration\" \/><\/p>\n<ul>\n<li><strong>Path to application<\/strong> is automatically filled with the information for the current solution.<\/li>\n<li><strong>Profiling Preset<\/strong><br \/>\nYou can select from the following predefined profiling configurations:\n<ul>\n<li><strong>CPU Sampling<\/strong><br \/>\nTrace CPU and source lines, but not memory allocation.<\/li>\n<li><strong>Memory Allocation<\/strong><br \/>\nTrace memory allocation and source lines, but not CPU.<\/li>\n<li><strong>Complex Profiling<\/strong><br \/>\nTrace CPU, source lines, and memory allocation.<\/li>\n<\/ul>\n<\/li>\n<li><strong>Sampling Options<\/strong><br \/>\nYou can set the following sampling options:\n<ul>\n<li><strong>Sampling Interval<\/strong><br \/>\nYou can set the sampling time interval, in milliseconds. The default is 10 ms.<\/li>\n<li><strong>High Granularity<\/strong><br \/>\nYou can switch on high-granularity sampling. It enables better precision and sample regularity, at the cost of efficiency.<\/li>\n<\/ul>\n<\/li>\n<li><strong>Trace Options<\/strong><br \/>\nYou can set the following trace options:\n<ul>\n<li><strong>Trace Execution<\/strong><br \/>\nYou can trace CPU utilization.<\/li>\n<li><strong>Trace Memory<\/strong><br \/>\nYou can trace memory allocation for methods.<\/li>\n<li><strong>Trace Garbage Collection<\/strong><br \/>\nYou can trace garbage collection.<\/li>\n<li><strong>Trace Source Lines<\/strong><br \/>\nYou can switch on line source mapping.<\/li>\n<li><strong>Stack Track<\/strong><br \/>\nYou can enable a hybrid trace, which registers stack changes on memory allocation.<\/li>\n<\/ul>\n<\/li>\n<li><strong>CPU Tracing Options<\/strong><br \/>\nYou can set the following CPU tracing options:\n<ul>\n<li><strong>Enable CPU Tracing<\/strong><br \/>\nYou can switch on the CPU tracing features.<\/li>\n<li><strong>Trace Process<\/strong><br \/>\nYou can trace the application's CPU utilization.<\/li>\n<li><strong>Trace Threads<\/strong><br \/>\nYou can trace each processing thread's CPU utilization.<\/li>\n<li><strong>Trace Interval (ms)<\/strong><br \/>\nYou can set the sampling time interval, in milliseconds.<\/li>\n<\/ul>\n<\/li>\n<li><strong>Misc Options<\/strong><br \/>\nYou can set the following additional option:\n<ul>\n<li><strong>Delayed start<\/strong><br \/>\nYou can delay the application startup.<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<\/li>\n<li>\n<p>To start the profiling session, click <strong>OK<\/strong>.<br \/>\nThe application is installed and launches on the emulator.<br \/>\nThe <strong>Output<\/strong> panel displays the installation log, including any errors.<br \/>\n<img src=\"media\/profiler-output-window.png\" alt=\"Output panel\" \/><\/p>\n<p>The <strong>Profiling Progress<\/strong> panel shows live CPU and memory usage information.<br \/>\n<img src=\"media\/profiler-progress.png\" alt=\"Profiling progress\" \/><\/p>\n<\/li>\n<li>\n<p>To pause and resume profiling, in the <strong>Profiling Progress<\/strong> panel, click <strong>Pause<\/strong> and <strong>Resume<\/strong>.<br \/>\nThe chart in the <strong>Profiling Progress<\/strong> panel uses a light-blue background to distinguish the time period when profiling is paused.<\/p>\n<\/li>\n<li>\n<p>To stop profiling, click <strong>Stop<\/strong>.<br \/>\nThe application is terminated and the profiling data is retrieved from the emulator.<\/p>\n<p><img src=\"media\/profiler-execute-stop.png\" alt=\"Stop profiling\" \/><\/p>\n<\/li>\n<\/ol>\n<h3 id=\"content-managing-profiling-sessions\"><a href=\"#content-managing-profiling-sessions\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Managing Profiling Sessions<\/h3>\n<p>To manage the recorded profiling sessions:<\/p>\n<ol>\n<li>\n<p>In the Visual Studio menu, select <strong>Tools &gt; Tizen &gt; Profiler &gt; Session Explorer<\/strong>.<\/p>\n<p>The <strong>Session Explorer<\/strong> panel opens. It lists the profiling sessions collected from the current solution.<br \/>\n<img src=\"media\/profiler-session-explorer.png\" alt=\"Session Explorer\" \/><\/p>\n<\/li>\n<li>\n<p>You can add a user-defined annotation to a session to, for example, identify what was tested during that session.<br \/>\nTo add an annotation:<\/p>\n<ol>\n<li>In the <strong>Session Explorer<\/strong>, right-click the session and select <strong>Edit Annotation<\/strong>.<br \/>\n<img src=\"media\/profiler-session-explorer-context-menu.png\" alt=\"Edit annotation\" \/><\/li>\n<li>Enter the annotation text, and click <strong>Ok<\/strong>.<br \/>\n<img src=\"media\/profiler-edit-annotation.png\" alt=\"Edit annotation text\" \/><\/li>\n<\/ol>\n<\/li>\n<li>\n<p>To view the session properties, click the session in the <strong>Session Explorer<\/strong>.<br \/>\nThe <strong>Properties<\/strong> panel (below the <strong>Session Explorer<\/strong> panel by default) displays additional information about the session, such as the profiling options used for the session.<br \/>\n<img src=\"media\/profiler-session-properties.png\" alt=\"Session properties\" \/><\/p>\n<\/li>\n<li>\n<p>To delete a session, in the <strong>Session Explorer<\/strong>, right-click the session and select <strong>Delete<\/strong>.<\/p>\n<\/li>\n<\/ol>\n<h3 id=\"content-viewing-profiling-sessions\"><a href=\"#content-viewing-profiling-sessions\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Viewing Profiling Sessions<\/h3>\n<p>To view a profiling session, in the <strong>Session Explorer<\/strong>, double-click on the session you want to view.<br \/>\nA session view opens, consisting of 3 panels:<\/p>\n<ul>\n<li>Filters panel on the left<\/li>\n<li>Timeline panel in the center<\/li>\n<li>Methods panel on the right<\/li>\n<\/ul>\n<p><strong>Figure: Session view<\/strong><\/p>\n<p><img src=\"media\/profiler-session-analysis.png\" alt=\"Session view\" \/><\/p>\n<h3 id=\"content-filters-panel\"><a href=\"#content-filters-panel\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Filters Panel<\/h3>\n<p>You can filter the profiling data by selecting from the following options:<\/p>\n<ul>\n<li><strong>Call Tree and Methods<\/strong> filters define which information is displayed in the methods panel:\n<ul>\n<li><strong>Time<\/strong> shows how much time each method has occupied.<\/li>\n<li><strong>Allocated Memory<\/strong> shows how much memory was allocated for each method.<\/li>\n<li><strong>Samples<\/strong> shows the number of samples for each method.<\/li>\n<\/ul>\n<\/li>\n<li><strong>Thread Timeline<\/strong> filters define which information is displayed in the timeline panel.<br \/>\nYou can display <strong>GC<\/strong> (garbage collection), <strong>JIT<\/strong> (just-in-time compilation), or <strong>Cpu Utilization<\/strong>.<\/li>\n<\/ul>\n<h3 id=\"content-timeline-panel\"><a href=\"#content-timeline-panel\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Timeline Panel<\/h3>\n<p>The timeline panel consists of 2 parts:<\/p>\n<ul>\n<li>\n<p>The upper part of the panel shows the overall CPU utilization chart.<\/p>\n<p><img src=\"media\/profiler-cpu-utilization.png\" alt=\"CPU utilization\" \/><\/p>\n<\/li>\n<li>\n<p>The lower part of the panel shows GC, JIT or CPU utilization charts for each thread, depending on the selected filter.<\/p>\n<p><img src=\"media\/profiler-gc-cpu-utilization.png\" alt=\"GC CPU utilization\" \/><\/p>\n<\/li>\n<\/ul>\n<p>You can select a specific time interval on the timeline, to view the detailed method data for it.<br \/>\nTo select a time interval:<\/p>\n<ol>\n<li>Highlight the interval you want to view in the upper part of the timeline panel.<br \/>\n<img src=\"media\/profiler-select-interval.png\" alt=\"Select interval\" \/><br \/>\nThe methods panel shows data for the selected interval.<\/li>\n<li>To clear the selected interval, click anywhere in the timeline chart.<\/li>\n<\/ol>\n<h3 id=\"content-methods-panel\"><a href=\"#content-methods-panel\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Methods Panel<\/h3>\n<p>The criteria for the data shown in the methods panel depends on the selected filter. The following figure shows examples of the data displayed in the methods panel.<\/p>\n<p><strong>Figure: Method filters<\/strong><\/p>\n<p><img src=\"media\/profiler-categories.png\" alt=\"Method filters\" \/><\/p>\n<p>The methods panel consists of 3 tabs:<\/p>\n<ul>\n<li>\n<p>The <strong>Call Tree<\/strong> tab displays the <strong>Top Methods<\/strong> and <strong>Call Tree<\/strong> for the selected thread and time interval.<br \/>\n<img src=\"media\/profiler-call-tree-tab.png\" alt=\"Call Tree tab\" \/><\/p>\n<\/li>\n<li>\n<p>The <strong>Hot Path<\/strong> tab displays the hottest paths for the selected thread and time interval.<br \/>\n<img src=\"media\/profiler-hotpath-tab.png\" alt=\"Hotpath tab\" \/><br \/>\nThe list displays the hottest methods. To view the call path from the method to its root, expand the list item.<\/p>\n<\/li>\n<li>\n<p>The <strong>Hot Lines<\/strong> tab displays the top source lines for the selected thread and time interval.  The source line numbers are shown in brackets (<strong>[ ]<\/strong>).<br \/>\n<img src=\"media\/profiler-hotline-tab.png\" alt=\"Hot Lines tab\" \/><\/p>\n<p>To show a &quot;hot line&quot; entry in its source code context, double-click the method in the <strong>Hot Lines<\/strong> tab. The code line is highlighted with a color intensity corresponding to its hotness.<br \/>\n<strong>Figure: &quot;Hot line&quot; in context<\/strong><br \/>\n<img src=\"media\/profiler-jump-to-line.png\" alt=\"&quot;Hot line&quot; in context\" \/><\/p>\n<\/li>\n<\/ul>\n<h2 id=\"content-get-started-with-memory-profiling\"><a href=\"#content-get-started-with-memory-profiling\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Get Started with Memory Profiling<\/h2>\n<h3 id=\"content-step-1-running-memory-profiler\"><a href=\"#content-step-1-running-memory-profiler\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Step 1. Running Memory Profiler<\/h3>\n<ul>\n<li>\n<p>In the menu, choose <strong>Tools &gt; Tizen &gt; Profiler &gt; Run Memory Profiler<\/strong>.<\/p>\n<p><img src=\"media\/run_memory_profiler.png\" alt=\"Run Memory Profiler\" \/><\/p>\n<\/li>\n<li>\n<p>If no Tizen device is connected and no Tizen emulators are running then Emulator Manager will be started. Please launch the type of emulator you want to use for running and profiling your application.<\/p>\n<p><img src=\"media\/start_emulator.png\" alt=\"Launch Emulator\" \/><\/p>\n<\/li>\n<li>\n<p>If everything is OK then the application starts as if you run it normally (using Start Debugging in Visual Studio).<\/p>\n<p><img src=\"media\/memory_profiling_app_started.png\" alt=\"Tizen application running\" \/><\/p>\n<\/li>\n<li>\n<p>Output Window will display any information messages (debug, warnings, and so on).<\/p>\n<p><img src=\"media\/memory_profiling_msvs_output.png\" alt=\"Memory Profiler Output Window\" \/><\/p>\n<\/li>\n<li>\n<p>The memory profiling data will be displayed with the Memory Profiler GUI after finishing the application or after closing it. The application can be closed by pressing &quot;Home&quot; or &quot;Back&quot; buttons.<\/p>\n<p><img src=\"media\/close_application.png\" alt=\"Close Application\" \/><\/p>\n<\/li>\n<li>\n<p>Also you can display any previous debug session with Session Explorer (In the menu, <strong>Tools &gt; Tizen &gt; Profiler &gt; Session Explorer<\/strong>).<\/p>\n<p><img src=\"media\/open_session_explorer.png\" alt=\"Open Session Explorer\" \/><\/p>\n<p><img src=\"media\/session_explorer_memory_profiler.png\" alt=\"Open Session Explorer\" \/><\/p>\n<\/li>\n<\/ul>\n<h3 id=\"content-step-2-analyzing-the-results\"><a href=\"#content-step-2-analyzing-the-results\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Step 2. Analyzing the results<\/h3>\n<ul>\n<li>\n<p>The GUI application provides several views to the memory profiling data. The views include:<\/p>\n<ul>\n<li>summary page with information on which process was profiled, its total runtime, some memory related statistics, and so on.<\/li>\n<li>bottom-up table tree view of the code locations that allocated memory with their aggregated cost and stack traces<\/li>\n<li>caller\/callee table<\/li>\n<li>top-down table tree view of the code locations<\/li>\n<li>managed heap table tree view<\/li>\n<li>flame graph visualization (explanation: <a href=\"http:\/\/www.brendangregg.com\/FlameGraphs\/memoryflamegraphs.html\">http:\/\/www.brendangregg.com\/FlameGraphs\/memoryflamegraphs.html<\/a>)<\/li>\n<li>consumed memory size over time graph<\/li>\n<li>number of instances over time graph<\/li>\n<li>number of memory allocations over time graph<\/li>\n<li>size of memory allocated over time graph<\/li>\n<li>allocation histogram displaying the number of allocations (the total number and the several topmost code locations) belonging to one of the groups divided by allocation size (0 - 8 bytes, 9 - 16 bytes, ... , 512 bytes - 1 KB, more than 1 KB)<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<h3 id=\"content-managed-heap-view-sample\"><a href=\"#content-managed-heap-view-sample\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Managed heap view sample<\/h3>\n<p><img src=\"media\/memory_profiler_gui_managed_heap.png\" alt=\"Managed heap view\" \/><\/p>\n<h3 id=\"content-flame-graph-view-sample\"><a href=\"#content-flame-graph-view-sample\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Flame graph view sample<\/h3>\n<p><img src=\"media\/memory_profiler_gui_flame_graph.png\" alt=\"Flame graph view\" \/><\/p>\n<h3 id=\"content-memory-allocations-graph-view-sample\"><a href=\"#content-memory-allocations-graph-view-sample\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Memory allocations graph view sample<\/h3>\n<p><img src=\"media\/memory_profiler_gui_allocations_graph.png\" alt=\"Memory allocations graph view\" \/><\/p>\n<h3 id=\"content-allocation-histogram-view-sample\"><a href=\"#content-allocation-histogram-view-sample\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Allocation histogram view sample<\/h3>\n<p><img src=\"media\/memory_profiler_gui_allocation_histogram.png\" alt=\"Allocation histogram view\" \/><\/p>\n","table_of_content":"<ul class=\"table-of-contents\">\n<li><a href=\"#content-get-started-with-core-profiler\">Get Started with Core Profiler<\/a><\/li>\n<li><a href=\"#content-recording-profiling-sessions\">Recording Profiling Sessions<\/a><\/li>\n<li><a href=\"#content-managing-profiling-sessions\">Managing Profiling Sessions<\/a><\/li>\n<li><a href=\"#content-viewing-profiling-sessions\">Viewing Profiling Sessions<\/a><\/li>\n<li><a href=\"#content-filters-panel\">Filters Panel<\/a><\/li>\n<li><a href=\"#content-timeline-panel\">Timeline Panel<\/a><\/li>\n<li><a href=\"#content-methods-panel\">Methods Panel<\/a><\/li>\n<li><a href=\"#content-get-started-with-memory-profiling\">Get Started with Memory Profiling<\/a><\/li>\n<li><a href=\"#content-step-1-running-memory-profiler\">Step 1. Running Memory Profiler<\/a><\/li>\n<li><a href=\"#content-step-2-analyzing-the-results\">Step 2. Analyzing the results<\/a><\/li>\n<li><a href=\"#content-managed-heap-view-sample\">Managed heap view sample<\/a><\/li>\n<li><a href=\"#content-flame-graph-view-sample\">Flame graph view sample<\/a><\/li>\n<li><a href=\"#content-memory-allocations-graph-view-sample\">Memory allocations graph view sample<\/a><\/li>\n<li><a href=\"#content-allocation-histogram-view-sample\">Allocation histogram view sample<\/a><\/li>\n<\/ul>\n","title":"Get Started with Core and Memory Profiler","raw":null},{"class":"App\\Services\\Documentation\\Data\\RenderedMarkdown","s":"wrbl"}]},{"s":"arr"}]},"memo":{"id":"Qi6VQgjCL1LUUyAIcMqA","name":"__mountParamsContainer","path":"docs\/sdk-tools\/dotnet\/visual-studio\/vstools\/getting-started\/test-profile-app-profiling","method":"GET","release":"a-a-a"},"checksum":"ff6ed1186945409b5149d5308f4dcca159a1404643639fd49a5d470de390a2c0"}')" >
  • For the best experience,
    Please visit us from a computer

    Copyright © 2026 SAMSUNG. All rights reserved.

    Customize your cookie preferences

    You can enable or disable non-essential cookies. Essential cookies are always on to ensure the site works properly and to keep you signed in.

    Necessary

    These cookies are necessary for the website to function properly and cannot be switched off. They help with things like logging in and setting your privacy preferences.

    Always on

    Analytics

    These cookies help us improve the site by tracking which pages are most popular and how visitors move around the site.

    Enable analytics cookies
    Public Forum Public Forum
    Employees only. Please sign in with your company account.