Microsoft MVP성태의 닷넷 이야기
.NET Framework: 479. Mono Profiler를 Unity의 Plugin으로 사용하는 방법 [링크 복사], [링크+제목 복사],
조회: 22870
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

Mono Profiler를 Unity의 Plugin으로 사용하는 방법

아래의 글에 Mono Profiler를 Unity의 Plug-in으로 사용하는 방법이 나옵니다.

Access to Mono’s Low Level Profiling Functions in Unity
; http://www.software7.com/blog/access-to-monos-low-level-profiling-functions-in-unity/

그런데, plugin으로 어떻게 Unity에 등록하는지는 설명이 빠져있어서 찾아 보니 Unity 측 매뉴얼에 자세히 설명되어 있습니다. ^^

Plugins (Pro/Mobile-Only Feature)
; http://docs.unity3d.com/Manual/Plugins.html

위의 글에 보면 plugin은 pro 제품에만 되고, 보안상의 이유로 webplayer에는 안된다고 합니다.

자... 그럼 실습을 해볼까요? ^^

일단, 전에 만들어 둔 Mono Profiler를 이번 실습에서 그대로 사용합니다.

Visual Studio에서 Mono 용 Profiler 개발
; https://www.sysnet.pe.kr/2/0/1805

위의 글에서 "mono --profile=..." 옵션으로 실행하는 경우 mono 측에서 프로파일러 DLL 내의 mono_profiler_startup API를 찾아서 실행해 주지만, "Access to Mono’s Low Level Profiling Functions in Unity" 글에서는 MonoBehavior 상속 클래스에서 일부러 프로파일러 측의 초기화 함수를 불러주어야 한다는 차이가 있습니다.

이때 Plugin DLL의 배포 위치는 다음과 같습니다.

x86 DLL: Assets/Plugins/x86 
x64 DLL: Assets/Plugins/x86_64

Unity 개발 환경에서 보면 그냥 Project 뷰에서 폴더를 만들어서 각각의 폴더에 파일이 놓여 있기만 하면 됩니다.

unity_profiler_1.png

이렇게 놓고 빌드하면 ".\..._Data\Plugins" 폴더에 배포됩니다.

DLL 배포가 확인되었으면, 이제 Unity 프로젝트에 Script 파일을 하나 추가하고 다음과 같이 DllImport 특성을 이용해 해당 파일을 PInvoke 구문으로 연결하고 호출하면 됩니다.

using UnityEngine;
using System.Runtime.InteropServices;

public class ProfilerScript : MonoBehaviour {

#if UNITY_IPHONE || UNITY_XBOX360
    [DllImport ("__Internal")]
#else
    [DllImport("mono-profiler-perf")]
#endif

    private static extern void mono_profiler_startup(string arg);

    void Start () {
        mono_profiler_startup(null);
    }
    
    void Update () {
    
    }
}

Profiler가 제대로 동작하려면 이제 위의 스크립트를 자동으로 실행할 수 있게 해야 하는데요. 이를 위해 다음의 방법을 사용할 수 있습니다.

Running Editor Script Code on Launch
; http://docs.unity3d.com/Manual/RunningEditorCodeOnLaunch.html

따라서 ProfilerScript 코드를 다음과 같이 바꿔주면 됩니다.

using UnityEngine;
using System.Runtime.InteropServices;
using UnityEditor;

[InitializeOnLoad]
public class ProfilerScript {


#if UNITY_IPHONE || UNITY_XBOX360
   [DllImport ("__Internal")]
#else
    [DllImport("mono-profiler-perf")]
#endif

    private static extern void mono_profiler_startup(string arg);

    static ProfilerScript()
    {
        mono_profiler_startup(null);
    }
}

이것이 어느 정도 빨리 불려지느냐는 알 수 없습니다. 아무리 빨리 불려도 Mono 런타임의 기본적인 메서드들은 이미 불린 상태일 것이기 때문에 JIT 컴파일을 콜백으로 받는 경우 이미 지나간 메서드에 대해서는 놓쳤다고 봐야 합니다.

어쨌든, 이런저런 제약이 있지만 그런대로 ^^ 쓸만하겠군요.




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







