Microsoft MVP성태의 닷넷 이야기
이벤트 접근 제한자 질문 있습니다. [링크 복사], [링크+제목 복사],
조회: 8156
글쓴 사람
한예지 donator
홈페이지
첨부 파일
 

선생님 안녕하세요!

이벤트는 접근 제한자가 public으로 선언되어 있어도 클래스 외부에서는 호출이 불가능한데

뭐하러 public 으로 선언할 수 있도록 허락했을까요?

private로 강제하면 event를 사용하는 사람도 직관적으로

"아, 이거는 외부에서 사용할 수 없구나." 하고 알 수 있을 텐데 말이죠...

마소는 똑똑하기 때문에 저만 모르는 이유가 있다고 생각하는데 혹시 어떤 이유 때문일까요????...








[최초 등록일: ]
[최종 수정일: 5/19/2022]


비밀번호

댓글 작성자
 



2022-05-19 10시57분
private이었으면 외부에서 접근조차 할 수 없으니 이벤트 구독을 하는 동작도 할 수 없습니다.

아마도 private으로 강제했으면 또 다시 어떤 식으로든 구독을 할 수 있는 "방법"을 제공해야 하는데, 아마도 그 둘 간의 조율 결과가 현재의 문법으로 나온 것일 듯합니다. (글쎄요, 제가 이 부분은 C# 언어를 개발한 당사자가 아니라 정확한 설명이 될 수는 없습니다.)

그리고 이벤트 관련한 문법은 외견상 "필드"나 "공용 속성"을 접근하는 듯하지만 실제 내부에서는 메서드 호출로 바뀝니다. 가령 아래와 같은 코드는,

pg.MyEvent += MyEventImpl;

이렇게 바뀝니다.

pg.add_MyEvent(MyEventImpl);

즉, MyEvent를 사용자가 정의하면 C# 컴파일러는 자동으로 add_MyEvent 메서드를 제공하고 외부에서는 그것을 통해 이벤트 구독/해제를 합니다. 그러니까, 애당초 외부에서는 "MyEvent" 인스턴스를 구할 방법이 없는 형식입니다.

-------

한예지 님이 설명한 방식은 기존의 delegate가 수행하는 동작입니다. 단지 마이크로소프트는 좀 더 정형적인, Windows Forms와 같은 윈도우 컨트롤에서 "이벤트"로써 동작하는 그 어떤 것을 넣고 싶었던 것이고 그렇게 구현한 "event"가 delegate와 같다면 처음부터 event를 넣을 필요도 없었을 것입니다. 일종의 차별화를 둔 것이고, 그것에는 "외부에서 호출할 수 없다"는 규칙을 추가한 것입니다.
정성태
2022-05-20 01시27분
[한예지] 답변 감사드립니다!
[guest]

[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5955tree...11/8/20241285C#12 책 179 페이지 문의 사항 [2]
5954SunN...10/10/20241839textbox에서 글자입력후 textBox1_KeyUp함수에서listBox1_SelectedIndexChanged 강제호출방법 [1]
5953Roya10/4/20241691c# com host dll을 c++에서 사용할 때, sdk 관련 runtime 을 설치 안하고 제공할수 있을까요?? [1]
5952우광현9/5/20242819서버용 소켓 포트 동적포트 적용시 클라이언트가 호출하는 방법? [2]
5951Kun ...8/21/20242597c++에서 복합데이터 Struct를 .NET Framework에서 구현할 수 있는 방법이 있을까요? [2]
5950SunN...8/18/20242940정석대로 한다면 response.Close() 해야되는지요? [4]
5949SunN...8/16/20243064SqlConnection Open()에서 에러가나면 Close()하는 시점 [3]
5948SunN...8/14/20243057WebRequestMethods.Ftp.MakeDirectory 해제 [3]
5947Roya8/7/20243560c# dll을 cpp lib에서 사용을 할려고 하는데요. CoCreateInstance 에서 지정된 파일을 찾을수 없다고 나오는대요. [4]
5946SunN...8/5/20243634TaskDefinition 에서 사용저가로그온상관없이실행 [3]파일 다운로드1
5945SunN...8/3/20243520윈도우 작업스케줄러 [1]
5944roya8/1/20243499C# dll을 C++ 프로젝트에서 사용을 하고 싶은데, 레지스트리 등록 없이 가능한걸까요?? [2]
5943SunN...8/1/20243402윈도우C#에서 리눅스FTP로 업로드 및 리눅스에 폴더생성(WindowsOS에서C#으로) [3]
5942vict...7/24/20243561dll 을 c#에서 쓰고 싶습니다 [1]
5941vict...7/17/20244806DependencyObject와 같은 스레드에서 DependencySource를 만들어야 합니다. 오류 [2]
5940ckm7/16/20244969선생님 안녕하세요 async await 교착 관련 질문입니다 [1]
5939괴물신인7/9/20244862템플릿 대체할수있는방법이 있을까요? [6]
5938씨제바보7/5/20243956책 질문드립니다. [1]
5937Thor... donator5/27/20245097C# 12 는 전자책이 언제쯤 나오게 될까요? [1]
5936ds4/26/20246114활성화 되어 있는 커뮤니티 발견하게 되어 기분이 좋습니다. 자주 놀러 올께요. (내용 없습니다. [2]
5935양승조 donator4/25/20246538Reflection 관련 질문 드립니다. [5]파일 다운로드1
5934양승조 donator4/24/20245039Reflection 관련 질문 드립니다. [1]
5933vict...4/23/20245127cpp 라이브러리 디버깅 방법 문의 드립니다. [1]
5932EK4/12/20245121다음 제네릭에서 널익셉션이 뜨는 이유를 알수있을까요? [1]
5931이대희4/2/20245492Windows 앱 SDK C# 템플릿의 용도가 무엇인지요? [1]
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...