yuchi's Development Home


윈폰개발은 여기까지 하려고 했는데 일단 크래시하는 원인이 너무 찜찜해서 정확히 원인을 파악하고자 열심히 디버깅을 시도.


크래시 원인이 메모리 부족인건 확실해보인다. 다만 에뮬레이터나 리얼폰이나 1GB메모리를 장착하고 있다. 메모리 부족 현상이 너무 빨리 오는것 같아서 이상하다고 생각했다.


내 코드가 CRT힙에서 할당한건 대략 60MB 정도.
버텍스버퍼,텍스쳐,인덱스 버퍼는 정확히 얼마를 썼는지 알수가 없는데 적어도 100MB는 될거고. 그럼 최소한 160MB를 소모했다는건데 페이징이 없는 모바일 환경에선 160MB로도 메모리 부족이 올 수는 있다.


일단 최대 사용 가능한 메모리가 얼마인지 찾아봤다.아래링크

http://msdn.microsoft.com/en-us/library/windowsphone/develop/jj681682(v=vs.105).aspx


디폴트로 앱이 사용할 수 있는 메모리는 150MB가 한계.


과연...DX에서 다수의 버텍스 버퍼 개수를 할당하지 못하는게 문제라고 생각했는데 메모리 할당량 제한에 걸렸다고 보는게 맞다.

일단 이 문제를 어느 정도 피해갈 수 있는 방법이 있는데 앱매니페스트에서 ID_FUNCCAP_EXTEND_MEM를 설정해서 메모리 1GB메모리 폰 기준으로 한계 메모리를 300MB까지 확장할 수 있다고 문서에 나와있다.

iOS쪽은 정확히 얼마인지 모르겠는데 내 경험상 딱 가이드라인이 정해진건 아니고 Low-Memory 경고 받을때까진 계속 사용할 수 있었던걸로 기억한다. 찾아봐도 정확히 얼마란 얘긴 안나오네.

하여간 매니페스트 파일을 수정하고 다시 빌드. 테스트 해보니 문제가 되었던(메모리를 좀 많이 먹었던) 전투필드도 제대로 로드 된다.

결국 모든건 메모리 문제..속도는 생각만큼 느리지 않다.
램2GB폰이 나오던지 내가 리소스를 더 팍팍 줄이던지 하면 풀버젼의 클라이언트도 윈폰으로 돌릴 수는 있을것 같다. 어차피 윈폰 사용자들은 대부분 저가폰을 사용하니 뭐 이건 자기만족으로 끝날 가능성이 높지만.

아 근데..대체 윈폰에서 C++ 코드만 사용해서 내 프로세스 메모리 사용량 얻어올 방법은 없는것인가. 

뭐좀 하려고 하면 다 C++에선 지원되지 않는대. 

DirectX는 C++ 네이티브로 짜라면서 시스템이나 UI관련 API는 C#만 지원하면 어쩌라고.
프로파일러도 네이티브 코드에선 매우 제한적으로 지원됨. 메모리 사용량도 안나옴.

제발 다음 버전에선 네티이브 코드 지원좀 제대로 해줬음 좋겠다.

어쨌건 이제 제대로 돌아는 간다.언제 메모리 부족으로 죽을지 몰라 겁나긴 하지만.


WinPRT_PrjDAIKON03.PNG

