Collection de questions d'entretien Java classiques (7)
Jul 15, 2020 pm 05:15 PM1. 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!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

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

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

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
échangez les visages dans n'importe quelle vidéo sans effort grace à notre outil d'échange de visage AI entièrement gratuit?!

Article chaud

Outils chauds

Bloc-notes++7.3.1
éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

Pour gérer correctement les transactions JDBC, vous devez d'abord désactiver le mode de validation automatique, puis effectuer plusieurs opérations, et enfin vous engager ou randonner en fonction des résultats; 1. Appelez Conn.SetAutoCommit (false) pour démarrer la transaction; 2. Exécuter plusieurs opérations SQL, telles que l'insertion et la mise à jour; 3. Appelez Conn.Commit () Si toutes les opérations sont réussies, et appelez Conn.Rollback () Si une exception se produit pour garantir la cohérence des données; Dans le même temps, les ressources TRY-With doivent être utilisées pour gérer les ressources, gérer correctement les exceptions et cl?turer les connexions pour éviter la fuite de connexion; De plus, il est recommandé d'utiliser des pools de connexion et de définir des points de sauvegarde pour réaliser un retour en arrière partiel, et de maintenir les transactions aussi courtes que possible pour améliorer les performances.

Pré-formancetartuptimemoryusage, quarkusandmicronautleadduetocompile-timeprocessingandgraalvsupport, withquarkusofperforming lightbetterine scénarios.

HTTP Log Middleware dans GO peut enregistrer les méthodes de demande, les chemins de requête, la propriété intellectuelle du client et le temps qui prend du temps. 1. Utilisez http.handlerfunc pour envelopper le processeur, 2. Enregistrez l'heure de début et l'heure de fin avant et après l'appel Suivant.Servehttp, 3. Obtenez le vrai client IP via R.RemoteAddr et X-Forwared-For Headers, 4. Utilisez le log.printf aux journaux de demande de sortie, 5. L'exemple de code complet a été vérifié pour s'exécuter et convient au démarrage d'un projet petit et moyen. Les suggestions d'extension incluent la capture des codes d'état, la prise en charge des journaux JSON et le suivi des ID de demande.

La collecte des ordures de Java (GC) est un mécanisme qui gère automatiquement la mémoire, ce qui réduit le risque de fuite de mémoire en récupérant des objets inaccessibles. 1. GC juge l'accessibilité de l'objet de l'objet racine (tel que les variables de pile, les threads actifs, les champs statiques, etc.), et les objets inaccessibles sont marqués comme des ordures. 2. Sur la base de l'algorithme de compensation de marque, marquez tous les objets accessibles et effacez des objets non marqués. 3. Adopter une stratégie de collecte générationnelle: la nouvelle génération (Eden, S0, S1) exécute fréquemment MinorGC; Les personnes agées fonctionnent moins, mais prend plus de temps pour effectuer MajorGC; Metaspace Stores Metadata de classe. 4. JVM fournit une variété de périphériques GC: SerialGC convient aux petites applications; Le parallelGC améliore le débit; CMS réduit

Le choix du bon type HTMLinput peut améliorer la précision des données, améliorer l'expérience utilisateur et améliorer la convivialité. 1. Sélectionnez les types d'entrée correspondants en fonction du type de données, tels que le texte, le courrier électronique, le tel, le numéro et la date, qui peuvent vérifier automatiquement la somme de la somme et l'adaptation au clavier; 2. Utilisez HTML5 pour ajouter de nouveaux types tels que l'URL, la couleur, la plage et la recherche, qui peuvent fournir une méthode d'interaction plus intuitive; 3. Utilisez l'espace réservé et les attributs requis pour améliorer l'efficacité et la précision du remplissage des formulaires, mais il convient de noter que l'espace réservé ne peut pas remplacer l'étiquette.

GradleisthebetterChoiceFormostNewProjectsDuetOtsSuperiorflexibility, Performance et ModerNtoolingSupport.1.gradle’sgroovy / kotlindslismoreConcis

Le report est utilisé pour effectuer des opérations spécifiées avant le retour de la fonction, telles que les ressources de nettoyage; Les paramètres sont évalués immédiatement lorsqu'ils sont reportés et les fonctions sont exécutées dans l'ordre de la dernière entrée (LIFO); 1. Plusieurs éleveurs sont exécutés dans l'ordre inverse des déclarations; 2. Communément utilisé pour le nettoyage sécurisé tel que la fermeture des fichiers; 3. La valeur de retour nommée peut être modifiée; 4. Il sera exécuté même si la panique se produit, adaptée à la récupération; 5. éviter l'abus de report dans les boucles pour éviter la fuite des ressources; Une utilisation correcte peut améliorer la sécurité et la lisibilité du code.

La réponse claire à cette question est la recommandation d'implémenter le modèle d'observateur à l'aide d'une interface d'observateur personnalisée. 1. Bien que Java offre observable et observateur, le premier est une classe et a été obsolète et manque de flexibilité; 2. La pratique recommandée moderne consiste à définir une interface d'observateur fonctionnel, et le sujet maintient la liste des observateurs et informe tous les observateurs lorsque l'état change; 3. Il peut être utilisé en combinaison avec les expressions de lambda pour améliorer la simplicité et la maintenabilité du code; 4. Pour les scénarios GUI ou Javabean, PropertyChangeListener peut être utilisé. Par conséquent, les nouveaux projets devraient adopter un schéma d'interface d'observateur personnalisé, qui est sécurisé, facile à tester et se spécialise dans le Java moderne
