diff options
| author | Marak <[email protected]> | 2021-03-19 22:22:51 -0400 |
|---|---|---|
| committer | GitHub <[email protected]> | 2021-03-19 22:22:51 -0400 |
| commit | b943a25ac61174a99dcd3a10110ceb2846fb167e (patch) | |
| tree | 60ad08e34465ce0e90e1b6415140f8f42a820289 /lib | |
| parent | 81f27065297c3e29eb552911b9a5dc8755600efb (diff) | |
| parent | 6d2902caf2df81fb14836b2cb4e1dbcdb72557ba (diff) | |
| download | faker-b943a25ac61174a99dcd3a10110ceb2846fb167e.tar.xz faker-b943a25ac61174a99dcd3a10110ceb2846fb167e.zip | |
Merge pull request #1143 from OleksandrYehorov/master
Improve faker.random.arrayElements performance
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/random.js | 18 |
1 files changed, 12 insertions, 6 deletions
diff --git a/lib/random.js b/lib/random.js index 6b532f25..adc9537b 100644 --- a/lib/random.js +++ b/lib/random.js @@ -82,14 +82,20 @@ function Random (faker, seed) { count = 0; } - var arrayCopy = array.slice(); - var countToRemove = arrayCopy.length - count; - for (var i = 0; i < countToRemove; i++) { - var indexToRemove = faker.datatype.number({ max: arrayCopy.length - 1 }); - arrayCopy.splice(indexToRemove, 1); + var arrayCopy = array.slice(0); + var i = array.length; + var min = i - count; + var temp; + var index; + + while (i-- > min) { + index = Math.floor((i + 1) * faker.datatype.float({ min: 0, max: 0.99 })); + temp = arrayCopy[index]; + arrayCopy[index] = arrayCopy[i]; + arrayCopy[i] = temp; } - return arrayCopy; + return arrayCopy.slice(min); }; /** |