List of Articles
번호 제목 글쓴이 날짜 조회 수
201 제가 필요해서 만든 OneDrivePlayer가 윈스토어에 올라갔네요. [2] 여치 2014-08-23 6008
200 기적같은 디버깅. 컴파일러 버그? 역시나 그럴리가. [3] 여치 2014-05-14 5778
199 초간단 SIMD(Single Instruction Multiple Data)최적화 성능 테스트 file 여치 2014-04-10 3428
198 진행중인 프로젝트 Visual Studio 2010 -> Visual Studio 2013으로 이전 [2] 여치 2014-04-10 2180
197 Windows Phone 8과 PC간 네트워크 플레이 여치 2013-11-22 875
» Windows Phone 8로 게임포팅 중 생긴 난관 - Windows Phone 8 에서 App당 사용 가능한 최대 메모리 file 여치 2013-11-21 911
195 윈폰8 포팅 중단. file 여치 2013-11-19 482
194 Windows Phone 8로 게임 포팅중 #2 여치 2013-11-18 499
193 Windows Phone에 게임 포팅중. 여치 2013-11-17 365
192 현재까지 느낀 Windows Phone 8용 게임 개발에 있어서의 장애물. [2] 여치 2013-11-07 1007
191 Windows Phone 8 디바이스를 몇 일 사용해보고 알게 된 것들. 여치 2013-11-01 332
190 Surface RT에서 유선랜 사용하기 여치 2013-10-26 1066
189 win8 sdk에서 ddraw.lib 위치 여치 2013-09-11 1004
188 TFS에서 Get Latest Version해도 갱신할 파일 없다고 나올 때 여치 2013-08-31 1242
187 dx9 debug 런타임이 활성화 안될 때 여치 2013-08-25 3499
186 인디게임 FEZ 개발자 필 피쉬, 최근 일본 게임에 대한 평가 - 그리고 내 생각 [2] 여치 2013-07-31 1856
185 The database principal owns a schema in the database, and cannot be dropped 여치 2013-05-23 4087
184 Using Windows 8* WinRT API from desktop applications 여치 2013-03-10 9077
183 WinRT 디바이스 디버깅에서 DEP0100 : Deployment failed due to a Developer Licensing issue에러를 만났을때 여치 2013-03-04 13064
182 계속되는 MS의 삽질에 대한 생각. [3] 여치 2013-02-15 12646
天安門大屠殺 六四天安門事件 反右派鬥爭 大躍進政策 文化大革命 六四天安門事件 The Tiananmen Square protests of 1989 天安門大屠殺 The Tiananmen Square Massacre 反右派鬥爭 The Anti-Rightist Struggle 大躍進政策 The Great Leap Forward 文化大革命 The Great Proletarian Cultural Revolution 人權 Human Rights 民運 Democratization 自由 Freedom 獨立 Independence 多黨制 Multi-party system 民主 言論 思想 反共 反革命 抗議 運動 騷亂 暴亂 騷擾 擾亂 抗暴 平反 維權 示威游行 法輪功 Falun Dafa 李洪志 法輪大法 大法弟子 強制斷種 強制堕胎 民族淨化 人體實驗 胡耀邦 趙紫陽 魏京生 王丹 還政於民 和平演變 激流中國 北京之春 大紀元時報 九評論共産黨 獨裁 專制 壓制 統一 監視 鎮壓 迫害 侵略 掠奪 破壞 拷問 屠殺 肅清 活摘器官 障テ社會 誘拐 買賣人口 遊進 走私 毒品 賣淫 春畫 賭博 六合彩 台灣 臺灣 Taiwan Formosa 中華民國 Republic of China 西藏 土伯特 唐古特 Tibet 達償ワ喇嘛 Dalai Lama 新疆維吾爾自治區 The Xinjiang Uyghur Autonomous Region free tibet



XE Login

天安門大屠殺 六四天安門事件 反右派鬥爭 大躍進政策 文化大革命 六四天安門事件 The Tiananmen Square protests of 1989 天安門大屠殺 The Tiananmen Square Massacre 反右派鬥爭 The Anti-Rightist Struggle 大躍進政策 The Great Leap Forward 文化大革命 The Great Proletarian Cultural Revolution 人權 Human Rights 民運 Democratization 自由 Freedom 獨立 Independence 多黨制 Multi-party system 民主 言論 思想 反共 反革命 抗議 運動 騷亂 暴亂 騷擾 擾亂 抗暴 平反 維權 示威游行 法輪功 Falun Dafa 李洪志 法輪大法 大法弟子 強制斷種 強制堕胎 民族淨化 人體實驗 胡耀邦 趙紫陽 魏京生 王丹 還政於民 和平演變 激流中國 北京之春 大紀元時報 九評論共産黨 獨裁 專制 壓制 統一 監視 鎮壓 迫害 侵略 掠奪 破壞 拷問 屠殺 肅清 活摘器官 障テ社會 誘拐 買賣人口 遊進 走私 毒品 賣淫 春畫 賭博 六合彩 台灣 臺灣 Taiwan Formosa 中華民國 Republic of China 西藏 土伯特 唐古特 Tibet 達償ワ喇嘛 Dalai Lama 新疆維吾爾自治區 The Xinjiang Uyghur Autonomous Region free tibet