


Quelle est la différence entre la copie superficielle et la copie profonde en Java ?
La différence entre la copie superficielle et la copie profonde : Copie superficielle : créez un objet qui fait référence aux mêmes données, et la modification de la copie affectera également l'objet d'origine. Copie complète : créez un objet contenant une copie des données de l'objet d'origine. La modification de la copie n'affectera pas l'objet d'origine.
Copie superficielle et copie profonde en Java
Introduction
En Java, comprendre les concepts de copie superficielle et de copie profonde est crucial pour les opérations sur les objets. Ce didacticiel détaille les différences entre les deux et les illustre avec des exemples de code.
Copie superficielle
- Crée un nouvel objet qui fait référence aux mêmes données sous-jacentes de l'objet d'origine.
- Toute modification apportée à la copie superficielle sera également répercutée sur l'objet original et vice versa.
- Suivez le principe "même référence".
Exemple de code :
class Person { private String name; private Address address; } public class ShallowCopyDemo { public static void main(String[] args) { Person p1 = new Person(); p1.setName("John Doe"); Address addr = new Address(); addr.setStreet("123 Main St."); p1.setAddress(addr); // Shallow copy Person p2 = p1; // 更改 p2 的地址 p2.getAddress().setStreet("456 Elm St."); // p1 的地址也发生了变化 System.out.println(p1.getAddress().getStreet()); // 输出:456 Elm St. } }
Dans cet exemple, p2
est une copie superficielle de p1
et ils font référence au même objet Adresse
. Par conséquent, les modifications apportées à l'adresse de p2
affecteront également p1
. p2
是 p1
的浅拷贝,它们引用相同的 Address
对象。因此,对 p2
的地址进行更改也会影响 p1
。
深拷贝
- 创建一个新对象,该对象拥有原始对象底层数据的独立副本。
- 更改深拷贝不会影响原始对象,反之亦然。
- 遵循“内容相同”原则。
代码示例:
使用 clone()
方法或第三方库(如 Apache Commons Lang)来实现深拷贝。
使用 clone() 方法:
class Person implements Cloneable { private String name; private Address address; @Override public Person clone() { try { // 使用 super.clone() 创建新对象 return (Person) super.clone(); } catch (CloneNotSupportedException e) { e.printStackTrace(); } return null; } } public class DeepCopyDemo { public static void main(String[] args) { Person p1 = new Person(); p1.setName("John Doe"); Address addr = new Address(); addr.setStreet("123 Main St."); p1.setAddress(addr); // Deep copy Person p2 = p1.clone(); // 更改 p2 的地址 p2.getAddress().setStreet("456 Elm St."); // p1 的地址保持不变 System.out.println(p1.getAddress().getStreet()); // 输出:123 Main St. } }
在此示例中,clone()
方法为 p1
创建了一个深拷贝。更改 p2
的地址不会影响 p1
,因为它们引用不同的 Address
Copie approfondie
- Crée un nouvel objet qui contient une copie indépendante des données sous-jacentes de l'objet d'origine.
- La modification de la copie complète n'affectera pas l'objet original et vice versa. Suivez le principe du "
- même contenu".
Exemple de code :
🎜🎜Utilisez la méthodeclone()
ou une bibliothèque tierce (telle qu'Apache Commons Lang) pour implémenter la copie approfondie. 🎜🎜🎜Utilisation de la méthode clone() : 🎜🎜rrreee🎜Dans cet exemple, la méthode clone()
crée une copie complète de p1
. Changer l'adresse de p2
n'affectera pas p1
car ils font référence à des objets Address
différents. 🎜🎜🎜Quand utiliser la copie profonde ou la copie superficielle ? 🎜🎜🎜🎜🎜Copie superficielle : 🎜Une copie superficielle peut être effectuée lorsqu'il n'y a aucun effet secondaire sur la modification de la copie de l'objet. 🎜🎜🎜Copie approfondie : 🎜Une copie approfondie est nécessaire lors de la modification d'une copie d'un objet pouvant affecter l'objet d'origine. 🎜🎜🎜 Par exemple, utilisez toujours des copies complètes lorsque vous mettez des objets en cache ou que vous les transmettez à du code non fiable. 🎜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

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à 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)

Sujets chauds

Pour configurer un répertoire CGI dans Apache, vous devez effectuer les étapes suivantes: Créez un répertoire CGI tel que "CGI-Bin" et accorder des autorisations d'écriture Apache. Ajoutez le bloc directif "Scriptalias" dans le fichier de configuration Apache pour mapper le répertoire CGI à l'URL "/ cgi-bin". Redémarrez Apache.

Lorsque le port Apache 80 est occupé, la solution est la suivante: découvrez le processus qui occupe le port et fermez-le. Vérifiez les paramètres du pare-feu pour vous assurer qu'Apache n'est pas bloqué. Si la méthode ci-dessus ne fonctionne pas, veuillez reconfigurer Apache pour utiliser un port différent. Redémarrez le service Apache.

Les étapes pour démarrer Apache sont les suivantes: Installez Apache (Commande: Sudo apt-get install Apache2 ou téléchargez-le à partir du site officiel) Start Apache (Linux: Sudo SystemCTL Démarrer Apache2; Windows: Cliquez avec le bouton droit sur le service "APACHE2.4" et SELECT ") Vérifiez si elle a été lancée (Linux: SUDO SYSTEMCTL STATURE APACHE2; (Facultatif, Linux: Sudo SystemCTL

Apache se connecte à une base de données nécessite les étapes suivantes: Installez le pilote de base de données. Configurez le fichier web.xml pour créer un pool de connexion. Créez une source de données JDBC et spécifiez les paramètres de connexion. Utilisez l'API JDBC pour accéder à la base de données à partir du code Java, y compris l'obtention de connexions, la création d'instructions, les paramètres de liaison, l'exécution de requêtes ou de mises à jour et de traitement des résultats.

Pour supprimer une directive de nom de serveur supplémentaire d'Apache, vous pouvez prendre les étapes suivantes: Identifier et supprimer la directive supplémentaire de serveur. Redémarrez Apache pour que les modifications prennent effet. Vérifiez le fichier de configuration pour vérifier les modifications. Testez le serveur pour vous assurer que le problème est résolu.

Il existe 3 façons d'afficher la version sur le serveur Apache: via la ligne de commande (apachectl -v ou apache2ctl -v), cochez la page d'état du serveur (http: // & lt; serveur ip ou nom de domaine & gt; / server-status), ou afficher le fichier de configuration Apache (serverVeelion: apache / & lt; version & gt;).

Comment configurer Zend dans Apache? Les étapes pour configurer Zend Framework dans un serveur Web Apache sont les suivantes: installer Zend Framework et l'extraire dans le répertoire du serveur Web. Créez un fichier .htaccess. Créez le répertoire d'application Zend et ajoutez le fichier index.php. Configurez l'application Zend (application.ini). Redémarrez le serveur Web Apache.

Cet article examine comment améliorer l'efficacité du traitement des données Hadoop sur les systèmes Debian. Les stratégies d'optimisation couvrent les mises à niveau matérielle, les ajustements des paramètres du système d'exploitation, les modifications de configuration de Hadoop et l'utilisation d'algorithmes et d'outils efficaces. 1. Le renforcement des ressources matérielles garantit que tous les nœuds ont des configurations matérielles cohérentes, en particulier en faisant attention aux performances du CPU, de la mémoire et de l'équipement réseau. Le choix des composants matériels de haute performance est essentiel pour améliorer la vitesse de traitement globale. 2. Réglage des paramètres JVM: Ajustez dans le fichier hadoop-env.sh
