Maison > interface Web > js tutoriel > Set vs Array en JavaScript : quand utiliser lequel ?

Set vs Array en JavaScript : quand utiliser lequel ?

Barbara Streisand
Libérer: 2025-01-22 20:41:14
original
559 Les gens l'ont consulté

Set vs Array in JavaScript: When to Use Which?

JavaScript fournit deux structures de données puissantes pour stocker les collections : Set et Array. Bien que les deux puissent stocker plusieurs valeurs, leurs caractéristiques uniques les rendent mieux adaptés à différents scénarios. Voyons quand et pourquoi choisir l’un plutôt que l’autre.

  1. Valeur unique par défaut

Set La fonctionnalité la plus notable est sa gestion automatique des doublons.

<code class="language-javascript">// 数组允许重复
const arr = [1, 2, 2, 3, 3, 4];
console.log(arr); // [1, 2, 2, 3, 3, 4]

// Set 自动删除重复项
const set = new Set([1, 2, 2, 3, 3, 4]);
console.log([...set]); // [1, 2, 3, 4]

// 使用 Set 从数组中删除重复项
const uniqueArray = [...new Set(arr)];
console.log(uniqueArray); // [1, 2, 3, 4]</code>
Copier après la connexion
  1. Performances de vérification des éléments

Set fournit des temps de recherche plus rapides pour vérifier si un élément existe.

<code class="language-javascript">const largeArray = Array.from({ length: 1000000 }, (_, i) => i);
const largeSet = new Set(largeArray);

// 数组查找
console.time('Array includes');
console.log(largeArray.includes(999999));
console.timeEnd('Array includes');

// Set 查找
console.time('Set has');
console.log(largeSet.has(999999));
console.timeEnd('Set has');

// Set 明显更快,因为它内部使用哈希表</code>
Copier après la connexion
  1. Méthodes et opérations disponibles

Array fournit des méthodes plus intégrées pour la manipulation des données, tandis que Set se concentre sur la gestion de l'unicité.

<code class="language-javascript">// 数组方法
const arr = [1, 2, 3, 4, 5];
arr.push(6);                    // 添加到末尾
arr.pop();                      // 从末尾移除
arr.unshift(0);                 // 添加到开头
arr.shift();                    // 从开头移除
arr.splice(2, 1, 'new');       // 替换元素
arr.slice(1, 3);               // 提取部分
arr.map(x => x * 2);           // 转换元素
arr.filter(x => x > 2);        // 过滤元素
arr.reduce((a, b) => a + b);   // 归约为单个值

// Set 方法
const set = new Set([1, 2, 3, 4, 5]);
set.add(6);                    // 添加值
set.delete(6);                 // 删除值
set.has(5);                    // 检查是否存在
set.clear();                   // 删除所有值</code>
Copier après la connexion
  1. Accès séquentiel et indexé

Array gère l'ordre d'insertion et fournit un accès basé sur l'index, tandis que Set ne gère que l'ordre d'insertion.

<code class="language-javascript">// 数组索引访问
const arr = ['a', 'b', 'c'];
console.log(arr[0]);      // 'a'
console.log(arr[1]);      // 'b'
arr[1] = 'x';            // 直接修改

// Set 没有索引访问
const set = new Set(['a', 'b', 'c']);
console.log([...set][0]); // 需要先转换为数组
// 不允许直接修改索引</code>
Copier après la connexion
  1. Utilisation de la mémoire

Set utilise généralement plus de mémoire que Array mais permet des recherches plus rapides.

<code class="language-javascript">// 内存比较(粗略示例)
const numbers = Array.from({ length: 1000 }, (_, i) => i);

// 数组内存
const arr = [...numbers];
console.log(process.memoryUsage().heapUsed);

// Set 内存
const set = new Set(numbers);
console.log(process.memoryUsage().heapUsed);
// 由于哈希表结构,Set 通常使用更多内存</code>
Copier après la connexion
  1. Cas d'utilisation courants

Quand utiliser les tableaux :

<code class="language-javascript">// 1. 当顺序和索引访问很重要时
const playlist = ['song1.mp3', 'song2.mp3', 'song3.mp3'];
const currentTrack = playlist[currentIndex];

// 2. 当您需要数组方法时
const numbers = [1, 2, 3, 4, 5];
const doubled = numbers.map(x => x * 2);
const sum = numbers.reduce((a, b) => a + b, 0);

// 3. 当重复值可以接受或需要时
const votes = ['yes', 'no', 'yes', 'yes', 'no'];
const yesVotes = votes.filter(vote => vote === 'yes').length;</code>
Copier après la connexion

Quand utiliser Set :

<code class="language-javascript">// 1. 当跟踪唯一值时
const uniqueVisitors = new Set();
function logVisitor(userId) {
    uniqueVisitors.add(userId);
    console.log(`Total unique visitors: ${uniqueVisitors.size}`);
}

// 2. 用于快速查找操作
const allowedUsers = new Set(['user1', 'user2', 'user3']);
function checkAccess(userId) {
    return allowedUsers.has(userId);
}

// 3. 用于删除重复项
function getUniqueHashtags(posts) {
    const uniqueTags = new Set();
    posts.forEach(post => {
        post.hashtags.forEach(tag => uniqueTags.add(tag));
    });
    return [...uniqueTags];
}</code>
Copier après la connexion

Convertir entre Set et Array

Vous pouvez facilement basculer entre Set et Array selon vos besoins.

<code class="language-javascript">// 数组到 Set
const arr = [1, 2, 2, 3, 3, 4];
const set = new Set(arr);

// Set 到数组 - 三种方法
const back1 = [...set];
const back2 = Array.from(set);
const back3 = Array.from(set.values());

// 用于数组去重
const deduped = [...new Set(arr)];</code>
Copier après la connexion

Conclusion

Choisissez Array quand vous en avez besoin :

  • Accès basé sur un index
  • Méthodes de tableaux étendues (cartographie, réduction, filtre, etc.)
  • Valeur en double
  • Efficacité de la mémoire
  • Mode itération traditionnel

Choisissez Set quand vous en avez besoin :

  • Valeurs uniques uniquement
  • Opération de recherche rapide
  • Opération simple d'ajout/suppression
  • Gardez une liste d'articles uniques
  • Supprimez rapidement les doublons

N'oubliez pas que vous pouvez basculer entre les deux types à tout moment, alors choisissez celui qui correspond le mieux à vos besoins actuels.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal