Maison Java JavaQuestions d'entretien Collection de questions d'entretien Java classiques (7)

Collection de questions d'entretien Java classiques (7)

Jul 15, 2020 pm 05:15 PM
java 面试题

Collection de questions d'entretien Java classiques (7)

1. Parlons de la différence entre ArrayList et Vector

(questions d'entretien plus recommandées : questions d'entretien Java )

1. Synchronicité : Vector est thread-safe. Utilisez synchronisé pour assurer la sécurité des threads, tandis qu'ArrayList n'est pas sécurisé pour les threads. Si un seul thread accède à la collection, il est préférable d'utiliser ArrayList car ce n'est pas le cas. considérez Thread-safe, l'efficacité sera plus élevée ;

Si plusieurs threads accèdent à la collection, il est préférable d'utiliser Vector, car nous n'avons pas besoin de penser et d'écrire du code thread-safe.

2. Croissance de la capacité des données : les deux ont une taille de capacité initiale et utilisent un espace de stockage continu linéaire. Lorsque le nombre d'éléments stockés dépasse la capacité, l'espace de stockage des deux doit être augmenté et Vector double. valeur d'origine, ArrayList augmente de 0,5 fois la valeur d'origine.

2. Pourquoi ArrayList est-il dangereux pour les threads

L'opération d'ajout d'éléments à ArrayList s'effectue en deux étapes, c'est-à-dire la première étape ? consiste d'abord à stocker les éléments à ajouter à l'emplacement de l'objet[taille]; dans la deuxième étape, augmentez la valeur de taille de 1.

Comme il n'est pas garanti que ce processus soit atomique dans un environnement multithread, ArrayList n'est pas sécurisé pour les threads dans un environnement multithread.

