#include "util/arrayList.hpp"#include "runtime/interpreter.hpp"#include "runtime/universe.hpp"#include "memory/heap.hpp"#include "memory/oopClosure.hpp"#include <new>#include <stdio.h>template <typename T>ArrayList<T>::ArrayList(int n) {_length = n;_size = 0;void* temp = Universe::heap->allocate(sizeof(T) * n);_array = new(temp)T[n];}template <typename T>void ArrayList<T>::add(T t) {if (_size >= _length)expand();_array[_size++] = t;}template <typename T>void ArrayList<T>::insert(int index, T t) {add(NULL);for (int i = _size - 1; i > index; i--) {_array[i] = _array[i - 1];}_array[index] = t;}template <typename T>void ArrayList<T>::expand() {void* temp = Universe::heap->allocate(sizeof(T) * (_length << 1));T* new_array = new(temp)T[_length << 1];for (int i = 0; i < _length; i++) {new_array[i] = _array[i];}// we do not rely on this, but gc.//delete[] _array;_array = new_array;_length <<= 1;printf("expand an array to %d, size is %d\n", _length, _size);}template <typename T>int ArrayList<T>::size() {return _size;}template <typename T>int ArrayList<T>::length() {return _length;}template <typename T>T ArrayList<T>::get(int index) {return _array[index];}template <typename T>void ArrayList<T>::set(int index, T t) {if (_size <= index)_size = index + 1;while (_size > _length)expand();_array[index] = t;}template <typename T>T ArrayList<T>::pop() {return _array[--_size];}template <typename T>void ArrayList<T>::delete_index(int index) {for (int i = index; i + 1 < _size; i++) {_array[i] = _array[i+1];}_size--;}template <typename T>void* ArrayList<T>::operator new(size_t size) {return Universe::heap->allocate(size);}template <typename T>void ArrayList<T>::oops_do(OopClosure* closure) {closure->do_raw_mem((char**)(&_array),_length * sizeof(T));}template <>void ArrayList<Klass*>::oops_do(OopClosure* closure) {closure->do_raw_mem((char**)(&_array),_length * sizeof(Klass*));for (int i = 0; i < size(); i++) {closure->do_klass((Klass**)&_array[i]);}return;}template <>void ArrayList<HiObject*>::oops_do(OopClosure* closure) {closure->do_raw_mem((char**)(&_array),_length * sizeof(HiObject*));for (int i = 0; i < size(); i++) {closure->do_oop((HiObject**)&_array[i]);}}template <typename T>int ArrayList<T>::index(T t) {return 0;}template <>int ArrayList<HiObject*>::index(HiObject* t) {for (int i = 0; i < _size; i++) {if (_array[i]->equal(t) == Universe::HiTrue) {return i;}}return -1;}class HiObject;template class ArrayList<HiObject*>;class HiString;template class ArrayList<HiString*>;class Block;template class ArrayList<Block*>;class Klass;template class ArrayList<Klass*>;
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。