Comment appeler Java à distance basé sur RMI
Introduction
Java RMI, Remote Method Invocation, une API Java utilisée pour implémenter un appel de procédure à distance (RPCRemote procédure call), qui peut transmettre directement des objets Java sérialisés. Son implémentation repose sur la machine virtuelle Java, elle ne prend donc en charge que les appels d'une JVM à une autre.
1. Le serveur génère un registre et lie un port
2 Le serveur enregistre l'interface de service qui doit être publiée dans le registre
3. Démarre le service et attend le consommateur
4. du serveur et du port pour obtenir le registre
5. Le consommateur obtient l'interface de service qu'il souhaite fournir des services à partir du registre en fonction de son nom
6. Le consommateur appelle la méthode dans l'interface pour terminer l'appel de la méthode
Configuration de l'environnement.
Créer un module d'ingénierie
Créer une classe pojo :
package cn.hu.rmi.pojo; import java.io.Serializable; /** * @Author: hu.chen * @Description: 因为需要序列化和反序列化,所以需要实现Serializable接口 * @DateTime: 2021/12/26 5:05 PM **/ public class User implements Serializable { private Integer id; private String name; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } @Override public String toString() { return "User{" + "id=" + id + ", name='" + name + '\'' + '}'; } }
Créer une interface utilisateur :
package cn.hu.rmi.service; import cn.hu.rmi.pojo.User; import java.rmi.Remote; import java.rmi.RemoteException; /** * @Author: hu.chen * @Description: 需要提供服务的接口需要继承 Remote 并且所有的方法都需要抛出 RemoteException 异常 * @DateTime: 2021/12/26 5:06 PM **/ public interface UserService extends Remote { /** * 所有的方法都需要抛出 RemoteException 异常 * @param id * @return * @throws RemoteException */ User getUserById(Integer id) throws RemoteException; }
Fournisseur de services :
创建userservice的实现类 package cn.hu.rmi.service.impl; import cn.hu.rmi.pojo.User; import cn.hu.rmi.service.UserService; import java.rmi.RemoteException; import java.rmi.server.UnicastRemoteObject; import java.util.Map; import java.util.concurrent.ConcurrentHashMap; /** * @Author: hu.chen * @Description: 所有的实现类都需要继承 UnicastRemoteObject 这个类 * @DateTime: 2021/12/26 5:07 PM **/ public class UserServiceImpl extends UnicastRemoteObject implements UserService { private static Map<Integer,User> userMap=new ConcurrentHashMap<>(8); static { User user1=new User(); user1.setId(1); user1.setName("张三"); User user2=new User(); user2.setId(2); user2.setName("李四"); userMap.put(user1.getId(),user1); userMap.put(user2.getId(),user2); } public UserServiceImpl() throws RemoteException { super(); } @Override public User getUserById(Integer id) throws RemoteException { return userMap.get(id); } }
Démarrer et ajouter la classe d'implémentation au registre
package cn.hu.rmi.server; import cn.hu.rmi.service.UserService; import cn.hu.rmi.service.impl.UserServiceImpl; import java.rmi.RemoteException; import java.rmi.registry.LocateRegistry; import java.rmi.registry.Registry; /** * @Author: hu.chen * @Description: 服务端(服务提供者) * @DateTime: 2021/12/26 5:11 PM **/ public class RmiServer { public static void main(String[] args) throws RemoteException { // 1: 创建注册表对象,之后服务提供者暴露的服务都需要注册到这个注册表中 Registry registry = LocateRegistry.createRegistry(8089); UserService userService=new UserServiceImpl(); // 将需要提供的service服务注册到注册表中 registry.rebind("userService",userService); System.err.println("服务提供者启动成功"); } }
Consommateur du service :
package cn.hu.rmi.client; import cn.hu.rmi.pojo.User; import cn.hu.rmi.service.UserService; import java.rmi.NotBoundException; import java.rmi.RemoteException; import java.rmi.registry.LocateRegistry; import java.rmi.registry.Registry; /** * @Author: hu.chen * @Description: 客户端(服务消费者) * @DateTime: 2021/12/26 5:18 PM **/ public class RmiClient { public static void main(String[] args) throws RemoteException, NotBoundException { //1: 获取远程的注册表 Registry registry = LocateRegistry.getRegistry("127.0.0.1", 8089); UserService userService= (UserService) registry.lookup("userService"); User userById = userService.getUserById(1); System.err.println(userById); } }
Démarrez le fournisseur de services, puis démarrez le consommateur de services :
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 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

La clé pour rédiger des commentaires PHP est de clarifier l'objectif et les spécifications. Les commentaires devraient expliquer "pourquoi" plutôt que "ce qui a été fait", en évitant la redondance ou trop de simplicité. 1. Utilisez un format unifié, tel que DocBlock (/ * /) pour les descriptions de classe et de méthode afin d'améliorer la lisibilité et la compatibilité des outils; 2. Soulignez les raisons de la logique, telles que pourquoi les sauts JS doivent être sortis manuellement; 3. Ajoutez une description d'une vue d'ensemble avant le code complexe, décrivez le processus dans les étapes et aidez à comprendre l'idée globale; 4. Utilisez TODO et FIXME Rationalement pour marquer des éléments et des problèmes de tâches pour faciliter le suivi et la collaboration ultérieurs. De bonnes annotations peuvent réduire les coûts de communication et améliorer l'efficacité de la maintenance du code.

Les commentaires ne peuvent pas être négligents car ils veulent expliquer les raisons de l'existence du code plutôt que des fonctions, telles que la compatibilité avec les anciennes interfaces ou les restrictions tierces, sinon les personnes qui lisent le code ne peuvent s'appuyer que sur de la devinettes. Les zones qui doivent être commentées comprennent des jugements conditionnels complexes, une logique spéciale de gestion des erreurs et des restrictions de dérivation temporaires. Une façon plus pratique d'écrire des commentaires consiste à sélectionner des commentaires en une seule ligne ou à bloquer les commentaires en fonction de la scène. Utilisez des commentaires sur le bloc de documents pour expliquer les paramètres et les valeurs de retour au début des fonctions, des classes et des fichiers, et gardez les commentaires à jour. Pour une logique complexe, vous pouvez ajouter une ligne à la précédente pour résumer l'intention globale. En même temps, n'utilisez pas de commentaires pour sceller le code, mais utilisez des outils de contrôle de version.

La clé pour écrire de bons commentaires est d'expliquer "pourquoi" plutôt que "ce qui a été fait" pour améliorer la lisibilité du code. 1. Les commentaires devraient expliquer des raisons logiques, telles que les considérations derrière la sélection de la valeur ou le traitement; 2. Utilisez des annotations de paragraphe pour une logique complexe pour résumer l'idée globale des fonctions ou des algorithmes; 3. Maintenir régulièrement des commentaires pour garantir la cohérence avec le code, éviter les tromperies et supprimer le contenu obsolète si nécessaire; 4. Vérifiez de manière synchrone les commentaires lors de l'examen du code et enregistrez la logique publique via des documents pour réduire le fardeau des commentaires du code.

La clé pour rédiger des commentaires PHP est claire, utile et concise. 1. Les commentaires devraient expliquer l'intention derrière le code plutôt que de simplement décrire le code lui-même, comme expliquer l'objectif logique des jugements conditionnels complexes; 2. Ajouter des commentaires aux scénarios clés tels que les valeurs magiques, la compatibilité du code ancien, les interfaces API, etc. pour améliorer la lisibilité; 3. Évitez le contenu du code en double, gardez-le concis et spécifique et utilisez des formats standard tels que PHPDOC; 4. Les commentaires doivent être mis à jour de manière synchrone avec le code pour garantir la précision. De bons commentaires doivent être pensés du point de vue des autres, réduire le coût de la compréhension et devenir un dispositif de navigation de compréhension du code.

La première étape consiste à sélectionner le package d'environnement intégré XAMPP ou MAMP pour créer un serveur local; La deuxième étape consiste à sélectionner la version PHP appropriée en fonction des besoins du projet et de configurer la commutation de la version multiple; La troisième étape consiste à sélectionner VScode ou PhpStorm comme éditeur et déboguer avec xdebug; De plus, vous devez installer Composer, PHP_CODESNIFFER, PHPUNIT et d'autres outils pour aider au développement.

Les variables PHP commencent par $, et la dénomination doit suivre des règles, telles qu'elles ne peuvent pas commencer par des chiffres et sont sensibles à la casse; La portée de la variable est divisée en locale, globale et hyperglobale; Les variables globales sont accessibles en utilisant Global, mais il est recommandé de les transmettre avec des paramètres; Les variables mutables et les affectations de référence doivent être utilisées avec prudence. Les variables sont la base du stockage des données et de la maîtrise correcte de leurs règles et mécanismes est cruciale pour le développement.

Il existe trois façons courantes d'utiliser les commentaires PHP: les commentaires en une seule ligne conviennent à l'explication brièvement de la logique de code, telle que // ou # pour l'explication de la ligne actuelle; Commentaires multi-lignes /*...*/ convient à une description détaillée des fonctions ou des classes; COMMENTAIRES DOCUMENTS DOCBLOCK Commencez par / ** pour fournir des informations rapides pour l'IDE. Lorsque vous l'utilisez, vous devez éviter les bêtises, continuez à mettre à jour de manière synchrone et n'utilisez pas de commentaires pour bloquer les codes pendant longtemps.

PHP possède 8 types de variables, couramment utilisés, inclut entier, float, chaîne, booléen, array, objet, null et ressource. Pour afficher les types de variables, utilisez les fonctions GetType () ou IS_TYPE (). PHP convertira automatiquement les types, mais il est recommandé d'utiliser === pour comparer strictement la logique clé. La conversion manuelle peut être utilisée pour la syntaxe telle que (int), (chaîne), etc., mais soyez prudent que les informations peuvent être perdues.
