Android 的 SparseArray 鸿蒙有什么可以替换?

Android 的 SparseArray  鸿蒙有什么可以替换?
 

鸿蒙
安卓
HarmonyOS
2021-12-02 11:32:50
浏览
1
收藏 0
回答 2
待解决
回答 2
按赞同
/
按时间
没用的喵叔
2

在Android中,替代HashMap有如下方案:

  1. 当元素数量不太大时(数量小于1000),使用ArrayMap,对应鸿蒙的ohos.utils.LightweightMap
  2. 当key为int,使用稀疏数组SparseArray,可避免key自动装箱,对应鸿蒙的ohos.utils.PlainArray
  3. 当key和val都为int,使用SparseIntArray,可避免key和val自动装箱,对应鸿蒙的ohos.utils.PlainIntArray

 

所以,你的问题的答案是ohos.utils.PlainArray

 

深入理解,大家可以参考:深度解读ArrayMap优势与缺陷

已于2022-2-11 08:58:10修改
分享
微博
QQ
微信
回复
2022-02-10 15:07:37
Cumberland
1

可以自己实现一个

public class SparseRawArray<K extends Number, E> {
 private final LinkedHashMap<K, E> mMap;
 private Iterator<K> mIterator;
 private int mIndex;
 private boolean mIndexDirty;
 private K mCurrentKey;

 public SparseRawArray() {
  mMap = new LinkedHashMap<>();
  resetIndex();
 }

 public E get(K key) {
  return get(key, null);
 }

 public E get(K key, E valueIfKeyNotFound) {
  E value = mMap.get(key);
  return value != null ? value : valueIfKeyNotFound;
 }

 public void delete(K key) {
  mMap.remove(key);
  mIndexDirty = true;
 }

 public void remove(K key) {
  delete(key);
 }

 public void put(K key, E value) {
  mMap.put(key, value);
  mIndexDirty = true;
 }

 public int size() {
  return mMap.size();
 }

 public K keyAt(int index, K keyIfIndexNotExist) {
  if (mIndex == index && !mIndexDirty) {
   return mCurrentKey;
  }

  if (mIndexDirty || mIndex > index) {
   resetIndex();
  }

  while (mIterator.hasNext()) {
   if (++mIndex == index) {
    mCurrentKey = mIterator.next();
    return mCurrentKey;
   }
  }

  mIndexDirty = true;

  return keyIfIndexNotExist;
 }

 public void clear() {
  mMap.clear();
  mIndexDirty = true;
 }

 private void resetIndex() {
  mIndex = -1;
  mIterator = mMap.keySet().iterator();
  mCurrentKey = null;
  mIndexDirty = false;
 }
}

public class SparseArray<E> extends SparseRawArray<Integer, E> {
 public int keyAt(int index) {
  return keyAt(index, -1);
 }
}

分享
微博
QQ
微信
回复
2021-12-02 14:53:51
相关问题
鸿蒙Android、iOS什么区别?
6613浏览 • 5回复 已解决
computeScroll() 方法鸿蒙什么可以替代
1618浏览 • 1回复 待解决
HarmonyOS没类似Android里面的Fragment
8556浏览 • 4回复 待解决