Flex-디버그 애플리케이션

Flex는 Flex 코드 디버깅의 뛰어난 기능을 제공하며 Flash Builder 4에는 뛰어난 내장 디버거 및 디버깅 관점 지원이 있습니다.

  • 디버그 모드 동안 Flex Application은 디버깅 기능을 지원하는 Flash Builder 4에 내장 된 Flash Player Debugger 버전에서 실행됩니다.

  • 따라서 개발자는 Flash Builder에서 쉽고 내장 된 디버깅 구성을 얻을 수 있습니다.

이 기사에서는 Flash Builder를 사용하여 Flex Client 코드를 디버깅하는 방법을 설명합니다. 다음 작업을 수행합니다.

  • 코드에 중단 점을 설정하고 중단 점 탐색기에서 확인하십시오.
  • 디버깅하는 동안 코드를 한 줄씩 살펴보십시오.
  • 변수 값을 봅니다.
  • 모든 변수의 값을 검사하십시오.
  • 표현식의 값을 검사하십시오.
  • 일시 중단 된 스레드의 스택 프레임을 표시합니다.

디버깅 예

단계 기술
1 Flex-Create Application 장에 설명 된대로 com.tutorialspoint.client 패키지 아래에 HelloWorld 라는 이름으로 프로젝트를 만듭니다 .
2 아래 설명대로 HelloWorld.mxml 을 수정 합니다. 나머지 파일은 변경하지 마십시오.
애플리케이션을 컴파일하고 실행하여 비즈니스 로직이 요구 사항에 따라 작동하는지 확인합니다.

다음은 수정 된 mxml 파일의 내용입니다. src/com.tutorialspoint/HelloWorld.mxml.

<?xml version = "1.0" encoding = "utf-8"?>
<s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009" 
   xmlns:s = "library://ns.adobe.com/flex/spark" 
   xmlns:mx = "library://ns.adobe.com/flex/mx"
   width = "100%" height = "100%"
   minWidth = "500" minHeight = "500" 
   initialize = "application_initializeHandler(event)">
   
   <fx:Style source = "/com/tutorialspoint/client/Style.css" />
   <fx:Script>
      <![CDATA[
         import mx.controls.Alert;
         import mx.events.FlexEvent;
         protected function btnClickMe_clickHandler(event:MouseEvent):void {
            Alert.show("Hello World!");
         }

         protected function application_initializeHandler(event:FlexEvent):void {
            lblHeader.text = "My Hello World Application";
         }
      ]]>
   </fx:Script>

   <s:BorderContainer width = "500" height = "500" id = "mainContainer"
      styleName = "container">
      <s:VGroup width = "100%" height = "100%" gap = "50" horizontalAlign = "center"
         verticalAlign = "middle">
         <s:Label id = "lblHeader" fontSize = "40" color = "0x777777"
            styleName = "heading" />
         <s:Button label = "Click Me!" id = "btnClickMe"
            click = "btnClickMe_clickHandler(event)" styleName = "button" />
      </s:VGroup>
   </s:BorderContainer>
</s:Application>

모든 변경이 완료되면 Flex-Create Application 장 에서했던 것처럼 일반 모드에서 컴파일하겠습니다 .

1 단계-중단 점 배치

HelloWorld.mxml의 응용 프로그램 초기화 처리기의 첫 번째 줄에 중단 점을 놓습니다.

2 단계-애플리케이션 디버그

이제

디버그 애플리케이션 메뉴를 클릭 하고HelloWorld 응용 프로그램을 디버깅합니다.

모든 것이 정상이면 응용 프로그램이 브라우저에서 실행되고 Flash Builder 콘솔에 다음 디버그 로그가 표시됩니다.

[SWF] \HelloWorld\bin-debug\HelloWorld.swf 
- 181,509 bytes after decompression
[SWF] \HelloWorld\bin-debug\HelloWorld.swf\[[DYNAMIC]]\1 
- 763,122 bytes after decompression
[SWF] \HelloWorld\bin-debug\HelloWorld.swf\[[DYNAMIC]]\2 
- 1,221,837 bytes after decompression
[SWF] \HelloWorld\bin-debug\HelloWorld.swf\[[DYNAMIC]]\3 
- 1,136,788 bytes after decompression
[SWF] \HelloWorld\bin-debug\HelloWorld.swf\[[DYNAMIC]]\4 
- 2,019,570 bytes after decompression
[SWF] \HelloWorld\bin-debug\HelloWorld.swf\[[DYNAMIC]]\5 
- 318,334 bytes after decompression

Application이 시작 되 자마자 application_initialize Handler 메서드의 첫 번째 줄에 중단 점을 배치 했으므로 Flash Builder 중단 점에 초점이 맞춰진 것을 볼 수 있습니다.

일시 중단 된 스레드에 대한 스택 추적을 볼 수 있습니다.

표현식의 값을 볼 수 있습니다.

배치 된 중단 점 목록을 볼 수 있습니다.

이제 application_initializeHandler () 메서드의 마지막 줄에 도달 할 때까지 F6 키를 계속 누릅니다. 기능 키에 대한 참조로 F6은 코드를 한 줄씩 검사하고 F5는 더 안쪽으로 들어가며 F8은 응용 프로그램을 다시 시작합니다. 이제 application_initializeHandler () 메서드의 모든 변수 값 목록을 볼 수 있습니다.

이제 Java 애플리케이션을 디버깅 할 수있는 것과 동일한 방식으로 플렉스 코드를 디버깅 할 수 있음을 알 수 있습니다. 임의의 줄에 중단 점을 배치하고 flex의 디버깅 기능을 사용하십시오.