Java BIO NIO AIO

}

catch (Exception e) {

System.out.println(e);

}

}

if(selector != null)

try{

selector.close();

}catch (Exception e) {

e.printStackTrace();

}

}

public void stop() { start = false;}

private void handleInput(SelectionKey key) throws Exception{

if(key.isValid()) {

if(key.isAcceptable()) {

ServerSocketChannel channel = (ServerSocketChannel) key.channel();

SocketChannel socketChannel = channel.accept();

socketChannel.configureBlocking(false);

socketChannel.register(selector, SelectionKey.OP_READ);

}

if(key.isReadable()) {

SocketChannel socketChannel = (SocketChannel)key.channel();

//分配1M的buffer

ByteBuffer byteBuffer = ByteBuffer.allocate(1024);

int size = socketChannel.read(byteBuffer);

if(size > 0) {

//将缓冲区当前的limit设置为position=0,用于后续对缓冲区的读取操作

byteBuffer.flip();

byte[] bytes = new byte[byteBuffer.remaining()];

//复制到bytes中

byteBuffer.get(bytes);

String contents = new String(bytes, “UTF-8”);

System.out.println(“NIO服务收到消息:”+contents);

String expression = new String(bytes,“UTF-8”);

System.out.println(“服务器收到消息:” + expression);

doWrite(socketChannel, “收到信息,你好,我是NIO”);

}

else if(size < 0) {

key.cancel();

socketChannel.close();

}

}

}

}

private void doWrite(SocketChannel channel, String msg) {

try {

byte[] bytes = msg.getBytes();

ByteBuffer writebuffer = ByteBuffer.allocate(bytes.length);

writebuffer.put(bytes);

//postion,limit值的交换,用于输出buffer

writebuffer.flip();

channel.write(writebuffer);

}catch (Exception e) {

System.out.print(“[error]: NIOserver发送信息失败”);

e.printStackTrace();

}

}

}

NIO 客户端代码

提示

  1. 类Client用于启动NIO客户端,传输参数只有IP、PORT

  2. 类ClientHandle用于NIO客户端请求服务端以及处理服务端的数返回数据

NIO客户端启动类

package com.ruider.customerNIO;

/**

  • Created by mahede on 2018/11/21.

*/

public class Client {

private static final String IP_ADDRESS = “localhost”;

private static final int PORT = 1234;

private static ClientHandle clientHandle;

public static void start(){ start(IP_ADDRESS, PORT);}

private synchronized static void start(String host, int port) {

if(clientHandle != null) {

clientHandle.stop();

}

clientHandle = new ClientHandle(IP_ADDRESS, PORT);

new Thread(clientHandle, “Client”).start();

}

//向服务器发送消息

public static boolean sendMsg(String msg) throws Exception{

if(msg.equals(“q”)) return false;

clientHandle.sendMsg(msg);

return true;

}

}

客户端发送请求和处理返回数据类

package com.ruider.customerNIO;

import java.io.IOException;

import java.net.InetSocketAddress;

import java.nio.ByteBuffer;

import java.nio.channels.SelectionKey;

import java.nio.channels.Selector;

import java.nio.channels.SocketChannel;

import java.util.Iterator;

import java.util.Set;

/**

  • Created by mahede on 2018/11/21.

*/

