统计两个ip(ipv6)之间有多个地址(不管掩码,就是单纯的组合)

两个IP之间的个数计算
问题是一个IP段 192.168.4.1 192.168.5.1
问题是一个IPV6段 2000::ff 2000::100
这两个IP之间有多少个IP?有代码最好!蟹蟹分享!

有一个ipv6的实现算法有问题,如下

这个算法有问题,请给出建议:
算法代码实现:
x = 16
s6_addr:类型:unsigd char
for( i = 0; i < 16; i++) {
n = endIp->s6_addr[i] - startIp->s6_addr[i];
count = count*x + n;
}

举个计算的列子:
2000::1-2000::16
上面算法计算得出21.而不是16

我好久不写c代码了,环境都没有。大致给你说一下算法吧。
建议16位一组,分8组,这是ipv6的冒分十六进制表示法。

把它看作8位2^16进制数,如ABCD:EF01:2345:6789:ABCD:EF01:2345:6789

跟10进制运算一样的,从低位开始做减法,如果某一位上减数比被减数大,去高位借一位。
被减数高位减1,低位加2^16。

以此类推,做8次,最后拼起来就是了。

拿你的例子来说,就是:(192 * 256^3 + 168 * 256^2 + 5 * 256 + 1) - (192 * 256^3 + 168 * 256^2 + 4 * 256 + 1)
你可以把它看成是256进制的数

用.拆分,第一段256^3+第二段256^2+第三段*256+第四段,最后两个相减

你提到的场景,ip6那个你算掩码就行了吧,100-ff就是了

我是说你的实现有什么问题?
哦,8位是256,不是16

这个算法有问题,请大佬指点:
算法代码实现:
x = 16
s6_addr:类型:unsigd char
for( i = 0; i < 16; i++) {
n = endIp->s6_addr[i] - startIp->s6_addr[i];
count = count*x + n;
}

可参考这篇文章
https://blog.csdn.net/ssxxgg123/article/details/118703922?spm=1001.2014.3001.5502