다음을 통해 공유


CA2014: 루프에서 stackalloc를 사용하지 마세요.

속성
규칙 ID CA2014
제목 루프에 stackalloc를 사용하지 마세요.
범주 신뢰성
수정 사항이 호환성을 깨뜨리는지 여부 또는 무중단인지 여부 주요 변경 아님
.NET 10에서 기본적으로 사용하도록 설정 경고로서
적용 가능한 언어 C#

원인

루프 내에서 C# stackalloc 식을 사용하고 있습니다.

규칙 설명

C# stackalloc 식은 현재 스택 프레임에서 메모리를 할당하고 해당 메모리는 현재 메서드 호출이 반환된 다음에야 해제될 수 있습니다. stackalloc이 루프에서 사용되는 경우 스택 메모리가 모두 사용되어 스택 오버플로가 발생할 수 있습니다.

위반 문제를 해결하는 방법

stackalloc 식을 메서드의 모든 루프 외부로 이동합니다.

Example

// This method violates the rule.
public void ProcessDataBad()
{
    for (int i = 0; i < 100; i++)
    {
        // CA2014: Potential stack overflow.
        // Move the stackalloc out of the loop.
        Span<int> buffer = stackalloc int[100];
        buffer[0] = i;

        // ...
    }
}

// This method satisfies the rule.
public void ProcessDataGood()
{
    Span<int> buffer = stackalloc int[100];

    for (int i = 0; i < 100; i++)
    {
        buffer[0] = i;

        // ...
    }
}

경고를 표시하지 않는 경우

모든 stackalloc 작업에서 할당된 전체 메모리 양이 상대적으로 작은 것으로 알려진 경우처럼 포함하는 루프가 한정된 횟수로만 호출되는 경우 경고를 표시하지 않아도 됩니다.

경고 표시 안 함

단일 위반을 억제하려면 원본 파일에 전처리기 지시문을 추가하여 규칙을 비활성화한 후 다시 활성화하십시오.

#pragma warning disable CA2014
// The code that's violating the rule is on this line.
#pragma warning restore CA2014

파일, 폴더 또는 프로젝트에 대한 규칙을 사용하지 않으려면 구성 파일에서 none의 심각도를 설정합니다.

[*.{cs,vb}]
dotnet_diagnostic.CA2014.severity = none

전체 규칙 카테고리를 사용하지 않도록 설정하려면 구성 파일에서 none의 범주 심각도를 으로 설정합니다.

[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-Reliability.severity = none

자세한 내용은 방법: 코드 분석 경고 표시 안 함을 참조하세요.

참고하기