php算法-- 关联数组使用,优化sip账号去重

1 变量定义

  • 类型:嵌套的关联数组(Nested Associative Array)
  • 外层结构:[中继ID => 账号列表]
  • 键 (Key):中继ID(字符串或整型)
  • 值 (Value):索引数组(包含属于该中继的所有SIP账号字符串)

内存形态:
php
[
“中继ID_A” => [“账号1”, “账号2”, …],
“中继ID_B” => [“账号X”, “账号Y”, …]
]


数据结构存储
// 初始状态
$existingAccounts = [
“2” => [“1001”],
“5” => [“2001”]
];

// 添加新账号到中继2
$existingAccounts[“2”][] = “1002”;

// 添加新中继组
$existingAccounts[“9”] = [“3001”];

// 最终形态
[
“2” => [“1001”, “1002”],
“5” => [“2001”],
“9” => [“3001”]
]


2. 核心特性

特性说明
按中继分组以中继ID为分组维度,天然隔离不同中继的账号
值唯一性同一中继组内SIP账号强制唯一(通过数组值隐式保证)
O(1)快速检索通过isset($existingAccounts[$trunkIdx])可瞬间判断中继是否存在
O(n)成员检查通过in_array($account, $existingAccounts[$trunkIdx])检查账号重复性

in_array解析:

$needle:要搜索的值(示例中的 SIP 账号)
$haystack:被搜索的数组(示例中的 $existingAccounts[$trunkIdx])
bool in_array(mixed $needle, array $haystack [, bool $strict = false])

code

1 基础功能:账号添加

// 检查中继组是否存在
if (!isset($existingAccounts[$trunkIdx])) {
    // 新建中继分组(初始化空数组)
    $existingAccounts[$trunkIdx] = [];
}

// 添加账号到中继组
$existingAccounts[$trunkIdx][] = $account;

2 去重高效性 ,添加新账号时,只需两步验证

$trunkIdx = "2";  // 目标中继
$newAccount = "1002";

if (isset($existingAccounts[$trunkIdx]) && 
    in_array($newAccount, $existingAccounts[$trunkIdx])) {
    // 账号已存在 → 拒绝添加
} else {
    // 安全添加账号
}

3 函数封装

// 新增账号时防重复检查
function addAccount($trunkIdx, $account) {
    global $existingAccounts;
    
    if (isset($existingAccounts[$trunkIdx]) {
        if (in_array($account, $existingAccounts[$trunkIdx])) {
            throw new Exception("账号 $account 已存在于中继 $trunkIdx");
        }
    } else {
        $existingAccounts[$trunkIdx] = []; // 初始化新中继组
    }
    
    // 安全添加账号
    $existingAccounts[$trunkIdx][] = $account;
}

// 示例:添加重复账号(触发异常)
addAccount("2", "1001");  // 抛出异常:账号1001已存在于中继2
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

八月的雨季997

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

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

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

打赏作者

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

抵扣说明:

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

余额充值