Microsoft MVP성태의 닷넷 이야기
Winform UserControl 상속 vs 감싸기? [링크 복사], [링크+제목 복사],
조회: 6179
글쓴 사람
김성민 (mad7322 at gmail.com)
홈페이지
첨부 파일
 

안녕하세요.
여기저기 찾아 봤지만 마땅한 자료를 찾을 수 없어서,..
혼자서만 개발을 해오다 보니 물어볼곳이 없어서 찾아오게 되었습니다.

Syncfusion이나 Devexpress 같은 외부 UI 컨트롤을 사용하여
자체 컴포넌트를 개발을 하려고 합니다.

이때 종속성을 최대한 없애려고 하는데 아래 2가지 방법중 어느것이 더 나은 방법인지에 대해
질문 드리고자 합니다.


1. 상속
public partial class MyTextBox : Syncfusion.Windows.Forms.Tools.TextBoxExt
{
}

2. 감싸기??
public partial class MyTextBox : Control (또는 UserControl)
{
  private Syncfusion.Windows.Forms.Tools.TextBoxExt _base = new Syncfusion.Windows.Forms.Tools.TextBoxExt();

  public MyTextBox()
  {
    _base.Parent = this;
  }
}


원래는 2번의 방법으로 하려고 했습니다. 제가 원하는 기능만 public으로 제공할 수 있고 나중에 교체를 해도 전체 프로그램에 영향이 가지 않아서요.
그런데 저렇게 할 경우에는 문제가 Form에서 MyTextBox을 생성하면 Control 내부에 Control이 생기면서 실질적인 TextBox(_base)가 내부 Control에 위치 하면서 2중 구조가 된다는 겁니다.

  // text.Controls[0]가 존재하게 됨
  MyTextBox text = new MyTextBox();

개인적으로 이렇게 되면 MyTextBox를 생성할때마다 실제로는 2배의 Control이 생기게 되고, 프로그램의 부피가 커지면 성능에 영향을 끼치지 않을까 생각합니다.
뭔가 Form 내부에 Control이 필요없이 생긴다는 찜찜함도 있고요.

그렇다고 1번의 방법으로 가기도 좀 그런 것이...
1번의 방법은 상속을 받기 때문에 Public으로 된 모든 메소드와 속성이 외부에 노출이 되고
이는 곳 종속성이 생길수 밖에 없는 구조기 때문입니다.

뭐가 더 좋은 방법인지, 아니면 다른 좋은 방법이 있는지 질문 드립니다.








[최초 등록일: ]
[최종 수정일: 1/13/2021]


비밀번호

댓글 작성자
 



2021-01-13 07시00분
당연히 그런 경우에는 1번 방식으로 하는 것이 좋습니다. public으로 인한 종속성 걱정은, 별도 인터페이스를 만들어 사용 측에서 가능한 인터페이스를 통해 접근하도록 신경쓰는 수고가 필요합니다. 아니면 2번의 방법에서 자식 컨트롤로 제공하지 않고 그것 스스로 Control의 기능을 구현하며 내부적인 동작을 Syncfusion 또는 Devexpress의 컨트롤로 이양을 시켜야 하는데 그 작업은 오히려 말도 안 되는 코딩양이 될 것입니다.

감싸기의 경우는, 복합 컨트롤을 자식으로 두고 사용할 때 유용합니다. 물론 컨트롤이 많지 않다면 이런 경우에도 방법일 수 있는데, 당연히 많아지면 성능이 떨어질 수 밖에 없습니다.

