Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 321. Visual Studio Emulator for Android 소개 [링크 복사], [링크+제목 복사],
조회: 23666
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

Visual Studio Emulator for Android 소개

모바일 관련 설치 옵션과 함께 Visual Studio 2017을 설치한 경우 Xamarin 모바일 앱을 빌드하면 기본적으로 에뮬레이터가 "VisualStudio_android-23_x86_phone (Android 6.0 - API 23)"과 같은 항목이 선택됩니다. 이름에서 알 수 있듯이 "x86" 프로세서 용으로 빌드된 것으로 ARM 빌드 버전보다 속도가 빠릅니다. 그런데, Hyper-V가 설치된 환경에서 이를 실행하면 다음과 같은 오류 메시지와 함께 에뮬레이터가 동작하지 않습니다.

1>------ Build started: Project: MyFirstApp.Android, Configuration: Debug Any CPU ------
1>  MyFirstApp.Android -> C:\temp\MyFirstApp\MyFirstApp\MyFirstApp.Android\bin\Debug\MyFirstApp.Android.dll
2>Starting deploy VisualStudio_android-23_x86_phone ...
2>Starting emulator VisualStudio_android-23_x86_phone ...
2>C:\PROGRA~2\Android\ANDROI~1\tools\emulator.EXE -partition-size 512 -no-boot-anim -avd VisualStudio_android-23_x86_phone -prop monodroid.avdname=VisualStudio_android-23_x86_phone
2>emulator: ERROR: x86 emulation currently requires hardware acceleration!
2>Please ensure Intel HAXM is properly installed and usable.
2>CPU acceleration status: Please disable Hyper-V before using the Android Emulator.  Start a command prompt as Administrator, run 'bcdedit /set hypervisorlaunchtype off', reboot.
2>Emulator VisualStudio_android-23_x86_phone cannot be started.
========== Build: 1 succeeded, 0 failed, 1 up-to-date, 0 skipped ==========
========== Deploy: 0 succeeded, 1 failed, 0 skipped ==========

이것 때문에 Hyper-V를 끄자니 여러 가지로 불편하게 되었는데요. 물론, 다음과 같이 설정해서 원하는 모드로 부팅할 수 있지만,

윈도우 8에서 Hyper-V 유무에 따른 듀얼 부트 설정하는 방법
; https://www.sysnet.pe.kr/2/0/1676

역시 부팅 자체가 불편합니다. 그렇다고 ARM 버전의 "VisualStudio_android-23_arm_phone (Android 6.0 - API 23)" 에뮬레이터를 이용하자니, 속도가 10배나 느리다는 말은 둘째치고, 정말 느린 속도에 에뮬 환경을 포기하고 싶어집니다. ^^;

그런데, 이런 불편함을 마이크로소프트가 전용 에뮬레이터를 내놓음으로써 말끔히 해결했습니다. ^^

Visual Studio Emulator for Android
; https://www.visualstudio.com/ko/vs/msft-android-emulator

Visual Studio Android Emulator
; https://developer.xamarin.com/guides/android/deployment,_testing,_and_metrics/debug-on-emulator/visual-studio-android-emulator/

Visual Studio 2015 사용자는 위의 링크에서 다운로드할 수 있고, 2017 사용자는 설치 파일에서 다음과 같이 "Visual Studio Emulator for Android" 구성 요소를 선택하면 됩니다.

