1 Star 0 Fork 86

mydecember/pythonvm

forked from hinus/pythonvm 
加入 Gitee
与超过 1400万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
oopClosure.cpp 3.10 KB
一键复制 编辑 原始数据 按行查看 历史
hinus 提交于 2018-10-03 00:06 +08:00 . add gc
#include "runtime/universe.hpp"
#include "runtime/stringTable.hpp"
#include "runtime/interpreter.hpp"
#include "memory/oopClosure.hpp"
#include "memory/heap.hpp"
#include "util/handles.hpp"
#include "util/stack.hpp"
#include "util/map.hpp"
#include "object/hiObject.hpp"
ScavengeOopClosure::ScavengeOopClosure(Space* from, Space* to, Space* meta) {
_from = from;
_to = to;
_meta = meta;
_oop_stack = new Stack<HiObject*>(1024);
}
ScavengeOopClosure::~ScavengeOopClosure() {
_from = NULL;
_to = NULL;
delete _oop_stack;
_oop_stack = NULL;
}
void ScavengeOopClosure::do_oop(HiObject** oop) {
if (oop == NULL || *oop == NULL)
return;
// this oop has been handled, since it may be
// refered by Klass
if(!_from->has_obj((char*)*oop))
return;
(*oop) = copy_and_push(*oop);
}
void ScavengeOopClosure::do_array_list(ArrayList<Klass*>** alist) {
if (alist == NULL || *alist == NULL)
return;
// no chance to visit list more than once.
assert(_from->has_obj((char*)*alist));
size_t size = sizeof(ArrayList<Klass*>);
char* target = (char*)_to->allocate(size);
memcpy(target, (*alist), size);
(*(char**)alist) = target;
(*alist)->oops_do(this);
}
void ScavengeOopClosure::do_array_list(ArrayList<HiObject*>** alist) {
if (alist == NULL || *alist == NULL)
return;
assert(_from->has_obj((char*)*alist));
size_t size = sizeof(ArrayList<HiObject*>);
char* target = (char*)_to->allocate(size);
memcpy(target, (*alist), size);
(*(char**)alist) = target;
(*alist)->oops_do(this);
}
void ScavengeOopClosure::do_map(Map<HiObject*, HiObject*>** amap) {
if (amap == NULL || *amap == NULL)
return;
assert(_from->has_obj((char*)*amap));
size_t size = sizeof(Map<HiObject*, HiObject*>);
char* target = (char*)_to->allocate(size);
memcpy(target, (*amap), size);
(*(char**)amap) = target;
(*amap)->oops_do(this);
}
void ScavengeOopClosure::do_raw_mem(char** mem, int length) {
if (*mem == NULL)
return;
char* target = (char*)_to->allocate(length);
memcpy(target, (*mem), length);
(*mem) = target;
}
// we do not move klass
void ScavengeOopClosure::do_klass(Klass** k) {
if (k == NULL || *k == NULL)
return;
(*k)->oops_do(this);
}
HiObject* ScavengeOopClosure::copy_and_push(HiObject* obj) {
char* target = obj->new_address();
if (target) {
return (HiObject*)target;
}
// copy
size_t size = obj->size();
target = (char*)_to->allocate(size);
memcpy(target, obj, size);
obj->set_new_address(target);
// push
_oop_stack->push((HiObject*)target);
return (HiObject*)target;
}
void ScavengeOopClosure::scavenge() {
// TODO : step 1, mark roots
process_roots();
// step2, process all objects;
while (!_oop_stack->empty()) {
_oop_stack->pop()->oops_do(this);
}
}
void ScavengeOopClosure::process_roots() {
Universe::oops_do(this);
Interpreter::get_instance()->oops_do(this);
HandleMark::get_instance()->oops_do(this);
StringTable::get_instance()->oops_do(this);
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C++
1
https://gitee.com/libown/pythonvm.git
git@gitee.com:libown/pythonvm.git
libown
pythonvm
pythonvm
master

搜索帮助