gpt4 book ai didi

javascript - 根据 Javascript 中的字符串输入生成唯一编号

转载 作者:搜寻专家 更新时间:2023-11-01 04:09:59 34 4
gpt4 key购买 nike

在过去,我创建了一个从字符串生成唯一 ID(数字)的函数。今天我发现它并不像应该的那样独特。以前从未见过问题。今天,两个不同的输入生成相同的 id(数字)。

我在 Delphi、C++、PHP 和 Javascript 中使用相同的技术来生成相同的 ID,因此当项目涉及不同的语言时没有区别。例如,对于 HTML id、临时文件等,这可以方便地进行通信。

一般来说,我所做的是计算一个字符串的CRC16,加上总和并返回它。

例如这两个字符串生成相同的id(数字):

o.uniqueId( 'M:/Mijn Muziek/Various Artists/Revs & ElBee - Tell It To My Heart.mp3' );
o.uniqueId( 'M:/Mijn Muziek/Various Artists/Dwight Yoakam - The Back Of Your Hand.Mp3');

它们都生成 224904 的 id。

下面的例子是一个javascript例子。我的问题是,我怎样才能避免(稍作改动)它生成重复项? (如果您想知道“o.”是什么意思,它是这些函数所属的对象):

o.getCrc16 = function(s, bSumPos) {
if(typeof s !== 'string' || s.length === 0) {
return 0;
}
var crc = 0xFFFF,
L = s.length,
sum = 0,
x = 0,
j = 0;
for(var i = 0; i < L; i++) {
j = s.charCodeAt(i);
sum += ((i + 1) * j);
x = ((crc >> 8) ^ j) & 0xFF;
x ^= x >> 4;
crc = ((crc << 8) ^ (x << 12) ^ (x << 5) ^ x) & 0xFFFF;
}
return crc + ((bSumPos ? 1 : 0) * sum);
}
o.uniqueId = function(s, bres) {
if(s == undefined || typeof s != 'string') {
if(!o.___uqidc) {
o.___uqidc = 0;
} else {
++o.___uqidc;
}
var od = new Date(),
i = s = od.getTime() + '' + o.___uqidc;
} else {
var i = o.getCrc16(s, true);
}
return((bres) ? 'res:' : '') + (i + (i ? s.length : 0));
};

如何通过对代码进行少量更改来避免重复?

最佳答案

好吧,做了很多测试,然后来到这里。由以下内容生成的相对较短的唯一 ID:

o.lz = function(i,c)
{
if( typeof c != 'number' || c <= 0 || (typeof i != 'number' && typeof i != 'string') )
{ return i; }
i+='';

while( i.length < c )
{ i='0'+i; }
return i;
}

o.getHashCode = function(s)
{
var hash=0,c=(typeof s == 'string')?s.length:0,i=0;
while(i<c)
{
hash = ((hash<<5)-hash)+s.charCodeAt(i++);
//hash = hash & hash; // Convert to 32bit integer
}

return ( hash < 0 )?((hash*-1)+0xFFFFFFFF):hash; // convert to unsigned
};

o.uniqueId = function( s, bres )
{
if( s == undefined || typeof s != 'string' )
{
if( !o.___uqidc )
{ o.___uqidc=0; }
else { ++o.___uqidc; }
var od = new Date(),
i = s = od.getTime()+''+o.___uqidc;
}
else { var i = o.getHashCode( s ); }
return ((bres)?'res:':'')+i.toString(32)+'-'+o.lz((s.length*4).toString(16),3);
};

例子:

o.uniqueId( 'M:/Mijn Muziek/Various Artists/Revs & ElBee - Tell It To My Heart.mp3' );
o.uniqueId( 'M:/Mijn Muziek/Various Artists/Dwight Yoakam - The Back Of Your Hand.Mp3');

将产生以下 id:

dh8qi9t-114
je38ugg-120

就我的目的而言,它似乎足够独特,额外的长度也增加了一些独特性。在包含大约 40.000 个 mp3 文件的文件系统上对其进行测试,未发现任何冲突。

如果您认为这不是要走的路,请告诉我。

关于javascript - 根据 Javascript 中的字符串输入生成唯一编号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15377161/

34 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com