Partilhar via


Multithreaded Libraries Performance

The single-threaded CRT is no longer available. This topic discusses how to get the maximum performance from the multithreaded libraries.

Maximizing performance

The performance of the multithreaded libraries has been improved and is close to the performance of the now-eliminated single-threaded libraries. For those situations when even higher performance is required, there are several new features.

  • Independent stream locking allows you to lock a stream and then use _nolock Functions that access the stream directly. This allows lock usage to be hoisted outside critical loops.

  • Per-thread locale reduces the cost of locale access for multithreaded scenarios (see _configthreadlocale).

  • Locale-dependent functions (with names ending in _l) take the locale as a parameter, removing substantial cost (for example, printf, _printf_l, wprintf, _wprintf_l).

  • Optimizations for common codepages reduce the cost of many short operations.

  • Defining _CRT_DISABLE_PERFCRIT_LOCKS forces all I/O operations to assume a single-threaded I/O model and use the _nolock forms of the functions. This allows highly I/O-based single-threaded applications to get better performance.

  • Exposure of the CRT heap handle allows you to enable the Windows Low Fragmentation Heap (LFH) for the CRT heap, which can substantially improve performance in highly scaled scenarios.

See Also

Reference

CRT Library Features