`
hm4123660
  • 浏览: 282387 次
  • 性别: Icon_minigender_1
  • 来自: 广州
博客专栏
Dea4ce76-f328-3ab2-b24a-fb268e1eeb75
数据结构
浏览量:69988
社区版块
存档分类
最新评论

java的Socket

    博客分类:
  • Java
阅读更多

 

        java API为我们网络通信提供了服务器套接字ServerSocket类和客户端套接字Socket,Socket是网络驱动层提供给应用程序编程的接口和一种机制。

下面提供具体实现例子

 

服务端--ServerSocket

     ServerSocket类实现了服务器的套接字,主要方法

ServerSocket(int port)-----创建绑定到特定端口的服务器套接字

void setSoTimeout(timeout);----指定超时时间

InetAdress getInetAddress()----返回此服务器套接字的本机地址

Socket accept()--------------侦听并接受此套接字的连接

 

示例代码:

package com;

import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;


public class Test {

	public static void main(String[] args) {
		
		try {
			ServerSocket server=new ServerSocket(8080);
			//等待客户端连接
			while(true){
			    Socket client=server.accept();
			    //每个客户端建立一个线程
			    new Thread(new myRunnable(client)).start();;
			}
			
		} catch (IOException e) {
			e.printStackTrace();
		}
	
	}
	
}

class myRunnable implements Runnable{
	
	private Socket socket;
	
	public myRunnable(Socket s)
	{
		this.socket=s;
	}
    //----run方法运行完毕,线程正常结束
	@Override
	public void run() {
        
		try {
			//接收客户端数据
			BufferedInputStream is=new BufferedInputStream(socket.getInputStream());			
			int data=is.read()+1;//把客户的数据加一
			
			Thread.sleep(1000);//休眠一秒
			//输出到客户端
			BufferedOutputStream os=new BufferedOutputStream(socket.getOutputStream());			
			os.write(data);//返回数据给客户端
			
			os.close();		
			os.close();
						
		} catch (IOException | InterruptedException e) {
			e.printStackTrace();
		}
		
		
	}
	
}

 

 

客户端----Socket

      Socket类实现客户端套接字,套接字是两台机器间通信的端点,主要方法有

 

Socket(String host,int port)----创建一个套接字将其连接到指定主机的指定端口号

InputStream getInputStream()----返回此套接字的输入流

OutputStream getOutputStream()----返回此套接字的输出流

 

示例代码:

 

package com;

import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.IOException;
import java.net.Socket;
import java.net.UnknownHostException;

public class Client {

	public static void main(String[] args) {

		for(int i=0;i<20;i++)
		{

			try {
				Socket socket = new Socket("localhost", 8080);
				//输出到服务器
				BufferedOutputStream os=new BufferedOutputStream(socket.getOutputStream());				
				os.write(i);			
				os.flush();
				//os.close();不能再这里关闭流,关闭流会导致socket也关闭

				// 构建字符缓冲流
				BufferedInputStream is=new BufferedInputStream(socket.getInputStream());
				
				int data=is.read();		
				is.close();
				
				os.close();
				
				System.out.println(data);			
			} catch (UnknownHostException e) {
				e.printStackTrace();
			} catch (IOException e) {
				e.printStackTrace();
			}
		}
		
	}

}

 

 主要不能提前关闭输入输出流,关闭输入输出流会导致Socket关闭


 

可以引起网络连接关闭的情况有以下4种:

 

1.直接调用Socket类的close方法。

 

2.只要Socket类的InputStream和OutputStream有一个关闭,网络连接自动关闭(必须通过调用InputStream和OutputStream的 close方法关闭流,才能使网络可爱接自动关闭)。

 

3.在程序退出时网络连接自动关闭。

4.将Socket对象设为null或未关闭最使用new Socket(…)建立新对象后,由JVM的垃圾回收器回收为Socket对象分配的内存空间后自动关闭网络连接。 

 

线程池

     在处理多个客户端时是为每一个连接创建一个线程,然而频繁的线程创建会影响性能,所以我们可以使用线程池来解决频线程的创建问题。

 

线程池:线程池是一种预先创建线程的一种技术。线程池在任务还没到来之前,创建一定数量的线程,放到空闲队列,然后对这些资源进行复用,减少频繁的线程创建和销毁。

 

        JDK1.5版本后提供了线程池,线程池的顶级接口是Executor,是一个执行工具,线程池的直接接口是ExecutorService,是并发开发中常用的工具类

 

      要配置一个线程池是比较复杂的,尤其是对于线程池的原理不是很清楚的情况下,很有可能配置的线程池不是较优的,因此在Executors类里面提供了一些静态工厂,生成一些常用的线程池。

 

1. newSingleThreadExecutor

 

创建一个单线程的线程池。这个线程池只有一个线程在工作,也就是相当于单线程串行执行所有任务。如果这个唯一的线程因为异常结束,那么会有一个新的线程来替代它。此线程池保证所有任务的执行顺序按照任务的提交顺序执行。

 

2. newFixedThreadPool

 

创建固定大小的线程池。每次提交一个任务就创建一个线程,直到线程达到线程池的最大大小。线程池的大小一旦达到最大值就会保持不变,如果某个线程因为执行异常而结束,那么线程池会补充一个新线程。

 

3. newCachedThreadPool

 

创建一个可缓存的线程池。如果线程池的大小超过了处理任务所需要的线程,

 

那么就会回收部分空闲(60秒不执行任务)的线程,当任务数增加时,此线程池又可以智能的添加新线程来处理任务。此线程池不会对线程池大小做限制,线程池大小完全依赖于操作系统(或者说JVM)能够创建的最大线程大小。

 

4. newScheduledThreadPool

创建一个大小无限的线程池。此线程池支持定时以及周期性执行任务的需求。

 

此时我们在服务器的用上线程池,使用newFixedThreadPool,代码改为

package com;

import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;


public class Test {

	public static void main(String[] args) {
		
		try {
			ServerSocket server=new ServerSocket(8080);
			//获取cpu数
			int cpu_Num=Runtime.getRuntime().availableProcessors();
			//创建指定大小的线程池
			ExecutorService es=Executors.newFixedThreadPool(cpu_Num);
			//等待客户端连接
			while(true){
			    Socket client=server.accept();
			    //每个客户端建立一个线程
			    //new Thread(new myRunnable(client)).start();
			    es.execute(new myRunnable(client));
			}
			
		} catch (IOException e) {
			e.printStackTrace();
		}
	
	}
	
}

class myRunnable implements Runnable{
	
	private Socket socket;
	
	public myRunnable(Socket s)
	{
		this.socket=s;
	}
    //----run方法运行完毕,线程正常结束
	@Override
	public void run() {
        
		try {
			//接收客户端数据
			BufferedInputStream is=new BufferedInputStream(socket.getInputStream());			
			int data=is.read()+1;//把客户的数据加一
			
			Thread.sleep(1000);//休眠一秒
			//输出到客户端
			BufferedOutputStream os=new BufferedOutputStream(socket.getOutputStream());			
			os.write(data);//返回数据给客户端
			
			os.close();		
			os.close();
						
		} catch (IOException | InterruptedException e) {
			e.printStackTrace();
		}
		
		
	}
	
}

 

 

    这样虽然现实了并发服务器,但这样的服务器效率低,吞吐量低,想提高服务器性能,可以研究学习java的nio和aio,能大大提升服务器性能。

    java nio资料地址:http://ifeve.com/overview/

 

 

  • 大小: 7.2 KB
4
0
分享到:
评论

相关推荐

    JAVA Socket 经典教程

    Java Socket是Java编程语言中实现网络通信的基础组件,它提供了应用程序与网络协议的接口,使得开发者可以构建基于TCP(传输控制协议)或UDP(用户数据报协议)的应用程序。本教程将深入探讨Java Socket编程的核心...

    java socket使用加密协议传输对象

    ### Java Socket 使用加密协议传输对象:深入解析与实践 在当今互联网时代,数据安全成为企业和个人用户关注的焦点。在Java开发中,Socket编程是一种常见的网络通信方式,它允许不同计算机上的应用程序通过网络进行...

    java socket 视频流转发socket

    Java Socket是Java编程语言中用于网络通信的核心API,它提供了低级别的、面向连接的、基于TCP/IP协议的网络通信能力。在"Java Socket 视频流转发Socket"这个主题中,我们将深入探讨如何使用Java Socket来处理视频流...

    java socket实现smtp发送邮件,支持SSL

    Java Socket 实现 SMTP 发送邮件是一项常见的编程任务,尤其在自动化通知、系统间通信或用户交互中非常有用。SMTP(Simple Mail Transfer Protocol)是互联网上用于传输电子邮件的标准协议,而Java Socket则是Java...

    Java Socket 聊天通信演示代码

    Java Socket 是一种网络通信协议,它是Java编程语言中实现客户端-服务器模型的基础。Socket 提供了低级别的、面向连接的、双向通信的网络接口,允许应用程序通过网络进行数据传输。在本示例中,我们将深入探讨Java ...

    JAVA Socket编程实现文件上传

    Java Socket编程是网络编程的基础,它提供了在两个应用程序之间建立通信连接的能力。在这个场景中,我们讨论的是如何使用Java的Socket来实现文件上传功能,即从客户端将文件发送到服务器,然后保存到服务器的数据库...

    Java Socket 实现SMTP邮件发送,支持SSL/TSL

    Java Socket编程是Java网络编程的基础,它提供了网络通信的能力,使得程序可以与其他计算机上的服务进行交互。在本案例中,我们将关注如何使用Java Socket来实现SMTP(Simple Mail Transfer Protocol)邮件发送,并...

    java socket连接池 实现

    Java Socket 连接池实现是提高网络应用性能和效率的关键技术之一。在高并发的网络环境中,频繁地创建和销毁Socket连接会导致大量的系统资源浪费,影响整体性能。为了解决这个问题,开发人员通常会使用连接池来管理和...

    java socket 客户端代码

    在Java编程语言中,Socket是实现网络通信的基础组件,它为两台计算机之间的通信提供了低级别的接口。在本文中,我们将深入探讨Java Socket客户端代码及其在创建基于Socket的聊天室客户端中的应用。 首先,理解...

    Java Socket网络编程.pdf

    Java Socket网络编程是Java平台中的核心特性,它为开发者提供了在TCP/IP协议下创建网络应用的能力。Socket编程主要用于实现客户端和服务器之间的通信,基于客户机/服务器模型。在这个模型中,服务器端通常处于被动...

    通过java socket实现屏幕网络监控

    Java Socket技术是网络编程中的重要组成部分,主要用于实现两个应用程序之间的通信。在这个场景中,我们讨论的是如何使用Java Socket来实现实时的屏幕监控功能,即服务端能够远程查看客户端的屏幕内容,这样的功能在...

    java socket 用户真实IP测试

    在Java网络编程中,Socket是实现客户端与服务器端通信的基础组件。当涉及到通过代理服务器或者负载均衡器(如Nginx)进行TCP转发时,获取用户的真实IP地址可能会变得复杂。在标题“java socket nginx tcp转发 用户...

    JAVA socket收发数据,并支持断网自动连接

    在Java编程中,Socket通信是网络应用程序之间进行双向通信的基础。Socket API提供了低级别的网络通信接口,使得开发者能够创建客户端和服务器之间的连接。本话题主要关注如何使用Java Socket实现数据的收发,并在...

    java socket客户端断线重连

    java socket client 断线重连的简单实现 有什么意见可以提哦

    Java Socket传输图片源代码

    在Java编程语言中,Socket是实现网络通信的基础组件。它提供了进程间通信(IPC)的能力,特别是在不同机器之间。在本示例中,我们将深入探讨如何使用Java Socket进行图片的传输,这对于理解网络编程和数据交换至关...

    java socket通信自定义消息协议

    Java Socket通信是网络编程中的基础部分,用于实现两个应用程序之间的双向通信。自定义消息协议是在标准TCP/IP协议之上,根据具体需求设计的一种数据传输格式。本篇将详细讲解如何在Java中实现基于Socket的自定义...

    java socket 经典版本

    Java Socket编程是网络编程的基础,它是Java API提供的一种用于实现客户端-服务器通信的接口。在Java中,Socket类和ServerSocket类是进行网络通信的核心组件。这个经典版本可能包含了一系列关于如何有效使用Java ...

    java socket 中文教程

    Java Socket是Java编程语言中用于网络通信的核心API,它提供了低级别的、面向连接的、基于TCP/IP协议的网络通信服务。本教程将深入探讨Java Socket的相关知识点,旨在帮助开发者理解和掌握如何在Java环境中构建网络...

    Java Socket PC端传输文件简易服务器客户端

    Java Socket编程是网络编程中的重要组成部分,主要用于在两台计算机之间建立双向通信通道,实现数据的交换。在Java中,Socket类和ServerSocket类是进行网络通信的核心工具,它们提供了客户端与服务器之间的连接和...

    基于java socket实现的ftp客户端和服务端交互

    本项目是使用java Socket编程实现的一个简单的FTP服务器和客户端。 客户端目前实现的功能是登录,刷新,上传和下载。同时具有主动模式和被动模式两种模式。 服务器端实现的功能有登录、刷新、上传、下载、列出文件...

Global site tag (gtag.js) - Google Analytics