(Recommandations de didacticiel associées : Tutoriel d'introduction à Java)

3. Quelles sont les différences entre HashMap, LinkedHashMap et TreeMap ?

1. HashMap est la carte la plus couramment utilisée. Elle stocke les données en fonction de la valeur hashCode de la clé, et a une vitesse d'accès très rapide. HashMap permet uniquement à la clé d'un enregistrement d'être nulle et ne permet pas à la valeur de plusieurs enregistrements d'être nulle.

HashMap ne prend pas en charge la synchronisation des threads, c'est-à-dire que plusieurs threads peuvent écrire HashMap en même temps à tout moment, ce qui peut entraîner une incohérence des données. Si une synchronisation est requise, vous pouvez utiliser la méthode Collections.synchronizedMap(HashMap map) pour synchroniser HashMap.

2. Hashtable est similaire à HashMap, sauf qu'il ne permet pas aux clés ou valeurs enregistrées d'être vides ; il prend en charge la synchronisation des threads, c'est-à-dire qu'un seul thread peut écrire dans la Hashtable à tout moment. Cependant, cela conduit également à ce que Hashtable soit plus lent lors de l'écriture.

3. LinkedHashMap enregistre l'ordre d'insertion des enregistrements Lors de la traversée de LinkedHashMap avec Iteraor, l'enregistrement obtenu en premier doit être inséré en premier. Il sera plus lent que HashMap lors de la traversée. Possède toutes les fonctionnalités de HashMap.

4. TreeMap peut trier les enregistrements qu'il enregistre en fonction des clés. La valeur par défaut est par ordre croissant. Vous pouvez également spécifier un comparateur pour le tri. Lorsque vous utilisez Iteraor pour parcourir un TreeMap, les enregistrements obtenus sont triés. Les clés et valeurs de TreeMap ne peuvent pas être vides.

4. Comment supprimer les éléments en double d'une collection Vector ?

Utilisez la méthode Vector.contains() pour déterminer si l'élément est inclus. S'il n'est pas inclus, ajoutez-le à une nouvelle collection. Cela convient aux cas où les données sont petites.

Il existe également un moyen simple de parcourir le vecteur et de mettre set, SortdSet, HashSet, etc.

(Tutoriel vidéo recommandé : Tutoriel vidéo Java)

5. Quelles sont les caractéristiques des trois interfaces List, Map et Set lors de l'accès aux éléments ?

1. Les éléments en double ne sont pas autorisés dans Set

Stockage des éléments :

La méthode add a une valeur de retour booléenne lorsqu'il n'y en a pas. élément dans l'ensemble, pour un élément, lorsque la méthode add peut ajouter l'élément avec succès, elle renvoie true lorsque l'ensemble contient un élément égal à un élément égal, la méthode add ne peut pas ajouter l'élément à ce moment et le résultat renvoyé est faux.

Obtenir des éléments :

Il n'y a aucun moyen de savoir quel numéro obtenir. Vous ne pouvez obtenir tous les éléments que via l'interface Iterator, puis parcourir chaque élément un par un.

2. List représente une collection séquentielle

Stockage des éléments :

Lorsque la méthode add(Object) est appelée plusieurs fois, les objets ajoutés à chaque fois sont triés dans l'ordre. du premier arrivé, premier servi , vous pouvez également sauter dans la file d'attente, c'est-à-dire appeler la méthode add(int index,Object) pour spécifier l'emplacement de stockage de l'objet actuel dans la collection.

Obtention d'éléments :

Méthode 1 : l'interface Iterator récupère tous les éléments et parcourt chaque élément un par un.

Méthode 2 : Appelez get(index i) pour indiquer clairement quel index prendre. Utilisez cette interface pour contrôler précisément la position d’insertion de chaque élément. Les utilisateurs peuvent accéder aux éléments de la liste à l'aide de l'index (la position de l'élément dans la liste, similaire à un indice de tableau), qui est similaire à un tableau Java.

3. Map est une collection à deux colonnes

Stockage des éléments :

Utilisez la méthode put, put(obj key, obj value). besoin d'en stocker une. Pour la clé/valeur, les clés en double ne peuvent pas être stockées. La règle de duplication est également basée sur une comparaison égale.

Obtenir des éléments :

Utilisez la méthode get(Object key) pour obtenir la valeur correspondante en fonction de la clé. Vous pouvez également obtenir une collection de toutes les clés, une collection de toutes les valeurs et une collection d'objets Map.Entry composés de clés et de valeurs.

La liste contient les éléments dans un ordre spécifique et peut avoir des éléments en double ; Set ne peut pas avoir d'éléments en double et est trié en interne ; Map enregistre les valeurs clé-valeur et la valeur peut être à plusieurs valeurs.

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!

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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Racine carrée en Java Racine carrée en Java Aug 30, 2024 pm 04:26 PM

Guide de la racine carrée en Java. Nous discutons ici du fonctionnement de Square Root en Java avec un exemple et son implémentation de code respectivement.

Nombre parfait en Java Nombre parfait en Java Aug 30, 2024 pm 04:28 PM

Guide du nombre parfait en Java. Nous discutons ici de la définition, comment vérifier le nombre parfait en Java ?, des exemples d'implémentation de code.

Générateur de nombres aléatoires en Java Générateur de nombres aléatoires en Java Aug 30, 2024 pm 04:27 PM

Guide du générateur de nombres aléatoires en Java. Nous discutons ici des fonctions en Java avec des exemples et de deux générateurs différents avec d'autres exemples.

Weka en Java Weka en Java Aug 30, 2024 pm 04:28 PM

Guide de Weka en Java. Nous discutons ici de l'introduction, de la façon d'utiliser Weka Java, du type de plate-forme et des avantages avec des exemples.

Numéro de Smith en Java Numéro de Smith en Java Aug 30, 2024 pm 04:28 PM

Guide du nombre de Smith en Java. Nous discutons ici de la définition, comment vérifier le numéro Smith en Java ? exemple avec implémentation de code.

Questions d'entretien chez Java Spring Questions d'entretien chez Java Spring Aug 30, 2024 pm 04:29 PM

Dans cet article, nous avons conservé les questions d'entretien Java Spring les plus posées avec leurs réponses détaillées. Pour que vous puissiez réussir l'interview.

Break or Return of Java 8 Stream Forach? Break or Return of Java 8 Stream Forach? Feb 07, 2025 pm 12:09 PM

Java 8 présente l'API Stream, fournissant un moyen puissant et expressif de traiter les collections de données. Cependant, une question courante lors de l'utilisation du flux est: comment se casser ou revenir d'une opération FOREAK? Les boucles traditionnelles permettent une interruption ou un retour précoce, mais la méthode Foreach de Stream ne prend pas directement en charge cette méthode. Cet article expliquera les raisons et explorera des méthodes alternatives pour la mise en œuvre de terminaison prématurée dans les systèmes de traitement de flux. Lire plus approfondie: Améliorations de l'API Java Stream Comprendre le flux Forach La méthode foreach est une opération terminale qui effectue une opération sur chaque élément du flux. Son intention de conception est

Horodatage à ce jour en Java Horodatage à ce jour en Java Aug 30, 2024 pm 04:28 PM

Guide de TimeStamp to Date en Java. Ici, nous discutons également de l'introduction et de la façon de convertir l'horodatage en date en Java avec des exemples.

See all articles