本来打算写一个多线程的图片批量处理的实例展示一下,后来觉得也没什么人需要这个多线程就算了,总之我了解的都说到了,所以这里打算总结一下就结束掉我们的教程:
- Worker运行在flashplayer11.4或air3.4以上,同步是flashplayer11.5和air3.5才引入的;
- Worker的主要目的是为了在高强度的运算下任然能保持较高运行帧率,但是Worker需要使用额外系统内存和CPU,开销很大,所以尽量少用Worker,最多同时运行时不应超过2个后台Worker(即子线程);
- 移动平台的AIR不支持Worker!
- ByteArray的两个方法教程中没有说到:atomicCompareAndSwapIntAt和atomicCompareAndSwapLength,这两个方法是线程安全的,帮助文档中有讲解,但是具体用法不清楚,求大神指点!!!
- WorkerDomain.current.createWorker方法的第二个参数设置为true后子线程就可以对文件系统进行操作,同时子线程中的trace也可以输出了!
- 同步技术除了可以用在共享的ByteArray上,也可以用在多个线程同时操作文件时,可以避免多个线程同时读写一个文件时导致的数据丢失或损坏的问题;
- 共享的ByteArray对象,在一个线程中由于各种操作导致其position改变(如改变为300),在该对象传递到另一个线程后该对象的position都会被置为0;而且两个线程中的ByteArray的position改变是相互独立的,虽然是共享的ByteArray对象双方都是同一个ByteArray对象的引用,但是A线程将ByteArray的position为100,B线程的ByteArray的position还是原来的数值;
- 共享的ByteArray对象,调用clear方法只能将position设置为0,长度不会改变,要清空共享的ByteArray对象请设置position和length为0;
- Condition类的wait方法可以实现线程的暂停效果,可指定暂停的时间;