最適化Tips 他クラスのメンバをローカル変数に保存して使用する。 mtok forked:0favorite:2lines:56license : All rights reserved modified : 2009-01-29 09:23:04 Embed Tweet <?xml version="1.0" encoding="utf-8" ?> <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" applicationComplete="appCompleteHandler(event)"> <mx:Script> <![CDATA[ import flash.events.MouseEvent; import mx.events.FlexEvent; import mx.controls.Alert; import flash.system.Capabilities; import flash.utils.getTimer; private var loopCount:int = 1000000; public function appCompleteHandler(event:FlexEvent):void{ if(Capabilities.isDebugger){ var msg:String = "デバッグ版のプレーヤを使用しています。正しいベンチマークの結果を得るにはリリース版を使用することをお勧めします。"; Alert.show(msg, "インフォメーション"); } console.text += "OS : " + Capabilities.os + "\n"; console.text += "Vesion : " + Capabilities.version + "\n"; console.text += "Type : " + Capabilities.playerType + "\n"; Capabilities.isDebugger ? console.text += "Debug version\n" : null; } public function clickHandler(event:MouseEvent):void{ startBenchmark(); } public function clear(event:MouseEvent):void { console.text = ""; } public function startBenchmark():void{ var i:int; var tmp:Number; console.text += "start benchimarking\n"; var time:int = getTimer(); for (i = 0; i < loopCount; i++) { tmp = Math.PI; } var dt:int dt = getTimer() - time; console.text += "他クラスのプロパティにアクセス" + dt + "ms\n"; var pi:Number = Math.PI; time = getTimer(); for(i = 0; i < loopCount; i++){ tmp = pi; } dt = getTimer() - time; console.text += "ローカル変数を経由してアクセス" + dt + "ms\n"; console.text += "\n"; } ]]> </mx:Script> <mx:VBox width="100%" height="100%"> <mx:TextArea id="console" width="100%" height="100%"></mx:TextArea> <mx:HBox width="100%"> <mx:Button label="Start" click="clickHandler(event)" /> <mx:Button label="Clear" click="clear(event)" /> </mx:HBox> </mx:VBox> </mx:Application> Code Fullscreen Preview Fullscreen yoropan hikipuro : optimize optimize Capabilities.version