Microsoft MVP성태의 닷넷 이야기
InitializeComponent 함수 호출 지연 현상 [링크 복사], [링크+제목 복사]
조회: 10113
글쓴 사람
김아영 (aykim at kriso.re.kr)
홈페이지
첨부 파일
 


안녕하세요!

프로그램을 하나 구현 했는데요 ..
제 작업 PC와 몇군데 테스트 해본 PC에서는 문제가 없는데요.
납품해야 할 PC에서는 처음에 폼띄우는게 너무 오래걸리네요.

그래서 메시지 박스를 여러군데 띄워놓고 확인해보니까, InitializeComponent 함수를 호출하는 순간 지연되는 현상이 나타납니다.
안에 컨트롤들도 단순하게 버튼이나 체크박스뿐인데요 ..
 
첨엔 컨트롤에서 문제가 생기나 해서 컨트롤 들을 조금씩 지워서 해봤는데도 똑같더라구요 ㅜㅜ
(다 지우기엔 컨트롤이 너무 많아서 다른 코드들에 너무 영향을 많이 끼쳐 확인하지 못하고 의심가는 컨트롤들만 확인 했어요..)

어쨋든 정리해 보면 ..
아래 함수를 호출하는 부분에서 호출전에 메시지 띄우고 나서 아래 메시지 띄우는 부분까지 한참 걸리네요..

public Form()
{
     // 첫 번째 아래 함수 호출 전 메시지 띄우는 곳 !
     InitializeComponent();
}

InitializeComponent()
{
     // 이 부분에 메시지를 띄웠는데, 첫 번째 메시지가 뜨고 나서 이 메시지가 뜨는데 한참 걸립니다 ..

     // 자동 생성된 코드 ..
}

도무지 감이 안오네요 .. ㅜㅜ
그렇다고 PC 환경이 특별히 다를 것도 없는데 그러네요 ..
제 작업 PC와 설치 PC 모두 Win7 32bit 이거든요 ..

조언 부탁 드려요!

 










[최초 등록일: ]
[최종 수정일: 5/29/2014]


비밀번호

댓글 작성자
 



2014-05-29 01시11분
Form 메서드에서 InitializeComponent 하기 전 메시지를 띄우고, InitializeComponent 메서드의 첫번째 코드로 메시지를 띄웠는데 그 시간이 오래 걸렸다는 것으로 이해되는데 맞나요?

현상만 듣고는 제가 경험해 본적이 없어서 뭐라고 말을 못하겠군요. ^^ 이론상으로 보면, 그 시간은 InitializeComponent 메서드의 IL 코드를 JIT 컴파일링 하는 시간외에는 없습니다. 그렇다면, 그 메서드의 코드가 비정상적으로 크다거나... 하는 식의 문제가 있어야 하는데, 그런 경우는 흔치 않을 테니 더 생각나는 것이 없군요.

어쩔 수 없을 것 같습니다. 어쨌든, 현상이 재현되는 컴퓨터에서 코드에 주석을 좀더 달아보시고 판단해 보는 수 밖에는.
정성태
2014-05-30 01시00분
[김아영] 그렇군요 ..

일단 이해하신 것이 맞습니다 ~
저도 아무리 고민을 해봐도 이유를 찾지 못하겠네요.
해당 PC를 제외하고 5군데 이상의 PC에서 테스트를 해봤지만 문제가 없거든요.
결국은 PC를 교체해야할 듯 싶긴 하네요 .. ㅜ
(해당 PC에서는 디버그를 할 수 없는 상황이네요.. 그래서 메시지로 확인한 것이거든요 ㅜㅜ 어느 구간이 느린지 확인하기 위해 ..)

무튼 답변 감사 드립니다 ^_^
[guest]
2014-05-30 01시10분
PC를 교체할 정도의 권한인데도 ^^ 디버그를 할 수 없다는 것이 잘 이해가 안됩니다. 암튼, 이런 케이스는 지금 당장은 피할 수 있어도 나중에 또 어느 순간 발생할 수 있기 때문에 현재 100% 재현이 되는 상황에서 문제를 최대한 살펴보시는 것이 좋지 않을까 싶습니다. (디버깅 경력이 쌓이다 보면... 100% 재현이 얼마나 축복인지 새삼 느끼게 됩니다. ^^)
정성태
2014-05-30 04시03분
[김아영] 아 그게요..