사실, 벤더가 바뀌는 차원의 종속성을 제거하는 것은 어떤 식으로 해도 힘듭니다. 예를 들어, DB의 경우에는 마이크로소프트 측에서 System.Data에 정의한 인터페이스로 모든 db provider들이 구현하고 있기 때문에 그나마 쉽게 가능한 것입니다. 하지만 그런 DB 조차도 SQL 서버에서 오라클로 바뀌면 벤더 의존적인 쿼리들은 모두 변경해야 하는 수고가 따르기 때문에 엄밀히는 포팅이 쉽다 뿐이지 100% 종속성이 제거된 것은 아닙니다.
정성태
2021-01-13 10시50분
[김성민] 답변 감사합니다. 아직 어떤식으로 작업을 할지에 대해서 결정을 하지는 못했지만 답변 주신내용이 좋은 참고가 될 것 같습니다. 종속성을 100% 버릴 수 없다면 최선이 될 수 있도록 방법을 강구해 봐야 겠네요.
[guest]

... 16  17  18  19  20  21  22  23  24  25  26  [27]  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
5219티지레몬9/9/20199657c# PCB 자동화 프로그램(윈도우 폼 위주로 작업) 제작 준비 [3]
5218민성9/9/20197699안녕하세요 WPF에서 xaml 안에 다른 xaml을 넣고 싶습니다. [1]파일 다운로드1
5216WPF9/8/20198793WPF에서 XAML Islands를 사용하여 Win2D를 사용하니 그래픽 품질이 저하됩니다. [2]파일 다운로드1
5215허송세월9/5/20198598중복실행 방지 관련 문의 [2]파일 다운로드1
5214Jang...9/4/20198215[DB 테이블의 데이터 변경에 대한 알림 처리] SQL-Server말고 MySQL은 불가능하겠죠? [1]
5213진우8/31/20197471c# 람다 변수 캡쳐 문의 [2]
5212심성보8/29/20199139Clipboard내 여러개의 이미지를 PictureBox로 불러오는 문제 [2]
5211최휘철8/24/20198313CLR20r3 관련된 윈도우 오류입니다. ㅠㅠ 도와주세요. / 아래글 관련하여 관련 파일 올려 드려요^^ [1]파일 다운로드1
5210최휘철8/23/201912227CLR20r3 관련된 윈도우 오류입니다. ㅠㅠ 도와주세요. [5]
5209세퉁8/21/20197864폰트 파일 속성 값을 가져오는 방법 질문 드립니다. [2]파일 다운로드1
5208홍길동8/19/20198693DebugDiag에서 .Net의 Stack Trace를 Windbg에서는 어떻게 볼 수 있나요? [3]
5207민성8/16/20197039네 소스 전체를 올리도록 하겠습니다. [2]파일 다운로드1
5206민성8/14/20197179전 재현 가능하다고 봤는데 다시올리도록 하겠습니다. [1]
5205miny...8/14/20198003안녕하세요 .WPF ListBox시 체크박스가 있는데 체크박스에서 체크가 되었는지 알수 있는 방법이 있을까요? [1]
5204영민8/8/201910780안녕하세요 디버깅시 콘솔창을 띠어서 볼수가 없나요? [7]
5202민성8/6/20197520WPF에서 <Application.Resources에 xaml에 있는 icon 값을 저장하고 xaml에 불러다 사용하고 싶은데요 [1]
5201김대훈8/3/20197126상속시 생성자에 대해 질문드립니다 [3]
5200농상7/30/20199822foreach로 데이터 변경 [2]
5190오리다람7/20/20197231질문드립니다. [3]
5189진우7/19/20197796C# 스레드풀 코어별 실행 문의 [2]
5188황태관7/19/20196987비주얼베이직 2019 실행 할때 마다.. [3]
5187플하7/19/20199808UWP 관련 궁금한 사항에 대해서 [1]
5186김대훈7/14/20198421박싱과 언박싱에 대해 [2]
5185농상7/13/20197274Nullable에 대해서 [1]
5184김대훈7/4/20197146저자님의 책을 다 본후에는 [2]
51837/2/20197861.NET Compact Freamwork 컨트롤러 더블버퍼링 [1]
... 16  17  18  19  20  21  22  23  24  25  26  [27]  28  29  30  ...