- ප්රශ්නය ටිකක් පරණයි, නමුත් මෙහි දී ඇති සියලුම පිළිතුරු සහ ජිම් බක් විසින් බෙදාගත් jsperf මත පදනම්ව මා විසින් සාදන ලද මිණුම් සලකුණු කිහිපයක් ඔබට පෙන්වීමට මෙම පිළිතුර ලිවීමට මට අවශ්ය විය.
දිගු ඉඳිකටුවක් දිගු පිදුරු මඩුවක තිබේදැයි සොයා බැලීමට මට මූලික වශයෙන් වේගවත් ක්රමයක් අවශ්ය වූ අතර අවසාන අක්ෂර හැර ඒවා බොහෝ සමාන වේ.
nestedString
අක්ෂර 1.000.0001 කින් යුත් පිදුරු දණ්ඩකට ( ) සහ ව්යාජ හෝ සත්ය ඉඳිකටු නූල 1.000.000 ට එරෙහිව ව්යාජ හා සත්ය ලෙස නැවත පැමිණෙන විට එක් එක් ශ්රිතය (භේදය, උපස්ථරය, ආරම්භය, ආදිය) පරීක්ෂා කරන කේතය මෙන්න. අක්ෂර ( testParentStringFalse
සහ testParentStringTrue
, පිළිවෙලින්):
// nestedString is made of 1.000.001 '1' repeated characters.
var nestedString = '...'
// testParentStringFalse is made of 1.000.000 characters,
// all characters are repeated '1', but the last one is '2',
// so for this string the test should return false.
var testParentStringFalse = '...'
// testParentStringTrue is made of 1.000.000 '1' repeated characters,
// so for this string the test should return true.
var testParentStringTrue = '...'
// You can make these very long strings by running the following bash command
// and edit each one as needed in your editor
// (NOTE: on OS X, `pbcopy` copies the string to the clipboard buffer,
// on Linux, you would probably need to replace it with `xclip`):
//
// printf '1%.0s' {1..1000000} | pbcopy
//
function testString() {
let dateStart
let dateEnd
let avg
let count = 100000
const falseResults = []
const trueResults = []
/* slice */
console.log('========> slice')
dateStart = +new Date()
var res
for (let j = 0; j < count; j++) {
res = nestedString.slice(0, testParentStringFalse.length) === testParentStringFalse
}
dateEnd = +new Date()
avg = (dateEnd - dateStart)/count
falseResults[falseResults.length] = {
label: 'slice',
avg
}
console.log(`testString() slice = false`, res, 'avg: ' + avg + 'ms')
dateStart = +new Date()
var res
for (let j = 0; j < count; j++) {
res = nestedString.slice(0, testParentStringTrue.length) === testParentStringTrue
}
dateEnd = +new Date()
avg = (dateEnd - dateStart)/count
trueResults[trueResults.length] = {
label: 'slice',
avg
}
console.log(`testString() slice = true`, res, 'avg: ' + avg + 'ms')
console.log('<======== slice')
console.log('')
/* slice END */
/* lastIndexOf */
console.log('========> lastIndexOf')
dateStart = +new Date()
var res
for (let j = 0; j < count; j++) {
res = nestedString.lastIndexOf(testParentStringFalse, 0) === 0
}
dateEnd = +new Date()
avg = (dateEnd - dateStart)/count
falseResults[falseResults.length] = {
label: 'lastIndexOf',
avg
}
console.log(`testString() lastIndexOf = false`, res, 'avg: ' + avg + 'ms')
dateStart = +new Date()
var res
for (let j = 0; j < count; j++) {
res = nestedString.lastIndexOf(testParentStringTrue, 0) === 0
}
dateEnd = +new Date()
avg = (dateEnd - dateStart)/count
trueResults[trueResults.length] = {
label: 'lastIndexOf',
avg
}
console.log(`testString() lastIndexOf = true`, res, 'avg: ' + avg + 'ms')
console.log('<======== lastIndexOf')
console.log('')
/* lastIndexOf END */
/* indexOf */
console.log('========> indexOf')
dateStart = +new Date()
var res
for (let j = 0; j < count; j++) {
res = nestedString.indexOf(testParentStringFalse) === 0
}
dateEnd = +new Date()
avg = (dateEnd - dateStart)/count
falseResults[falseResults.length] = {
label: 'indexOf',
avg
}
console.log(`testString() indexOf = false`, res, 'avg: ' + avg + 'ms')
dateStart = +new Date()
var res
for (let j = 0; j < count; j++) {
res = nestedString.indexOf(testParentStringTrue) === 0
}
dateEnd = +new Date()
avg = (dateEnd - dateStart)/count
trueResults[trueResults.length] = {
label: 'indexOf',
avg
}
console.log(`testString() indexOf = true`, res, 'avg: ' + avg + 'ms')
console.log('<======== indexOf')
console.log('')
/* indexOf END */
/* substring */
console.log('========> substring')
dateStart = +new Date()
var res
for (let j = 0; j < count; j++) {
res = nestedString.substring(0, testParentStringFalse.length) === testParentStringFalse
}
dateEnd = +new Date()
avg = (dateEnd - dateStart)/count
falseResults[falseResults.length] = {
label: 'substring',
avg
}
console.log(`testString() substring = false`, res, 'avg: ' + avg + 'ms')
dateStart = +new Date()
var res
for (let j = 0; j < count; j++) {
res = nestedString.substring(0, testParentStringTrue.length) === testParentStringTrue
}
dateEnd = +new Date()
avg = (dateEnd - dateStart)/count
trueResults[trueResults.length] = {
label: 'substring',
avg
}
console.log(`testString() substring = true`, res, 'avg: ' + avg + 'ms')
console.log('<======== substring')
console.log('')
/* substring END */
/* startsWith */
console.log('========> startsWith')
dateStart = +new Date()
var res
for (let j = 0; j < count; j++) {
res = nestedString.startsWith(testParentStringFalse)
}
dateEnd = +new Date()
avg = (dateEnd - dateStart)/count
falseResults[falseResults.length] = {
label: 'startsWith',
avg
}
console.log(`testString() startsWith = false`, res, 'avg: ' + avg + 'ms')
dateStart = +new Date()
var res
for (let j = 0; j < count; j++) {
res = nestedString.startsWith(testParentStringTrue)
}
dateEnd = +new Date()
avg = (dateEnd - dateStart)/count
trueResults[trueResults.length] = {
label: 'startsWith',
avg
}
console.log(`testString() startsWith = true`, res, 'avg: ' + avg + 'ms')
console.log('<======== startsWith')
console.log('')
/* startsWith END */
falseResults.sort((a, b) => a.avg - b.avg)
trueResults.sort((a, b) => a.avg - b.avg)
console.log('false results from fastest to slowest avg:', falseResults)
console.log('true results from fastest to slowest avg:', trueResults)
}
මම මෙම මිණුම් දණ්ඩ පරීක්ෂණය ක්රියාත්මක කළෙමි ක්රෝම් 75 , ෆයර්ෆොක්ස් 67 , සෆාරි 12 සහ ඔපෙරා 62 .
මම මෙම යන්ත්රය තුළ නොමැති නිසා මම එඩ්ජ් සහ අයිඊ ඇතුළත් කර නැත, නමුත් ඔබෙන් කෙනෙකුට එඩ්ජ්ට හා අවම වශයෙන් අයිඊ 9 ට එරෙහිව ස්ක්රිප්ට් ධාවනය කර ප්රතිදානය මෙහි බෙදා ගැනීමට අවශ්ය නම් ප්රති .ල දැකීමට මා තුළ කුතුහලයක් ඇති වනු ඇත.
ඔබට දිගු නූල් 3 නැවත ප්රතිනිර්මාණය කර ස්ක්රිප්ට් ගොනුවක සුරැකීමට අවශ්ය බව මතක තබා ගන්න, ඉන්පසු බ්රව්සරයේ කොන්සෝලයෙහි පිටපත් / පේස්ට් ලෙස ඔබේ බ්රව්සරයේ විවෘත වන අතර එය එක් එක් නූල් වල දිග> = 1.000.000 බැවින් එය අවහිර කරනු ඇත).
ප්රතිදානයන් මෙන්න:
ක්රෝම් 75 ( substring
ජයග්රහණ):
false results from fastest to slowest avg:
1) {"label":"substring","avg":0.08271}
2) {"label":"slice","avg":0.08615}
3) {"label":"lastIndexOf","avg":0.77025}
4) {"label":"indexOf","avg":1.64375}
5) {"label":"startsWith","avg":3.5454}
true results from fastest to slowest avg:
1) {"label":"substring","avg":0.08213}
2) {"label":"slice","avg":0.08342}
3) {"label":"lastIndexOf","avg":0.7831}
4) {"label":"indexOf","avg":0.88988}
5) {"label":"startsWith","avg":3.55448}
ෆයර්ෆොක්ස් 67 (indexOf
ජයග්රහණ):
false results from fastest to slowest avg
1) {"label":"indexOf","avg":0.1807}
2) {"label":"startsWith","avg":0.74621}
3) {"label":"substring","avg":0.74898}
4) {"label":"slice","avg":0.78584}
5) {"label":"lastIndexOf","avg":0.79668}
true results from fastest to slowest avg:
1) {"label":"indexOf","avg":0.09528}
2) {"label":"substring","avg":0.75468}
3) {"label":"startsWith","avg":0.76717}
4) {"label":"slice","avg":0.77222}
5) {"label":"lastIndexOf","avg":0.80527}
සෆාරි 12 (slice
ව්යාජ ප්රති results startsWith
ල සඳහා ජයග්රහණ, සත්ය ප්රති results ල සඳහා ජයග්රහණ, සහ සම්පූර්ණ පරීක්ෂණය ක්රියාත්මක කිරීමට ගතවන කාලය අනුව වේගවත්ම වේ සෆාරි):
false results from fastest to slowest avg:
1) "{\"label\":\"slice\",\"avg\":0.0362}"
2) "{\"label\":\"startsWith\",\"avg\":0.1141}"
3) "{\"label\":\"lastIndexOf\",\"avg\":0.11512}"
4) "{\"label\":\"substring\",\"avg\":0.14751}"
5) "{\"label\":\"indexOf\",\"avg\":0.23109}"
true results from fastest to slowest avg:
1) "{\"label\":\"startsWith\",\"avg\":0.11207}"
2) "{\"label\":\"lastIndexOf\",\"avg\":0.12196}"
3) "{\"label\":\"substring\",\"avg\":0.12495}"
4) "{\"label\":\"indexOf\",\"avg\":0.33667}"
5) "{\"label\":\"slice\",\"avg\":0.49923}"
ඔපෙරා 62 (substring
ජය. ප්රති Results ල ක්රෝම් වලට සමාන වන අතර ඔපෙරා ක්රෝමියම් සහ බ්ලින්ක් මත පදනම් වී ඇති බැවින් මම පුදුම නොවෙමි):
false results from fastest to slowest avg:
{"label":"substring","avg":0.09321}
{"label":"slice","avg":0.09463}
{"label":"lastIndexOf","avg":0.95347}
{"label":"indexOf","avg":1.6337}
{"label":"startsWith","avg":3.61454}
true results from fastest to slowest avg:
1) {"label":"substring","avg":0.08855}
2) {"label":"slice","avg":0.12227}
3) {"label":"indexOf","avg":0.79914}
4) {"label":"lastIndexOf","avg":1.05086}
5) {"label":"startsWith","avg":3.70808}
සෑම බ්රව්සරයකටම තමන්ගේම ක්රියාත්මක කිරීමේ තොරතුරු ඇති බව පෙනේ (ඔපෙරා හැර, එය ක්රෝම් හි ක්රෝමියම් සහ බ්ලින්ක් මත පදනම් වේ).
ඇත්ත වශයෙන්ම, විවිධ භාවිත අවස්ථා සමඟ තවදුරටත් පරීක්ෂා කළ හැකි හා කළ යුතු ය (උදා: පිදුරු මඩුව හා සසඳන විට ඉඳිකටුවක් කෙටි වන විට, පිදුරු මඩුව ඉඳිකටුවට වඩා කෙටි වන විට ...), නමුත් මගේ නඩුවේදී මට ඉතා දිගු නූල් සංසන්දනය කිරීමට අවශ්ය විය. එය මෙහි බෙදා ගැනීමට අවශ්ය විය.