Pourquoi l'API Date de Java est-elle si compliquée ?
Le cas curieux de l'API Messy Date de Java
Les classes java.util.Date et java.util.Calendar ont longtemps été critiquées pour leurs défauts inhérents. Date, un horodatage modifiable, présente de nombreux défis, tels que son incapacité à représenter explicitement les dates. Le calendrier, en revanche, combine maladroitement différents systèmes de calendrier, ce qui entraîne une expérience utilisateur lourde.
Origines de la conception défectueuse
Malgré les lacunes évidentes, ces cours ont trouvé leur place dans le SDK Java. Certains pensent que les contraintes de temps pourraient avoir joué un rôle. Cependant, une explication plus nuancée réside dans l'évolution de la conception des API au cours de cette époque.
La mutabilité dans les premières classes du JDK
La mutabilité, comme le montre Date, a été un problème. caractéristique de nombreuses premières classes JDK. Cela est né du désir d’optimiser le code en réutilisant des objets au lieu de créer des copies. À une époque où les machines virtuelles étaient moins efficaces, cette approche aurait pu paraître raisonnable.
Rétrospective rétrospective
Avec le recul, les problèmes de ces classes sont flagrants évident. Cependant, à l’époque, la compréhension des meilleures pratiques en matière de conception d’API était moins mature. De plus, toutes les implications du modèle de mutabilité de Java n'ont peut-être pas été pleinement réalisées.
Legacy of Misfortune
L'héritage de ces classes défectueuses persiste aujourd'hui, malgré l'introduction de JSR-310, qui fournit une API plus moderne et plus robuste pour travailler avec les dates et les heures. Malheureusement, de nombreuses applications existantes continuent de s'appuyer sur les anciennes classes, perpétuant ainsi leurs problèmes inhérents.
En conclusion, la nature désordonnée de l'API de date de Java souligne l'importance d'une conception réfléchie de l'API, reconnaissant les pièges potentiels de la mutabilité et la compréhension évolutive des meilleures pratiques. Même si le passé ne peut pas être modifié, les leçons tirées de ces faux pas peuvent guider les futurs efforts de développement d'API.
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.

Stock Market GPT
Recherche d'investissement basée sur l'IA pour des décisions plus intelligentes

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)

Utilisez le paramètre -cp pour ajouter le pot au ClassPath, afin que le JVM puisse charger ses classes et ressources internes, telles que Java-Cplibrary.jarcom.example.main, qui prend en charge plusieurs pots séparés par semi-colons ou couleurs, et peut également être configuré via des variables d'environnement de ClassPath Variables ou Manifest.mf.

UseFile.CreateEnewFile () toCreateaFileOnlyiFitDoOesn’texist, EvitingoverWriting; 2.Preferfiles.CreateFile () FromNio.2Formodern, SafeFilecreationThatFailSiftheFileExists; 3.UseFileWriterorPrintwriterWistereAdMedimMedimate

Javaspi est un mécanisme de découverte de service intégré dans JDK et met en œuvre une expansion dynamique orientée vers l'interface via ServiceLoader. 1. Définissez l'interface de service et créez un fichier nommé avec le nom complet de l'interface sous Meta-Inf / Services /, et écrivez le nom entièrement qualifié de la classe d'implémentation; 2. Utilisez ServiceLoader.Load () pour charger la classe d'implémentation, et le JVM lira automatiquement la configuration et l'instanciera; 3. Le contrat d'interface doit être clarifié lors de la conception, de la priorité de support et du chargement conditionnel et fournit une implémentation par défaut; 4. Les scénarios d'application incluent l'accès au canal multi-paiement et la vérification du plug-in; 5. Faites attention aux performances, à ClassPath, à l'isolement des exceptions, à la sécurité des fils et à la compatibilité des versions; 6. Dans Java9, la fourniture peut être utilisée en combinaison avec des systèmes de modules.

JavagenerricsprovideCompile-TimetypePesafetyAndeliminateStingByAllowingTypeParameTersersonClasses, Interfaces et Methods; Wildcards (?,

Utilisez le mot-clé Implements pour implémenter l'interface. La classe doit fournir des implémentations spécifiques de toutes les méthodes dans l'interface. Il prend en charge plusieurs interfaces et est séparé par des virgules pour s'assurer que les méthodes sont publiques. Les méthodes par défaut et statiques après Java 8 n'ont pas besoin d'être réécrites.

Cet article explore en profondeur le mécanisme d'envoi de plusieurs demandes HTTP sur la même prise TCP, à savoir la connexion persistante HTTP (Keep-Alive). L'article clarifie la différence entre les protocoles HTTP / 1.x et HTTP / 2, souligne l'importance de la prise en charge côté serveur pour les connexions persistantes et comment gérer correctement la connexion: fermer les en-têtes de réponse. En analysant les erreurs courantes et en fournissant les meilleures pratiques, nous visons à aider les développeurs à construire des clients HTTP efficaces et robustes.

Ce didacticiel détaille comment traiter efficacement les listes de table imbriquées contenant d'autres listes de tableaux en Java et fusionner tous ses éléments internes en un seul tableau. L'article fournira deux solutions de base grâce à l'opération FlatMap de l'API Java 8 Stream: aplatissant d'abord une liste, puis remplissant le tableau, et créant directement un nouveau tableau pour répondre aux besoins de différents scénarios.

Utilisez la classe Properties pour lire facilement les fichiers de configuration Java. 1. Mettez Config.Properties dans le répertoire de ressources, chargez-le via getClassOader (). GetResourceAsStream () et appelez la méthode Load () pour lire la configuration de la base de données. 2. Si le fichier est dans un chemin externe, utilisez FileInputStream pour le charger. 3. Utilisez GetProperty (Key, DefaultValue) pour gérer les clés manquantes et fournir des valeurs par défaut pour garantir la gestion des exceptions et la vérification des entrées.
