Définir le délai d'attente pour Socket en Java
Il existe deux manières principales de définir le délai d'expiration de Socket en Java. Jetons un coup d'œil : (Recommandé : tutoriel vidéo Java)
Méthode 1 :
Socket s=new Socket(); s.connect(new InetSocketAddress(host,port),10000);
Méthode 2 :
Socket s=new Socket("127.0.0.1",8080); s.setSoTimeout(10000);
Alors, que signifient les délais d'attente définis dans ces deux méthodes ? Quelle est la différence ?
Méthode 1
Jetons d'abord un coup d'œil à la méthode 1, testons-la :
Dans la méthode principale, nous créons Socket Connect à
ip : 29.212.19.201, port : 2132
public static void main(String[] args) { Socket socket = new Socket(); SocketAddress endpoint = new InetSocketAddress("29.212.19.201", 2132); long timeMillis = System.currentTimeMillis(); try { socket.connect(endpoint, 10000); } catch (IOException e) { e.printStackTrace(); } System.out.println(System.currentTimeMillis()-timeMillis); System.out.println("end"); }
Exécutez ce code, aucune information n'est affichée sur la console avant 10 secondes, et les informations suivantes sont imprimées après 10 secondes :
10002 java.net.SocketTimeoutException: connect timed out at java.net.DualStackPlainSocketImpl.waitForConnect(Native Method) at java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketImpl.java:85) at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:172) at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) at java.net.Socket.connect(Socket.java:589) at com.wakling.cn.SocketSever.main(SocketSever.java:33) end
On peut voir que lorsque nous avons essayé de nous connecter à 29.212.19.201:2132, la connexion n'a pas réussi à se connecter pendant 10 secondes, donc une exception java.net.SocketTimeoutException: connect timed out a été signalée.
Expliquez que l'IP ci-dessus est une IP inconnue, c'est-à-dire que mon IP ne peut pas accéder à cette IP dans l'environnement réseau actuel, donc notre Socket continuera d'essayer de se connecter à cette IP jusqu'à expiration. Si l'adresse IP est une adresse IP connue, telle que 127.0.0.1 locale plus un port inconnu, cette connexion Socket signalera immédiatement une erreur.
De plus, si le délai d'expiration de connexion n'est pas défini, le délai d'expiration de connexion par défaut du Socket est d'environ 21 s (testé trois fois, toutes 21 020 millisecondes). Voici le code qui ne définit pas le délai d'expiration de la connexion :
Socket socket = new Socket("29.212.19.201", 2132);
La deuxième méthode
Jetons ensuite un œil à la deuxième méthode dont nous avons besoin à ce stade. Écrire un ensemble de services et de clients Socket pour simuler ce scénario.
Nous laissons le client définir setSoTimeout sur 10 s. Une fois que le code du serveur a obtenu les informations de la demande du client, il se met en veille pendant 10 s avant de traiter la demande du client et de renvoyer une réponse.
Jetons un coup d'œil à l'effet. Le code clé est le suivant :
//服务端 System.out.println("进入休眠,10s后醒来"); Thread.sleep(10000); System.out.println("休眠结束"); //返回响应 OutputStream outputStream = socket.getOutputStream();// 获取一个输出流,向服务端发送信息 PrintWriter printWriter = new PrintWriter(outputStream);// 将输出流包装成打印流 printWriter.print("你好,服务端已接收到您的信息"); printWriter.flush(); //客户端 Socket socket = new Socket("127.0.0.1",2132); socket.setSoTimeout(10000);//read的超时时间
Après l'exécution, attendez la sortie du client. Après 10 s, la console client affiche les informations suivantes : <🎜. >
java.net.SocketTimeoutException: Read timed out at java.net.SocketInputStream.socketRead0(Native Method) at java.net.SocketInputStream.socketRead(SocketInputStream.java:116) at java.net.SocketInputStream.read(SocketInputStream.java:171) at java.net.SocketInputStream.read(SocketInputStream.java:141) at sun.nio.cs.StreamDecoder.readBytes(StreamDecoder.java:284) at sun.nio.cs.StreamDecoder.implRead(StreamDecoder.java:326) at sun.nio.cs.StreamDecoder.read(StreamDecoder.java:178) at java.io.InputStreamReader.read(InputStreamReader.java:184) at java.io.BufferedReader.fill(BufferedReader.java:161) at java.io.BufferedReader.readLine(BufferedReader.java:324) at java.io.BufferedReader.readLine(BufferedReader.java:389) at com.wakling.cn.SocketClient.main(SocketClient.java:36) 10020 end
Tutoriel de base 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.

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

Spring Boot simplifie la création d'applications Java robustes, évolutives et prêtes à la production, révolutionnant le développement de Java. Son approche "Convention sur la configuration", inhérente à l'écosystème de ressort, minimise la configuration manuelle, allo
