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
번호 제목 글쓴이 날짜 조회 수sort
201 TFS 사용시 로컬패스 맵핑이 안될 때 처리방법 여치 2011-07-11 39385
200 dx11프로젝트 - 아웃라인 쉐이더 및 테셀레이션 여치 2011-06-06 22798
199 WinRT 디바이스 디버깅에서 DEP0100 : Deployment failed due to a Developer Licensing issue에러를 만났을때 여치 2013-03-04 13089
198 4DyuchiGX #8 맵툴 [4] 여치 2002-09-02 12916
197 계속되는 MS의 삽질에 대한 생각. [3] 여치 2013-02-15 12745
196 WinRT(Windows Store App) 엔진 프로젝트 file 여치 2013-02-12 11817
195 라이트맵 텍스쳐 좌표 생성 코드 개선 file [1] 여치 2006-12-31 11375
194 jailbreaking된 Surface RT에 win32 D3D9엔진을 포팅해 보았다. 여치 2013-02-10 10441
193 제가 필요해서 만든 OneDrivePlayer가 윈스토어에 올라갔네요. [2] 여치 2014-08-23 9425
192 Using Windows 8* WinRT API from desktop applications 여치 2013-03-10 9077
191 vs2010공백 및 탭 표시 핫키 file 여치 2012-08-08 8928
190 x64 어셈을 쓰기 위해 몇 가지 찾아본 결과(현재까지 경과) 여치 2005-12-09 7365
189 Visual Studio 2012 Compiling Native for ARM 여치 2013-02-02 7332
188 iOS엔진 프로젝트 file 여치 2012-09-15 7274
187 포스트 이펙트-글로우 file 여치 2004-12-04 7255
186 dx11프로젝트 - 테셀레이션(Curved PN Triangles) file 여치 2011-03-15 6695
185 기적같은 디버깅. 컴파일러 버그? 역시나 그럴리가. [3] 여치 2014-05-14 6658
184 hlsl ddx,ddy 여치 2012-10-12 6465
183 4DyuchiGX #7 HeightField [5] 여치 2002-09-01 6296
182 iOS엔진프로젝트 file 여치 2012-10-23 6067
天安門大屠殺 六四天安門事件 反右派鬥爭 大躍進政策 文化大革命 六四天安門事件 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