var resFuture = Isolate.run(callbackFun); // 在FfiData的test方法里创建出isolate1
这个isolate1虽然和主的Isolate不共用堆内存(至少在isolate1结束前是这样),但是isolate1在创建时是能捕获在主Isolate里初始化的final字段的,
因此两个isolate共存期间,虽然他们的堆内存互相隔离,但是GC层面,是要求isolate1结束了,才能将主Isolate里创建的FfiData对象给GC掉,
哪怕是在主Isolate里该FfiData对象已经明面上没有变量引用它了;
这个听起来有点像结构化并发的概念,要求子的结束了,才能清理父的(但是还需要确认是否只针对FfiData类,如果这个isolate1不是在FfiData里创建的会怎么样?);
经过测试,如果isolate1是在FfiData外部,比如main方法里创建的,它的callbackFun里也通过data?.address引用了FfiData里的address(且获取到了malloc创建的空间的地址)
,这个时候isolate1没有结束的话,DVM不会等待isolate1结束才GC这个FfiData对象,这种情况下要很小心的在isolate1里Pointer.fromAddress,因为这个address指向的空间可能已经被释放了;
标签:创建,FfiData,Isolate,Dart,理解,GC,address,isolate1 From: https://www.cnblogs.com/silentdoer/p/17761669.html