다음을 통해 공유


CA1016: AssemblyVersionAttribute로 어셈블리 표시

속성
규칙 ID CA1016
제목 AssemblyVersionAttribute로 어셈블리 표시
범주 디자인
수정 사항이 호환성을 깨뜨리는지 여부 또는 무중단인지 여부 주요 변경 아님
.NET 10에서 기본적으로 사용하도록 설정 제안 사항
적용 가능한 언어 C# 및 Visual Basic

원인

어셈블리에 버전 번호가 없습니다.

규칙 설명

어셈블리의 ID는 다음 정보로 구성됩니다.

  • 어셈블리 이름

  • 버전 번호

  • 문화

  • 퍼블릭 키(강력한 이름의 어셈블리의 경우).

.NET에서는 버전 번호를 사용하여 어셈블리를 고유하게 식별하고 강력한 이름의 어셈블리에 있는 형식에 바인딩합니다. 버전 번호는 버전 및 게시자 정책과 함께 사용됩니다. 기본적으로 애플리케이션은 해당 애플리케이션이 빌드될 때 사용된 어셈블리 버전으로만 실행됩니다.

위반 문제를 해결하는 방법

이 규칙 위반 문제를 해결하려면 System.Reflection.AssemblyVersionAttribute 특성을 사용하여 어셈블리에 버전 번호를 추가합니다.

경고를 표시하지 않는 경우

타사 또는 프로덕션 환경에서 사용하는 어셈블리에 대해서는 이 규칙의 경고를 억제하지 마십시오.

경고 표시 안 함

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

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

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

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

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

예시

다음 예제에서는 AssemblyVersionAttribute 특성이 적용된 어셈블리를 보여 줍니다.

using System;
using System.Reflection;

[assembly: AssemblyVersionAttribute("4.3.2.1")]
namespace DesignLibrary {}
<Assembly: AssemblyVersionAttribute("4.3.2.1")>
Namespace DesignLibrary
End Namespace

참고하기