- 浏览: 583683 次
- 性别:
- 来自: 北京
-
文章分类
- 全部博客 (237)
- Java (48)
- Flex3 (43)
- Spring (7)
- Hibernate (7)
- 杂文 (2)
- 设计模式 (3)
- 数据库相关 (32)
- Eclipse开发环境 (10)
- C/C++ (1)
- 随笔 (1)
- 生活点滴 (2)
- Flex4 (3)
- Oracle (6)
- SQLServer (6)
- Degrafa (1)
- ActionScript (2)
- JavaScript (11)
- MySQL (8)
- 开源项目 (4)
- AspectJ (0)
- Spring Security (1)
- SSO (0)
- PV3D (2)
- JBPM (1)
- JBoss (0)
- Tomcat (5)
- Struts (1)
- WebService (2)
- 算法 (1)
- 数据结构 (1)
- POI (2)
- Lucene (2)
- 其他 (3)
- Blazeds (2)
- Alternative 3D (0)
- Ibatis (3)
- Intellij (3)
- freemaker (0)
- Maven (5)
- web (4)
- Eclipse (1)
- velocity (1)
- Linux (7)
- CXF (3)
- html (2)
- JVM (1)
最新评论
-
jpsb:
多谢楼主,问题解决,主要就是svn版本不同导致的
Eclipse 导入本地svn项目的问题 -
yycdaizi:
lanmolsz 写道无法同意楼主的说法,楼主所谓的晚捕捉就是 ...
Java异常处理原则 -
lanmolsz:
无法同意楼主的说法,楼主所谓的晚捕捉就是典型的让异常控制程序的 ...
Java异常处理原则 -
cici_new_1987:
...
Java异常处理原则 -
雁行:
倒是怀疑这个功能来着
Eclipse 导入本地svn项目的问题
Caching
Let’s assume you know in advance how many renderers are needed. One way to solve the memory leak is to create a cache of renderers at startup.
1
2
3
4
5
6
7
|
private var cache:Array = new Array();
private function initRenderers():void {
for (var i:int = 0; i < 200; i++) {
renderers.push(new MyRenderer());
}
}
|
We can then modify our loadData method like this:
1
2
3
4
5
6
7
8
9
10
11
|
private function loadData():void {
container.removeAllChildren();
var array:Array = getData();
for (var i:int = 0; i < array.length; i++) {
var rend:MyRenderer = cache[i];
rend.data = array[i];
container.addChild(rend);
i++;
}
}
|
As you can see in the code we don’t create new renderers but we look for one in the cache. There are cases when you don’t know in advance which data are returned from the server and then you don’t know how many rendereres you need. In this case you need a dynamic cache.
Dynamic cache
Dynamic caching is based on an elastic mechanism. You have a place where you can look for a renderer: if there is one in the cache, that is returned, otherwise a new one is created temporarily. Better to see some code.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
public class MyRendererCache extends Object {
private static var cache : ArrayCollection = new ArrayCollection();
public function MyRendererCache() {
super();
for ( var x : Number = 0; x < 20; x ++ ) {
cache.addItem( new MyRenderer() );
}
}
public static function getRenderer() : MyRenderer {
var renderer : MyRenderer;
if ( cache.length <= 0 ) {
renderer = new MyRenderer();
} else {
renderer = cache.removeItemAt( 0 ) as MyRenderer;
}
return renderer;
}
public static function setRenderer( renderer : MyRenderer ) : void {
cache.addItem( renderer );
}
}
|
In the constructor you populate the cache with the minimu number of renderers, say 20 (lines 7-9). The cache has two static methods, getRenderer
and setRenderer
. The first is used to obtain a renderer, the second to give it back when done. If you look and lines 15-16 the cache returns a new renderer when the cache is empty. This way the number of renderers in memory can grow beyond the minimum number set in the constructor, but just temporarily, since the GC will delete them when not referenced anymore.
An important issue is related to the setRenderer
. When you don’t need a renderer anymore you have to return it back to the cache, otherwise we fall again in a memory leak as explained above. To achieve this we exploit the remove event of the renderer. The remove event is triggerer whenever a UI element is removed from the display list. For example when we call removeAllChildren()
such event is triggered for each renderer.
We can modify the renderer like this:
1
2
3
4
5
6
7
8
9
10
|
<mx:VBox xmlns:mx="http://www.adobe.com/2006/mxml"
borderStyle="solid" width="200"
remove="onRemove()"
>
private function onRemove():void {
MyRendererCache.setRenderer(this);
}
....
</VBox>
|
If you now run the profiler you will notice that memory grows until a given point and then keeps stable as in the figure below.
Congratulations! You have solved the memory leak!
Suggesting the GC
Besides favoring the job of GC Adobe has allowed programmers to suggest the intervention of the GC. The command is in the flash.system
package and it is System.gc()
. By documentation this “Forces the garbage collection process” but in my experience it is just a vague suggestion of intervention. It can solve some situation, so it is worth trying it at the beginning, when you need a quick way to save some memory.
Full screen slides available here.
The source code of this post is available under the new BSD license.
References
- Garbage Collection and Memory Leaks by Alex Aharui. Somehow outdated but a good introduction.
- Tip to force GC via local connection.
- GC and Flash player 9. Good article by G. Skinner.
- GC and reflections on Adobe Air vs the design of Flash player by Sean Christmann (creator of the Ebay Desktop application).
- The downside of developing Adobe Air application via Html/JS. Reflections on the lack of a profiler.
- Tips to optimize Air/Flash applications presented by Sean Christmann at Max 2008 Milan
发表评论
-
AIR html 内存泄露
2010-07-15 14:21 1727众所周知,Flex虽然在客户体验方面独领风骚,但是其 ... -
Flex 内部命名空间
2010-05-11 13:27 1325使用方式如下: //引用命名空间 im ... -
AIR开发下的ALert窗口无法弹出
2010-05-05 10:55 1556最近在从事AIR编程。AIR开发和之前做的RIA开发还是 ... -
Flex调用JS代码
2010-03-03 11:23 5281在Flex开发中有时候需要调用JS代码,例如关闭浏览 ... -
Flex设置浏览器标题
2010-03-03 11:17 3044在Flex下设置页面浏览器标题Title工有两种方式 ... -
Flex版在线PhotoShop(2个)
2010-03-02 13:47 2183刚刚看到了一个Flex版本的Online PhotoShop工 ... -
Degrafa渲染DataGrid
2009-12-22 09:58 2124在DataGrid中可以利用多种组件实现Column ... -
Flex3D 视屏网站
2009-12-21 08:28 1184http://www.hboimagine.com/#/the ... -
多种DataGrid ItemRender实现
2009-12-10 15:00 2112在Flex开发中,可能在展示数据方面,DataGr ... -
Flex RSL(Runtime Shared Library)
2009-12-10 08:03 1777RSL是 Runtime Shared Lib ... -
Degrafa(Beta3)源码
2009-12-08 17:01 1231Degrafa源码共享下载,见附件。 -
Flex 动态换肤
2009-12-08 16:57 1831可能很多人在写Flex程序的时候为了界面的美化,都会用 ... -
Flex Sound Effect 异常
2009-12-08 13:14 1180早上在写Flex代码的时候,想放首歌听听,不知道什么原 ... -
推荐一个不错的Flex网站
2009-12-07 15:51 1271今天看到了一个相当不错的关于Flex/Flash开发的英文站点 ... -
Flex+Java文件上传
2009-12-07 10:14 4443在研究Flex DataGrid导入exc ... -
Flex DataGrid导入Excel(一)
2009-12-02 18:46 5598这篇Blog只是写实现思路。 记得刚毕业 ... -
Flex版FusionCharts图形组件
2009-11-27 08:34 3861在Flex图形领域,FusionCharts为广 ... -
DataGrid导出Excel
2009-11-24 16:54 6414在Adobe的RIA开发环境下,flex并没有导出 ... -
Flex高级表格(Mecgrid)
2009-11-20 13:52 4416最近在考虑DataGrid单元格定位的问题时,收集到了 ... -
DataGrid单元格定位
2009-11-20 13:39 4873在Flex项目开发中,相信很多人会用到DataG ...
相关推荐
本篇文章将深入探讨Flex虚拟机的内存管理机制以及如何预防和处理内存泄漏问题。 内存管理在任何软件开发中都至关重要,尤其是在动态语言如ActionScript中。Flex虚拟机采用了一种自动垃圾回收(Garbage Collection, ...
通过本篇文章的学习,我们可以清楚地了解到对象缓存技术在提升Flex应用程序性能方面的重要作用。它不仅可以减少内存使用,还能提高应用程序的整体性能和稳定性。对于那些需要处理大量用户交互和频繁对象创建的应用来...
以上是Flex3.0面试题涉及的主要知识点,包括ActionScript版本差异、开发框架特点、MVC实施、内存管理、垃圾回收机制、前后端通信、性能优化以及Flash与Flex的协作方式。这些知识对于理解和实践Flex3.0开发至关重要。
1. 垃圾回收:理解ActionScript 3.0的垃圾回收机制,避免内存泄漏。 2. 性能监控:使用Flex Profiler分析应用性能,找出瓶颈并进行优化。 3. 缓存策略:有效利用Flash Player的本地存储,缓存数据以提高性能。 七、...
启动参数用于控制JVM的行为,常见的参数包括-Xms(最小堆内存)、-Xmx(最大堆内存)、-XX:+UseConcMarkSweepGC(垃圾回收算法)等。 ### 26. 一个优秀的JAR包下载站点:Apache Maven Repository Apache Maven ...
3. **内存管理**:有效释放不再使用的对象,避免内存泄漏,合理使用垃圾回收机制。 4. **使用开发工具**:利用Adobe Animate的性能分析器或其他第三方工具检测性能问题。 5. **Flex 4框架**:学习Flex 4的新特性,...
6. **利用垃圾回收机制**:及时释放不再使用的对象,防止内存泄漏。 转正工作总结则是软件工程师在试用期结束时对个人工作成绩、问题及改进方向的反思和记录。通常会包含以下内容: 1. **项目参与**:列出参与的...
- **性能优化**:作者还提到了BitmapData对象的内存管理问题,比如如何避免过多的垃圾回收,以确保程序运行效率。 - **Sprite 类**:Sprite 类是AS3中最常用的显示对象容器之一,它可以包含多个子项,并提供了一...
10. **性能优化**:学习如何避免内存泄漏,正确使用垃圾回收,以及优化代码以获得更好的运行效率。 11. **Flex框架**:如果PDF还包括Flex相关内容,那么Flex Builder、MXML和CSS布局也会是重要的学习部分。 通过...