Microsoft MVP성태의 닷넷 이야기
static instance의 initialize 순서가 보장되나요? [링크 복사], [링크+제목 복사],
조회: 3133
글쓴 사람
박지범
홈페이지
첨부 파일
 

안녕하세요.

C++에서 static instance는 선언 순서와 관계 없이 초기화 순서를 보장하지 않는데요.

C#(특히 유니티의 mono)에선 어떤지 찾아보다 본 사이트에 비슷한 류의 질문에 답변을 달아주신 것을 보게 되었습니다.
https://www.sysnet.pe.kr/3/0/5703
해당 답변에서 선생님께서는 static으로 선언된 멤버 변수의 경우, 선언한 순서대로 초기화된다고 말씀해주셨습니다.

간단한 싱글턴 클래스를 가정해보겠습니다.



public class EagerInitialization {

    private static EagerInitialization instance = new EagerInitialization();
    private EagerInitialization() {}
    
    public static EagerInitialization getInstance() {
        return instance;
    }
}

위와 똑같은 싱글턴 클래스가 파일 A에 순서대로 1~3개, 파일 B에 1개 존재한다고 했을 때
총 4개의 싱글턴 클래스가 가지고 있는 static 멤버 변수의 초기화 순서를 알 수 있는 건가요?








[최초 등록일: ]
[최종 수정일: 2/27/2023]


비밀번호

댓글 작성자
 



2023-02-27 02시18분
질문하신 것과, 링크한 5703의 글은 다소 상황이 다릅니다.

링크한 글의 경우, class 내에 정의한 필드들의 초기화 순서가 동일하다는 것을 의미합니다. 반면 질문하신 상황에서는 파일에 정의한 클래스들에 있는 static 필드들의 초기화 순서를 묻는 건데요, 그건 static 필드에 대한 지식이 없어서 그런 질문을 하게 된 것입니다.

닷넷 프로그램은 static으로 정의된 필드를 프로그램 시작 시 일괄적으로 실행하지 않습니다. 그것들이 실행되는 시점은, "해당 클래스가 사용되는 최초 시점"입니다.

따라서, "파일 A" 또는 "파일 B"에 몇 개의 static 필드가 있다고 해도, 중요한 건 해당 파일에 있는 클래스들을 "사용하는 순"으로 초기화가 됩니다. (혹시 제 책을 가지고 계시다면 "4.1.5 정적 멤버, 인스턴스 멤버"를 참고하세요.)
정성태
2023-02-27 02시30분
[박지범] 답변 감사합니다.
질문을 올리고 내용을 약간 수정했는데, 제가 등록버튼을 안눌렀나보네요ㅠ
그럼에도 제가 궁금하던 내용에 대해 정확하게 답변해 주셔서 정말 감사합니다.
큰 도움이 되었습니다.
[guest]
2023-02-27 02시56분
[박지범] 게시물 수정이 안돼 부득이하게 댓글로 남깁니다.

C++에서 static, 즉 정적 객체는 다음과 같이 구분합니다.

  (1) 전역객체

  (2) namespace 유효범위에서 정의된 객체

  (3) 클래스 안 static 객체

  (4) 함수 안 static 객체

  (5) 파일 유효범위에서 static으로 정의된 객체


이 중 3, 4를 지역 전역 객체, 나머지는 비지역 전역 객체로 구분합니다.
C#에서는 특별한 구분은 없는 것 같습니다만, 클래스 혹은 함수 내에 선언된 정적 변수의 경우
선언한 순서대로 초기화 순서가 보장됩니다.

C++은 프로그램이 실행될 때(컴파일 언어임)
C#은 해당 정적 변수를 최초로 호출할 때(C 기반이지만 하이브리드 언어라서 가능)

정적 변수들을 초기화합니다.

제 질문처럼 다른 파일에 나눠서 선언된 경우

C++ - 알 수 없음.
C# - 호출될 때 초기화함으로 알 수 있음.