현장에 설치하는 PC인데, 해당 PC에 개발 환경이 준비가 되어 있질 않습니다..
교체하는 것도 사수와 협의해야하는 부분이거든요 .. ㅜ

말씀하신 것처럼 문제를 해결하고 가는 것이 좋겠지만 여건이 좋진 않네요 ㅜㅜ
전 대전에 거주하고 .. 현장은 여수 촌동네라 ..

교체 부분이 허락되지 않는다면 개발 환경을 설치해서 잡고 가겠죠 ~
문제점 발견하게 되면 알려 드리도록 하겠습니다 ^_^
즐거운 하루되세요 ~ !
[guest]
2014-05-30 12시51분
^^ 넵. 원인 파악 되시면 꼭 댓글 부탁드립니다.
정성태

... 31  32  33  34  35  36  37  38  39  40  41  42  43  [44]  45  ...
NoWriterDateCnt.TitleFile(s)
4745힘찬도약7/27/201612042.NET 자식창 데이터를 부모창에 전달시 오류 질문드립니다. [4]파일 다운로드1
4744변찬연7/27/201611809안녕하세요 그 edge를 이용하는 데 조금 불편함이 있어서 문의드립니다 [1]
4743딸랑구아빠7/26/201610738IE 사용 시 인증 정보 계속 보내기? [1]
4741차가워7/20/201612358UWP 에서 COM 참조 불가능한가요? [6]
4740luna...7/19/201612759clickonce manifest 파일 질문 [1]
4739윤똘씨7/19/201612196정말 감동적입니다... [7]
4738닷넷초보7/7/201611077안녕하세요. C#의 개체 전달방식(참조)에 관련해서 질문 있습니다. [3]파일 다운로드1
4737beau...7/6/201613399python embedding 한 c++ 프로그램의 배포에 관해서 질문드리고 싶습니다. [1]
4736spow...7/6/201610287Property Lambda에 대한 심층 분석을 의뢰합니다 [7]
4735힘찬도약7/5/201611416.Net/Web.config에서 MSSQL을 쓰는데, MysqlSiteMap 참조오류 [3]파일 다운로드1
4734spow...6/28/201610986Visual Studio 2015 + Windows Forms 환경에서 컴파일 할 때 드물게 개발환경이 Crash 됩니다 [1]
4733feel...6/15/201611459타 서버로 소스 이전 중 [3]파일 다운로드1
4732구봉근6/14/201610202안녕하세요 [1]파일 다운로드1
4731초급개발자6/7/201612750Windows Form Application는 사라질까요? [2]
4730김시현6/4/201610807책으로 공부하던 도중 생성자에 대해서 궁금한게 생겼는데 혹시 답변좀 해주실수 있나요? [1]
4729Jeah...6/3/201612258C#.Net 프로그램에서 C++로 만들어진 dll 파일 이용관련 문의 하나 드립니다. [3]
4727링거5/30/201610910WPF MediaElement 파일 실행 후 삭제시 오류 문의 [1]파일 다운로드1
4728링거5/30/201611280    답변글 [답변]: WPF MediaElement 파일 실행 후 삭제시 오류 문의 [2]파일 다운로드1
4726spow...5/25/201610727덧글을 달고 나서 F5를 눌렀을 때 똑같은 덧글이 달리는 현상 고쳐주세요 [4]
4725Futu...5/23/201611185책 잘보고 있습니다. Task관련 질문을!!! [1]
4724학생15/23/201612469웹소켓과 소켓 관련해서 질문 드립니다. [2]
4722지나가던...5/15/201614302Part 3 pdf파일 그림 재수정 문의 [1]
4723지나가던...5/16/201611541    답변글 [답변]: Part 3 pdf파일 그림 재수정 문의 [1]
4721김종희4/30/2016116913D 시뮬레이션 개발 [1]
4720DC4/29/201611083C# 6.0 델리게이트 인스턴스화 관련 질문~ [2]
4719이민구4/29/201612026[시작하세요! C# 프로그래밍] 4.5.1.6 열거형 마지막 예제 질문입니다. [4]파일 다운로드1
... 31  32  33  34  35  36  37  38  39  40  41  42  43  [44]  45  ...