Java IO示例代码

简介: public class BIOServer { public static void main(String[] args) { try { ServerSocket serverSocket = new ServerSocket(); InetSocketAddress address = new InetSocketAddress("127.

//BIO服务端
public class BIOServer {

public static void main(String[] args) {
    try {
        ServerSocket serverSocket = new ServerSocket();
        InetSocketAddress address = new InetSocketAddress("127.0.0.1", 9001);
        serverSocket.bind(address);
        while (true) {
            Socket socket = serverSocket.accept();
            new Thread(new Runnable() {
                @Override
                public void run() {
                    System.out.println(socket.getLocalAddress().getHostAddress() + "连接了");
                    InputStream inputStream = null;
                    try {
                        inputStream = socket.getInputStream();
                        InputStreamReader inputStreamReader = new InputStreamReader(inputStream);
                        BufferedReader reader = new BufferedReader(inputStreamReader);
                        String str = null;
                        str = reader.readLine();
                        System.out.println(str);
                    } catch (IOException e) {
                        e.printStackTrace();
                    }
                }
            }).start();
        }
    } catch (Exception e) {
        e.printStackTrace();
    }
}

}

//BIO客户端
public class BIOClient {

public static void main(String[] args) {
    try {
        Socket socket = new Socket("127.0.0.1", 9001);
        OutputStream outputStream = socket.getOutputStream();
        OutputStreamWriter outputStreamWriter = new OutputStreamWriter(outputStream);
        BufferedWriter writer = new BufferedWriter(outputStreamWriter);
        String str = "你好";
        writer.write(str);
        //刷新输入流
        writer.flush();
        //关闭socket的输出流
        socket.shutdownOutput();
    } catch (Exception e) {
        e.printStackTrace();
    }
}

}

//NIO服务端
public class NIOServer {

/**
 * 选择器
 */
private Selector selector;

/**
 * 通道
 */
ServerSocketChannel serverSocketChannel;

public void initServer(int port) throws IOException
{
    //打开一个通道
    serverSocketChannel = ServerSocketChannel.open();

    //通道设置非阻塞
    serverSocketChannel.configureBlocking(false);

    //绑定端口号
    serverSocketChannel.socket().bind(new InetSocketAddress("0.0.0.0", port));

    //注册
    this.selector = Selector.open();
    //先注册事件
    serverSocketChannel.register(selector, SelectionKey.OP_ACCEPT);
}

public void listen() throws IOException
{
    System.out.println("server started succeed!");

    while (true)
    {
        //阻塞到至少有一个就绪通道
        selector.select();
        Iterator<SelectionKey> ite = selector.selectedKeys().iterator();
        while (ite.hasNext())
        {
            SelectionKey key = ite.next();
            if (key.isAcceptable())
            {
                //接收新请求,并创建新通道
                SocketChannel channel = serverSocketChannel.accept();
                channel.configureBlocking(false);
                //通道注册可读事件
                channel.register(selector, SelectionKey.OP_READ);
            }
            else if (key.isReadable())
            {
                recvAndReply(key);
            }
            ite.remove();
        }
    }
}

public void recvAndReply(SelectionKey key)
{
    SocketChannel channel = (SocketChannel) key.channel();
    try {
        ByteBuffer buffer = ByteBuffer.allocate(256);
        int i = channel.read(buffer);
        if (i != -1) {
            String msg = new String(buffer.array()).trim();
            System.out.println(new Date() + ",NIO server received message =  " + msg);
            System.out.println(new Date() + ",NIO server reply =  " + msg);
            //通道写入数据
            channel.write(ByteBuffer.wrap(msg.getBytes()));
        } else {
            //多线程处理业务
            channel.close();
        }
    }catch (IOException e) {
        e.printStackTrace();
        try {
            channel.close();
        } catch (IOException ex) {
            ex.printStackTrace();
        }
    }
}

public static void main(String[] args) throws IOException
{
    NIOServer server = new NIOServer();
    server.initServer(8001);
    server.listen();
}

}

//NIO客户端
public class NIOClient {

/**
 * 通道
 */
SocketChannel channel;

public void initClient(String host, int port) throws IOException
{
    //构造socket连接
    InetSocketAddress servAddr = new InetSocketAddress(host, port);

    //通过通道,打开连接
    this.channel = SocketChannel.open(servAddr);
}

public void sendAndRecv(String words) throws IOException {
    byte[] msg = new String(words).getBytes();
    ByteBuffer buffer = ByteBuffer.wrap(msg);
    System.out.println(new Date() + ",Client sending: " + words);
    //通道写数据
    channel.write(buffer);
    buffer.clear();
    //阻塞,通道读数据
    channel.read(buffer);
    System.out.println(new Date() + ",Client received: " + new String(buffer.array()).trim());
}

public void close() throws IOException {
    channel.close();
}

public static void main(String[] args) throws IOException {
    NIOClient client = new NIOClient();
    try {
        client.initClient("localhost", 8001);
        Random random = new Random(10000000);
        while (true) {
            client.sendAndRecv(random.nextInt() + ",I am a client");
        }
    } catch (Exception e) {
        e.printStackTrace();
        client.close();
    }
}

}

相关文章
|
5月前
|
存储 Java
【IO面试题 四】、介绍一下Java的序列化与反序列化
Java的序列化与反序列化允许对象通过实现Serializable接口转换成字节序列并存储或传输,之后可以通过ObjectInputStream和ObjectOutputStream的方法将这些字节序列恢复成对象。
|
30天前
|
监控 Java API
探索Java NIO:究竟在哪些领域能大显身手?揭秘原理、应用场景与官方示例代码
Java NIO(New IO)自Java SE 1.4引入,提供比传统IO更高效、灵活的操作,支持非阻塞IO和选择器特性,适用于高并发、高吞吐量场景。NIO的核心概念包括通道(Channel)、缓冲区(Buffer)和选择器(Selector),能实现多路复用和异步操作。其应用场景涵盖网络通信、文件操作、进程间通信及数据库操作等。NIO的优势在于提高并发性和性能,简化编程;但学习成本较高,且与传统IO存在不兼容性。尽管如此,NIO在构建高性能框架如Netty、Mina和Jetty中仍广泛应用。
43 3
|
2月前
|
Java
java 中 IO 流
Java中的IO流是用于处理输入输出操作的机制,主要包括字节流和字符流两大类。字节流以8位字节为单位处理数据,如FileInputStream和FileOutputStream;字符流以16位Unicode字符为单位,如FileReader和FileWriter。这些流提供了读写文件、网络传输等基本功能。
64 9
|
3月前
|
存储 缓存 Java
java基础:IO流 理论与代码示例(详解、idea设置统一utf-8编码问题)
这篇文章详细介绍了Java中的IO流,包括字符与字节的概念、编码格式、File类的使用、IO流的分类和原理,以及通过代码示例展示了各种流的应用,如节点流、处理流、缓存流、转换流、对象流和随机访问文件流。同时,还探讨了IDEA中设置项目编码格式的方法,以及如何处理序列化和反序列化问题。
109 1
java基础:IO流 理论与代码示例(详解、idea设置统一utf-8编码问题)
|
4月前
|
安全 Java API
【Java面试题汇总】Java基础篇——String+集合+泛型+IO+异常+反射(2023版)
String常量池、String、StringBuffer、Stringbuilder有什么区别、List与Set的区别、ArrayList和LinkedList的区别、HashMap底层原理、ConcurrentHashMap、HashMap和Hashtable的区别、泛型擦除、ABA问题、IO多路复用、BIO、NIO、O、异常处理机制、反射
|
3月前
|
Java 数据处理 开发者
揭秘Java IO流:字节流与字符流的神秘面纱!
揭秘Java IO流:字节流与字符流的神秘面纱!
55 1
|
3月前
|
自然语言处理 Java 数据处理
Java IO流全解析:字节流和字符流的区别与联系!
Java IO流全解析:字节流和字符流的区别与联系!
131 1
|
4月前
|
Java 大数据 API
Java 流(Stream)、文件(File)和IO的区别
Java中的流(Stream)、文件(File)和输入/输出(I/O)是处理数据的关键概念。`File`类用于基本文件操作,如创建、删除和检查文件;流则提供了数据读写的抽象机制,适用于文件、内存和网络等多种数据源;I/O涵盖更广泛的输入输出操作,包括文件I/O、网络通信等,并支持异常处理和缓冲等功能。实际开发中,这三者常结合使用,以实现高效的数据处理。例如,`File`用于管理文件路径,`Stream`用于读写数据,I/O则处理复杂的输入输出需求。
284 12
|
3月前
|
Java
Java 中 IO 流的分类详解
【10月更文挑战第10天】不同类型的 IO 流具有不同的特点和适用场景,我们可以根据具体的需求选择合适的流来进行数据的输入和输出操作。在实际应用中,还可以通过组合使用多种流来实现更复杂的功能。
79 0
|
3月前
|
存储 Java 程序员
【Java】文件IO
【Java】文件IO
47 0

热门文章

最新文章