有没有办法让数组永不会出现越界呢?

12 篇文章 0 订阅

一个不会产生数组溢出的数组使用扩容方案

看源码里面存在这样的一个函数

源码里面array的容量始终为2^n
private fun Array<Any?>.getBufferAt(index: Long) = get(index.toInt() and (size - 1))
private fun Array<Any?>.setBufferAt(index: Long, item: Any?) = set(index.toInt() and (size - 1), item)

什么意思呢?

我们知道a % b = a & (b - 1)在b为2^n时成立。

因为源码里面array的容量始终为2^n,所以上述get 和 set 的index均为 a % b。为什么这么写呢?

下面我们写个例子看看结果🙆‍♀️

    val intArray = Array(2) { it + 1 }
    for (i in 0..10){
        println(intArray[i and (intArray.size - 1)])
    }
    //结果 
    1
    2
    1
    2
    1
    2
    1
    2
    1
    2
    1

看得出,取余的时候,永远就没有数组越界了。😮

但是,使用位运算符的方式,只能在b为2^n时成立,所以如果想要任何适合都可以使用的话,可以直接取余不通过位运算符。

    val intArray = Array(3) { it + 1 }
    for (i in 0..10){
        println(intArray[i % intArray.size])
    }
    //结果
    1
    2
    3
    1
    2
    3
    1
    2
    3
    1
    2

总结

如果你不想自己封装的代码在数组这一块出现数组越界异常的话,可以使用余数做处理。

如果你确定自己的数组容量始终以时2的倍数,可以直接使用位运算符进行取余操作。否则可以直接取余。👀

看源码看到的,分享一下 哈哈哈哈。

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

pumpkin的玄学

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值