[그림 출처: https://social.msdn.microsoft.com/Forums/vstudio/en-US/34d06dea-0bb4-4c67-a115-d739f7be91c7/visual-studio-2017-emulator-for-android]
and_emul_0.png

그럼 다음과 같이 "Tools" / "Visual Studio Emulator for Android..." 메뉴가 제공되고,

[그림 출처: https://developer.xamarin.com/guides/android/deployment,_testing,_and_metrics/debug-on-emulator/visual-studio-android-emulator/]
and_emul_1.png

동작 속도는, 예전 Windows Phone 에뮬레이터만큼의 쾌적함을 제공합니다. ^^




참고로, Visual Studio에서 Emulator를 시작할 때 다음과 같은 오류가 발생할 수 있습니다.

2>Starting deploy 5" KitKat (4.4) XXHDPI Phone ...
2>Starting emulator 5" KitKat (4.4) XXHDPI Phone ...
2>An error occured. See full exception on logs for more details.
2>Object reference not set to an instance of an object.

이런 경우에는, "Tools" / "Visual Studio Emulator for Android..." 메뉴를 실행해 직접 해당 Emulator를 시작, 다음과 같이 권한 승인을 요구하는 창을 거치기만 하면 됩니다. (한 번만 필요합니다.)

and_emul_2.png




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 7/11/2017]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2017-07-14 12시01분
Visual Studio 2017의 경우 설치 파일을 "C:\Program Files (x86)\Microsoft Visual Studio\Installer" 폴더의 vs_installer.exe를 실행시키면 됩니다.
정성태
2018-05-08 11시00분
Android emulator를 아예 hyper-v 호환으로 내놓는군요. ^^

Hyper-V Android emulator support
; https://devblogs.microsoft.com/visualstudio/hyper-v-android-emulator-support/

HAXM v7.8.0 (INTEL CPU)
; https://github.com/intel/haxm/releases

Android Emulator hypervisor driver 2.1 (AMD & INTEL CPU)
; https://github.com/google/android-emulator-hypervisor-driver/releases
정성태

... 121  122  123  124  125  126  127  128  [129]  130  131  132  133  134  135  ...
NoWriterDateCnt.TitleFile(s)
1830정성태1/1/201527430오류 유형: 265. svchost.exe 프로세스(IP Helper: IPHLPSVC)의 CPU 100% 현상
1829정성태12/16/201431205VC++: 86. Windows Vista부터 바뀐 Credential Provider 예제 분석 (2) [2]파일 다운로드1
1828정성태12/15/201427663VC++: 85. Windows Vista부터 바뀐 Credential Provider 예제 분석 (1) [4]파일 다운로드1
1827정성태12/12/201424004VC++: 84. CredUIPromptForWindowsCredentials Win32 API 사용법 정리
1826정성태12/11/201428500.NET Framework: 489. Socket.Listen에 전달된 backlog 인자의 의미 [6]
1825정성태12/11/201475677.NET Framework: 488. TCP 소켓 연결의 해제를 알 수 있는 방법 [10]파일 다운로드1
1824정성태12/10/201425731.NET Framework: 487. Socket.Receive 메서드의 SocketFlags.Peek 동작을 이용해 소켓 연결 유무를 확인? [8]파일 다운로드1
1823정성태12/10/201422658.NET Framework: 486. Java의 ScheduledExecutorService에 대응하는 C#의 System.Threading.Timer [2]
1822정성태12/3/201425312개발 환경 구성: 252. Xamarin 라이선스 관리 [8]
1821정성태12/1/201431711VS.NET IDE: 96. Visual Studio에서 /* ~ */ 주석을 위한 단축키(매크로)
1820정성태11/23/201420469.NET Framework: 485. Mono Profiler에서 IL 코드 변경이 가능할까? - 두 번째 이야기파일 다운로드1
1819정성태11/22/201420445오류 유형: 264. MSBuild 에러 - warning MSB3052: The parameter to the compiler is invalid,
1818정성태11/22/201422881개발 환경 구성: 251. NUMA 노드 수에 따른 IIS Worker Process(w3wp.exe) 설정 [1]
1817정성태11/22/201426029VS.NET IDE: 95. Macros for Visual Studio 2013 [1]
1816정성태11/20/201420709.NET Framework: 484. Mono Profiler에서 IL 코드 변경이 가능할까?
1815정성태11/18/201418677.NET Framework: 483. 코드로 살펴 보는 ETW의 활성화 시점 [2]
1814정성태11/18/201420259오류 유형: 263. Unable to find the requested .Net Framework Data Provider. It may not be installed.
1813정성태11/18/201422112오류 유형: 262. Build Events에 robocopy 작업이 있는 경우 "VCEnd exited with code 3" 오류 발생
1812정성태11/17/201419547.NET Framework: 482. ETW 자동 생성 코드의 VerificationException 예외 발생
1811정성태11/16/201420874.NET Framework: 481. Mono 내부의 문자열 처리 방식은 UTF-8
1810정성태11/15/201457519.NET Framework: 480. C# - 배치 파일 실행하고 출력 결과를 얻는 방법 [4]
1809정성태11/11/201422769.NET Framework: 479. Mono Profiler를 Unity의 Plugin으로 사용하는 방법
1808정성태11/11/201423090.NET Framework: 478. C# - 폴더 경로 문자열에서 "..", "." 표기를 고려한 최종 문자열을 얻는 방법 [2]
1807정성태11/10/201429253개발 환경 구성: 250. 서버용 Socket에서 사용하는 포트가 충돌한다면?파일 다운로드1
1806정성태11/10/201425051.NET Framework: 477. SeCreateGlobalPrivilege 특권과 WCF NamedPipe
1805정성태11/5/201421861.NET Framework: 476. Visual Studio에서 Mono용 Profiler 개발 [3]파일 다운로드1
... 121  122  123  124  125  126  127  128  [129]  130  131  132  133  134  135  ...