RTI Connext .Net APIs
Version 5.3.1
|
Unsupported utility APIs. More...
#include <managed_config_dotnet.h>
Static Public Member Functions | |
static void | spin (System::UInt64 spinCount) |
Performs the spin operation as many times as indicated. More... | |
static System::UInt64 | get_spin_per_microsecond () |
Returns the number of spin operations to perform to wait 1 microsecond. More... | |
static System::Boolean | enable_heap_monitoring () |
Starts monitoring the heap memory used by RTI Connext. More... | |
static void | disable_heap_monitoring () |
Stops monitoring the heap memory used by RTI Connext. More... | |
static System::Boolean | pause_heap_monitoring () |
Pauses heap monitoring. More... | |
static System::Boolean | resume_heap_monitoring () |
Resumes heap monitoring. More... | |
static System::Boolean | take_heap_snapshot (System::String^ filename, System::Boolean print_details) |
Saves the current heap memory usage in a file. More... | |
Unsupported utility APIs.
|
static |
Performs the spin operation as many times as indicated.
Spinning is the action of performing useless operations in a for loop in order to actively wait some time without yielding the CPU. Given that the resolution of sleep is in the order of ms, you can use this utility to wait times in the order of microseconds. To properly use this functionality, it is useful to measure previously the number of spin operations needed to wait the equivalent to 1 microsecond (using the utility get_spin_per_microsecond) and then compute the corresponding spin count desired.
spinCount | <<in>> Number of spin operations to perform. |
|
static |
Returns the number of spin operations to perform to wait 1 microsecond.
This utility can be used to measure how many spin operations must be performed to wait 1 microsecond. Since the time that it takes the CPU to perform 1 spin operation depends on the CPU frequency, it is recommended to use this utility before using spin().
|
static |
Starts monitoring the heap memory used by RTI Connext.
This function must be called before any other function in the RTI Connext library is called.
Once heap monitoring is enabled, you can take heap snapshots by using NDDS::Utility::take_heap_snapshot.
Use this method only for debugging purposes, as it may introduce a significant performance impact.
|
static |
|
static |
Pauses heap monitoring.
New memory allocations will not be monitored and they will not appear in the snapshot generated by NDDS::Utility::take_heap_snapshot.
|
static |
Resumes heap monitoring.
|
static |
Saves the current heap memory usage in a file.
After NDDS::Utility::enable_heap_monitoring is called, you may invoke this method periodically to save the current heap memory usage to a file.
By comparing two snapshots, you can tell if new memory has been allocated and in many cases where. This is why this operation can be used to debug unexpected memory growth.
The format of a snapshot is as follows:
First, there is a memory usage summary like this:
After the previous summary, and only if you set the parameter print_details to true, the method will print the details of every single outstanding heap allocation done by RTI Connext. For example:
filename | <<in>>. Name of file in which to store the snapshot. |
print_details | <<in>>. Indicates if the snapshot will contain only the memory usage summary or the details of the individual allocations. |