Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 321. Visual Studio Emulator for Android 소개 [링크 복사], [링크+제목 복사],
조회: 23548
글쓴 사람
정성태 (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
정성태

1  2  3  4  [5]  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13818정성태11/15/20245294Windows: 272. Windows 11 24H2 - sudo 추가
13817정성태11/14/20244941Linux: 106. eBPF / bpf2go - (BPF_MAP_TYPE_HASH) Map을 이용한 전역 변수 구현
13816정성태11/14/20245397닷넷: 2312. C#, C++ - Windows / Linux 환경의 Thread Name 설정파일 다운로드1
13815정성태11/13/20244822Linux: 105. eBPF - bpf2go에서 전역 변수 설정 방법
13814정성태11/13/20245290닷넷: 2311. C# - Windows / Linux 환경에서 Native Thread ID 가져오기파일 다운로드1
13813정성태11/12/20245048닷넷: 2310. .NET의 Rune 타입과 emoji 표현파일 다운로드1
13812정성태11/11/20245267오류 유형: 933. Active Directory - The forest functional level is not supported.
13811정성태11/11/20244859Linux: 104. Linux - COLUMNS 환경변수가 언제나 80으로 설정되는 환경
13810정성태11/10/20245389Linux: 103. eBPF (bpf2go) - Tracepoint를 이용한 트레이스 (BPF_PROG_TYPE_TRACEPOINT)
13809정성태11/10/20245263Windows: 271. 윈도우 서버 2025 마이그레이션
13808정성태11/9/20245271오류 유형: 932. Linux - 커널 업그레이드 후 "error: bad shim signature" 오류 발생
13807정성태11/9/20244994Linux: 102. Linux - 커널 이미지 파일 서명 (Ubuntu 환경)
13806정성태11/8/20244917Windows: 270. 어댑터 상세 정보(Network Connection Details) 창의 내용이 비어 있는 경우
13805정성태11/8/20244748오류 유형: 931. Active Directory의 adprep 또는 복제가 안 되는 경우
13804정성태11/7/20245377Linux: 101. eBPF 함수의 인자를 다루는 방법
13803정성태11/7/20245336닷넷: 2309. C# - .NET Core에서 바뀐 DateTime.Ticks의 정밀도
13802정성태11/6/20245705Windows: 269. GetSystemTimeAsFileTime과 GetSystemTimePreciseAsFileTime의 차이점파일 다운로드1
13801정성태11/5/20245493Linux: 100. eBPF의 2가지 방식 - libbcc와 libbpf(CO-RE)
13800정성태11/3/20246337닷넷: 2308. C# - ICU 라이브러리를 활용한 문자열의 대소문자 변환 [2]파일 다운로드1
13799정성태11/2/20244922개발 환경 구성: 732. 모바일 웹 브라우저에서 유니코드 문자가 표시되지 않는 경우
13798정성태11/2/20245521개발 환경 구성: 731. 유니코드 - 출력 예시 및 폰트 찾기
13797정성태11/1/20245513C/C++: 185. C++ - 문자열의 대소문자를 변환하는 transform + std::tolower/toupper 방식의 문제점파일 다운로드1
13796정성태10/31/20245396C/C++: 184. C++ - ICU dll을 이용하는 예제 코드 (Windows)파일 다운로드1
13795정성태10/31/20245178Windows: 268. Windows - 리눅스 환경처럼 공백으로 끝나는 프롬프트 만들기
13794정성태10/30/20245263닷넷: 2307. C# - 윈도우에서 한글(및 유니코드)을 포함한 콘솔 프로그램을 컴파일 및 실행하는 방법
13793정성태10/28/20245148C/C++: 183. C++ - 윈도우에서 한글(및 유니코드)을 포함한 콘솔 프로그램을 컴파일 및 실행하는 방법
1  2  3  4  [5]  6  7  8  9  10  11  12  13  14  15  ...