이렇게 구분할 수 있겠습니다.
[guest]
2023-02-27 02시56분
[박지범] 한줄이 빠졌는데, 비슷한 궁금증을 가지고 이곳으로 오실 분들을 위해 별첨합니다.
[guest]
2023-02-27 03시08분
위의 의견에 대해 약간 오해의 여지가 있어 첨언합니다.

C#에서는 함수 내에 static 변수가 없습니다. (목록에서라면 오직 3번 유형에 대해서만 지원합니다.)

C#은 "해당 정적 변수를 최초로 호출할 때"가 아니고, 해당 (변수 및 메서드 호출을 포함해) "타입"을 최초로 접근할 때입니다. 또한, C#의 이런 특징은 "C 기반이지만 하이브리드 언어"라기 보다는 JIT 컴파일 언어의 특성에 기인합니다.
정성태
2023-02-27 03시20분
[박지범] 첨언 감사합니다. 졸업한지 시간이 좀 돼서, 기초 cs부분의 희미한 기억을 가지고 작성하다보니 오류가 많네요.
[guest]

... 16  17  18  19  20  21  22  [23]  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
5348776/19/20206149시작하세요 C# 8.0프로그래밍 책에 대한 질문입니다. [8]
5347민성6/19/20206974안녕하세요 WPF Binding에서요 [1]
5346dimo...6/18/20207036Task.WhenAll() 메소드를 이용한 코드를 좀더 짧게 사용하고 싶은데 다른 표현이 있을까요? [3]
5345질문요6/12/20206102idc vs 집 속도 [2]
5344하태6/2/20207223c++ .ilb에서 c# dll 호출 질문 드리겠습니다 (콜백함수 전달) [4]
5343하태6/2/202010158안녕하십니까! c# dll을 c++ .lib에서 호출 질문 드립니다. [6]
5342진우5/30/202011327c++ 에서 C# DLL 사용 문의 [2]
5341미나리5/28/20207052스레드 lock키워드 관련 질문드립니다 [3]
5339민성5/27/20206355WPF cmd을 실행을 할때 파라미터 넘기는 방법 [1]
5338서영준5/26/20208219.Net Core Blazor 서버에 Xing API를 이용한 통신 요청 [5]파일 다운로드1
5337ogos...5/26/20208413C# DB connection string 보호 방법에 대하여 [2]
5336saki5/21/20208337이벤트 뷰어 .NET Runtime 오류 [3]
5335민성5/21/20206563안녕하세요 C#으로 컴퓨터 시작프로그램 목록을 가져와서 사용안함으로 바꿀려면 [1]
5334민성5/19/20206892안녕하세요 WPF 콘솔창을 띠우면서 Ping이라는 명령어가 콘솔에 Write되게 할려면 어떻게 해야 하나요?? [1]
5333초보5/18/20206959공유 메모리 관련 문의 [2]
5332질문요5/15/20206820TcpListener TcpClient 문의 [4]
5331sdd5/13/20206673안녕하세요 Settings관련하여 질문드립니다. [2]파일 다운로드1
5330하태5/7/202011015안녕하세요! 질문 드리겠습니다! C# dll에서 c++ CLR프로젝트를 참조 추가 할 수 있나요? [2]
5329김태령4/21/20206558젠킨스에서 원격 머신에 있는 실행 파일을 실행하면 백그라운드로 뜹니다 [2]
5328crea...4/17/20206618안녕하세요! [3]파일 다운로드1
5327김동욱4/17/20206878HttpListener 사용시 HTTP/2 질문입니다. [2]
5323나그네4/15/20206172해결 115p 네임스페이스의 ConsoleApp1.exe는 netcoreapp3.1 폴더에 있었습니다. [1]파일 다운로드1
5322나그네4/14/20207128질문 115p 네임스페이스의 ConsoleApp1.exe 컴파일 또는 빌드방법 [2]파일 다운로드1
5321나그네4/14/20208054오타인가요? [2]
5320kiki...4/10/202010252C# Serial 통신 관련 질문 입니다. [5]
5319권대현4/10/20206462C++(UWP)Dll에서 C#(UWP)Dll 호출이 가능한가요? [1]
... 16  17  18  19  20  21  22  [23]  24  25  26  27  28  29  30  ...