GC.AllocateUninitializedArray<T>(Int32, Boolean) Method
Definition
Important
Some information relates to prerelease product that may be substantially modified before it’s released. Microsoft makes no warranties, express or implied, with respect to the information provided here.
Allocates an array while skipping zero-initialization, if possible.
public static T[] AllocateUninitializedArray<T> (int length, bool pinned = false);
static member AllocateUninitializedArray : int * bool -> 'T[]
Public Shared Function AllocateUninitializedArray(Of T) (length As Integer, Optional pinned As Boolean = false) As T()
Type Parameters
- T
Specifies the type of the array element.
Parameters
- length
- Int32
Specifies the length of the array.
- pinned
- Boolean
Specifies whether the allocated array must be pinned.
Returns
An array object with uninitialized memory.
Remarks
If pinned is set to true
, T
must not be a reference type or a type that contains object references.
Skipping zero-initialization is a security risk. The unitialized array can contain invalid valuetype instances or sensitive information created by other parts of the application. The code operating on unitialized arrays should be heavily scrutinized to ensure that the unitialized data is never read.
Skipping zero-initialization using this API only has a material performance benefit for large arrays, such as buffers of several kilobytes or more.
Applies to
.NET
피드백
https://aka.ms/ContentUserFeedback
출시 예정: 2024년 내내 콘텐츠에 대한 피드백 메커니즘으로 GitHub 문제를 단계적으로 폐지하고 이를 새로운 피드백 시스템으로 바꿀 예정입니다. 자세한 내용은 다음을 참조하세요.다음에 대한 사용자 의견 제출 및 보기