entretien java - structure des données
Les structures de données courantes incluent : entretien java - structure des données, Hashtable, Concurrententretien java - structure des données.
(Partage de vidéos associées : vidéo d'enseignement Java)
Présentons-les séparément :
entretien java - structure des données
- Implémentation sous-jacente : la structure globale sous-jacente de entretien java - structure des données est un tableau, et chaque élément du tableau est une liste chaînée. Chaque fois qu'un objet (put) est ajouté, un objet de liste chaînée (type d'objet) sera généré. Chaque entrée dans la carte est un élément du tableau (Map.Entry est un
<key></key>
), qui pointe vers l'élément actuel. au suivant Les références aux éléments forment une liste chaînée. - Principe de stockage : lors de l'ajout d'un élément à HsahMap, calculez d'abord la valeur de hachage de l'objet Key et récupérez l'indice du tableau. Si la position dans le tableau est vide, insérez-la, sinon parcourez la liste chaînée à cet endroit. position. Lorsque l'objet Key et l'objet Node d'un nœud sont égaux au nouvel élément, remplacez l'objet Value du nœud par l'objet Value du nouvel élément, sinon insérez un nouveau nœud. (Remarque : Des arbres rouge-noir ont été ajoutés après JDK 8)
La longueur de entretien java - structure des données est de 2 élevée à la nième puissance afin de rendre tous les bits du la valeur binaire de length-1 complete est 1. Dans ce cas, lorsque la valeur de hachage et (table.length - 1) effectuent une opération & pour calculer l'index, le résultat est équivalent à la valeur des derniers chiffres du hashcode. À ce stade, tant que le hashcode d'entrée lui-même est distribué uniformément, l'algorithme de hachage Le résultat est l'uniformité. Par conséquent, la longueur par défaut de entretien java - structure des données est de 16 pour réduire la probabilité de collision de hachage, et c'est également une taille appropriée.
Table de hachage
比较点 | entretien java - structure des données | Hashtable |
---|---|---|
实现原理 | 见上小节 | 和entretien java - structure des données的实现原理几乎一样 |
Key和Value | 允许Key和Value为null | 不允许Key和Value为null |
扩容策略 | 2倍扩容oldThr
|
2倍+1扩容(oldCapacity
|
安全性 | 线程不安全 | 线程安全 |
La stratégie de sécurité des threads de la table de hachage est très coûteuse à mettre en œuvre. Toutes les opérations get/put associées sont synchronisées et les performances sont très médiocres dans des scénarios de concurrence hautement compétitifs.
Concurrententretien java - structure des données
Concurrententretien java - structure des données est une implémentation entretien java - structure des données thread-safe et efficace fournie dans le package de concurrence Java. Elle adopte une stratégie de verrouillage de segmentation très exquise. de Concurrententretien java - structure des données est le tableau Segment. Le segment hérite de ReentrantLock et est un verrou réentrant. Chaque segment est une sous-table de hachage et un tableau HashEntry est conservé dans le segment. Dans un environnement simultané, il n'est pas nécessaire de prendre en compte la concurrence des verrous lors de l'exploitation des données de différents segments.
Linkedentretien java - structure des données, TreeMap, TreeSet
- Linkedentretien java - structure des données : entretien java - structure des données à accès séquentiel (implémenté sur la base de tableaux et de listes doublement chaînées).
- TreeMap : tri interne (basé sur l'implémentation d'un arbre rouge-noir).
- TreeSet : une collection Set ordonnée (basée sur l'implémentation d'un arbre binaire).
ArrayList, LinkedList, Vector
- ArrayList : tableau dynamique (basé sur l'implémentation du tableau).
- LinkedList : tableau ordonné (implémenté sur la base d'une liste doublement chaînée).
- Vector : Conteneur d'objets, qui peut mettre des objets de différents types (implémentés en fonction de tableaux).
Collection et collections
- Collection : L'interface supérieure de la classe collection, les sous-interfaces incluent principalement List, Set, Queue, etc.
- Collections : fournit des classes d'outils pour les opérations de recherche, de tri, de remplacement et de sécurité des threads sur les collections.
(Recommandations pour des questions d'entretien plus connexes : questions et réponses d'entretien Java)
Arbre binaire
Concepts courants d'arbre binaire
Arbre B+ : voir section base de donnéeshttps://blog.csdn.net/u012102104/article/details/79773362
Arbre binaire équilibré (arbre AVL) : la valeur absolue de la différence de profondeur entre les sous-arbres gauche et droit de chaque nœud ne dépasse pas 1.
Arbre de Huffman : L'arbre binaire avec la plus petite longueur de chemin pondérée est appelé l'arbre binaire optimal. La construction de l’arbre de Huffman n’est pas unique, mais la somme des longueurs de chemin pondérées de tous les nœuds feuilles est la plus petite.
-
Arbre rouge-noir : un arbre de recherche binaire auto-équilibré, ses propriétés sont :
- Les nœuds sont rouges ou noirs.
- Le nœud racine est noir.
- Chaque nœud feuille est un nœud noir vide (nœud NIL).
- Les deux nœuds enfants de chaque nœud rouge sont noirs.
- Tous les chemins d'un nœud à chacune de ses feuilles contiennent le même nombre de nœuds noirs.
Il ne peut pas y avoir deux nœuds rouges consécutifs sur tous les chemins de chaque feuille à la racine
Parcours d'arbre binaire
// 1. 先序遍历算法 DLRvoid Preorder ( BinTree bt ) { if ( bt ) { visit ( bt->data ); Preorder ( bt->lchild ); Preorder ( bt->rchild ); }}// 2. 中序遍历算法 LDRvoid Inorder ( BinTree bt ) { if ( bt ) { Inorder ( bt->lchild ); visit ( bt->data ); Inorder ( bt->rchild ); }}// 3. 后序遍历 LRDvoid Postorder ( BinTree bt ) { if ( bt ) { Postorder ( bt->lchild ); Postorder ( bt->rchild ); visit ( bt->data ); }}// 4. 按层次遍历。/* 思路:利用一个队列,首先将根(头指针)入队列,以后若队列不空则取队头元素 p, 如果 p 不空,则访问之,然后将其左右子树入队列,如此循环直到队列为空。*/void LevelOrder ( BinTree bt ) { // 队列初始化为空 InitQueue ( Q ); // 根入队列 EnQueue ( Q, bt ); // 队列不空则继续遍历 while ( ! QueueEmpty(Q) ) { DeQueue ( Q, p ); if ( p!=NULL ) { visit ( p->data ); // 左、右子树入队列 EnQueue ( Q, p->lchild ); EnQueue ( Q, p->rchild ); } }}// 非递归遍历二叉树一般借助栈实现
Recommandations associées : Tutoriel d'introduction à Java
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

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.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

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)

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.

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.

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.

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.

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

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.

Java est un langage de programmation populaire qui peut être appris aussi bien par les développeurs débutants que par les développeurs expérimentés. Ce didacticiel commence par les concepts de base et progresse vers des sujets avancés. Après avoir installé le kit de développement Java, vous pouvez vous entraîner à la programmation en créant un simple programme « Hello, World ! ». Une fois que vous avez compris le code, utilisez l'invite de commande pour compiler et exécuter le programme, et « Hello, World ! » s'affichera sur la console. L'apprentissage de Java commence votre parcours de programmation et, à mesure que votre maîtrise s'approfondit, vous pouvez créer des applications plus complexes.

Les capsules sont des figures géométriques tridimensionnelles, composées d'un cylindre et d'un hémisphère aux deux extrémités. Le volume de la capsule peut être calculé en ajoutant le volume du cylindre et le volume de l'hémisphère aux deux extrémités. Ce tutoriel discutera de la façon de calculer le volume d'une capsule donnée en Java en utilisant différentes méthodes. Formule de volume de capsule La formule du volume de la capsule est la suivante: Volume de capsule = volume cylindrique volume de deux hémisphères volume dans, R: Le rayon de l'hémisphère. H: La hauteur du cylindre (à l'exclusion de l'hémisphère). Exemple 1 entrer Rayon = 5 unités Hauteur = 10 unités Sortir Volume = 1570,8 unités cubes expliquer Calculer le volume à l'aide de la formule: Volume = π × r2 × h (4