public class ClientHandle implements Runnable {

private String ipAddress;

private int port;

private SocketChannel socketChannel;

private Selector selector;

private static boolean start;

public ClientHandle(String host, int port) {

try{

this.ipAddress = host;

this.port = port;

selector = Selector.open();

socketChannel = SocketChannel.open();

socketChannel.configureBlocking(false);

//socketChannel.connect(new InetSocketAddress(ipAddress, port));

//socketChannel.register(selector, SelectionKey.OP_CONNECT);

start = true;

System.out.println(“客户端启动”);

}catch (Exception e) {

System.out.println(“客户端启动失败”);

e.printStackTrace();

}

}

public static void stop() { start = false;}

public void sendMsg(String msg) throws Exception{

socketChannel.register(selector, SelectionKey.OP_READ);

doWrite(socketChannel, msg);

}

@Override

public void run() {

try{

doConnect();

}catch (Exception e){

e.printStackTrace();

System.exit(1);

}

while (start) {

try {

selector.select(1000);

Set selectionKeys = selector.selectedKeys();

Iterator it = selectionKeys.iterator();

SelectionKey key = null;

while (it.hasNext()) {

key = it.next();

it.remove();

try {

handleInput(key);

}

catch (Exception e) {

if(key != null){

key.cancel();

if(key.channel() != null){

key.channel().close();

}

}

}

}

} catch (Exception e) {

e.printStackTrace();

System.exit(1);

}

}

try{

if(selector != null) {

selector.close();

}

}

catch (Exception e) {

e.printStackTrace();

}

}

private void handleInput(SelectionKey key) {

if(key.isValid()) {

try{

SocketChannel socketChannel = (SocketChannel)key.channel();

if(key.isConnectable()){

if(socketChannel.finishConnect());

else System.exit(1);

}

if(key.isReadable()){

//创建ByteBuffer,并开辟一个1M的缓冲区

ByteBuffer buffer = ByteBuffer.allocate(1024);

//读取请求码流,返回读取到的字节数

int readBytes = socketChannel.read(buffer);

//读取到字节,对字节进行编解码

if(readBytes>0){

//将缓冲区当前的limit设置为position=0,用于后续对缓冲区的读取操作

buffer.flip();

//根据缓冲区可读字节数创建字节数组

byte[] bytes = new byte[buffer.remaining()];

//将缓冲区可读字节数组复制到新建的数组中

buffer.get(bytes);

String result = new String(bytes,“UTF-8”);

总结

一般像这样的大企业都有好几轮面试,所以自己一定要花点时间去收集整理一下公司的背景,公司的企业文化,俗话说「知己知彼百战不殆」,不要盲目的去面试,还有很多人关心怎么去跟HR谈薪资。

这边给大家一个建议,如果你的理想薪资是30K,你完全可以跟HR谈33~35K,而不是一下子就把自己的底牌暴露了出来,不过肯定不能说的这么直接,比如原来你的公司是25K,你可以跟HR讲原来的薪资是多少,你们这边能给到我的是多少?你说我这边希望可以有一个20%涨薪。

最后再说几句关于招聘平台的,总之,简历投递给公司之前,请确认下这家公司到底咋样,先去百度了解下,别被坑了,每个平台都有一些居心不良的广告党等着你上钩,千万别上当!!!

Java架构学习资料,学习技术内容包含有:Spring,Dubbo,MyBatis, RPC, 源码分析,高并发、高性能、分布式,性能优化,微服务 高级架构开发等等。

还有Java核心知识点+全套架构师学习资料和视频+一线大厂面试宝典+面试简历模板可以领取+阿里美团网易腾讯小米爱奇艺快手哔哩哔哩面试题+Spring源码合集+Java架构实战电子书。
在这里插入图片描述

有很多人关心怎么去跟HR谈薪资。

这边给大家一个建议,如果你的理想薪资是30K,你完全可以跟HR谈33~35K,而不是一下子就把自己的底牌暴露了出来,不过肯定不能说的这么直接,比如原来你的公司是25K,你可以跟HR讲原来的薪资是多少,你们这边能给到我的是多少?你说我这边希望可以有一个20%涨薪。

最后再说几句关于招聘平台的,总之,简历投递给公司之前,请确认下这家公司到底咋样,先去百度了解下,别被坑了,每个平台都有一些居心不良的广告党等着你上钩,千万别上当!!!

Java架构学习资料,学习技术内容包含有:Spring,Dubbo,MyBatis, RPC, 源码分析,高并发、高性能、分布式,性能优化,微服务 高级架构开发等等。

还有Java核心知识点+全套架构师学习资料和视频+一线大厂面试宝典+面试简历模板可以领取+阿里美团网易腾讯小米爱奇艺快手哔哩哔哩面试题+Spring源码合集+Java架构实战电子书。
[外链图片转存中…(img-QceJrEmM-1714123000549)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

  • 24
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值