Important This document may not represent best practices for current development, links to downloads and other resources may no longer be valid. Current recommended version can be found here. ArchiveDisclaimer


Microsoft Specific

Applied to a function declaration or definition that returns a pointer type and tells the compiler that the function returns an object that will not be aliased with any other pointers.

__declspec(restrict) return_type f();

The compiler will propagate __declspec(restrict). For example, the CRT malloc function is decorated with __declspec(restrict) and therefore, pointers initialized to memory locations with malloc are also implied to not be aliased.

The compiler does not check that the pointer is actually not aliased. It is the developer's responsibility to ensure the program does not alias a pointer marked with the restrict __declspec modifier.

For similar semantics on variables, see __restrict.

See noalias for an example using restrict.

END Microsoft Specific

© 2016 Microsoft