[최초 등록일: ]
[최종 수정일: 6/28/2021]

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

비밀번호

댓글 작성자
 




... 106  107  108  109  110  111  112  113  [114]  115  116  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11075정성태10/20/201621002Windows: 127. Convert-WindowsImage.ps1 사용 방법 정리
11074정성태10/20/201629305Windows: 126. Windows Server 2016 평가판을 정식 버전으로 라이선스 변경하는 방법
11073정성태10/20/201625336.NET Framework: 613. 윈도우 데스크톱 응용 프로그램(예: Console)에서 알림 메시지(Toast notifications) 띄우기 [1]파일 다운로드1
11072정성태10/20/201621876VC++: 102. 새로 추가한 ATL COM 객체가 regsvr32.exe로 등록이 안 되는 문제
11071정성태10/20/201625412.NET Framework: 612. UWP(유니버설 윈도우 플랫폼) 앱에서 콜백 함수 내에서의 UI 요소 접근 방법 [1]
11070정성태10/20/201619622Windows: 125. 윈도우 서버 2016 마이그레이션
11069정성태10/19/201627339.NET Framework: 611. C++ 개발자들을 위한 C# Thread 동작 방식 [2]
11068정성태10/19/201630531Windows: 124. 윈도우 운영체제의 시간 함수 (5) - TSC(Time Stamp Counter)와 QueryPerformanceCounter [12]파일 다운로드1
11067정성태10/18/201626854Windows: 123. 윈도우 운영체제의 시간 함수 (4) - RTC, TSC, PM Clock, HPET Timer [2]
11066정성태10/17/201624499Windows: 122. 윈도우 운영체제의 시간 함수 (3) - QueryInterruptTimePrecise, QueryInterruptTime 함수파일 다운로드1
11065정성태10/15/201629933Windows: 121. 윈도우 운영체제의 시간 함수 (2) - Sleep 함수의 동작 방식 [1]
11064정성태10/14/201621631.NET Framework: 610. C# - WaitOnAddress Win32 API 사용파일 다운로드1
11063정성태10/14/201637739Windows: 120. 윈도우 운영체제의 시간 함수 (1) - GetTickCount와 timeGetTime의 차이점 [5]파일 다운로드1
11062정성태10/12/201618348오류 유형: 361. WCF .svc 호출 시 Could not find a base address that matches scheme net.tcp 예외
11061정성태10/12/201630470오류 유형: 360. IIS - 500.19 오류 (0x80070021)
11060정성태10/12/201622945오류 유형: 359. WCF - .svc 요청시 404 Not Found
11059정성태10/11/201627199.NET Framework: 609. WPF - 다중 스레드 환경에서 데이터 바인딩의 INotifyPropertyChanged.PropertyChanged에 대한 배려 [1]파일 다운로드1
11058정성태10/8/201622529개발 환경 구성: 303. Windows 10 Bash Shell - 한글 환경을 영문으로 바꾸고 싶다면?
11057정성태10/8/201617925오류 유형: 358. Windows 10 bash shell - sudo: unable to resolve host ...
11056정성태10/8/201620789개발 환경 구성: 302. Windows 10 bash shell 시작 시 [...] packages can be updated.
11055정성태10/8/201621837.NET Framework: 608. double 값을 구할 때는 반드시 피연산자를 double로 형변환! [6]
11054정성태10/5/201625849개발 환경 구성: 301. "Let's Encrypt" SSL 인증서를 Azure Cloud Services(classic)에 업데이트하는 방법
11053정성태10/5/201620552.NET Framework: 607. C# try/catch/finally의 IL 코드 표현
11052정성태9/27/201634705개발 환경 구성: 300. C# DLL에서 Win32 C/C++처럼 dllexport 함수를 제공하는 방법 [7]파일 다운로드1
11051정성태9/25/201621883개발 환경 구성: 299. docker - c:\programdata\docker\windowsfilter 폴더 정리하는 방법파일 다운로드1
11050정성태9/24/201626621VC++: 101. 반올림하지 않고 double 변수 값 출력하는 방법 [3]
... 106  107  108  109  110  111  112  113  [114]  115  116  117  118  119  120  ...