1.反射

  • Class类: 反射的外围类、能够获取类的属性,办法等信息
  • Field类: Java.lang.reflec包中的类,示意类的成员变量,能够用来获取和设置类之中的属性值
  • Method类:Java.lang.reflec包中的类,示意类的办法,能够用来获取类中的办法信息或者执行办法
  • Constructor类:Java.lang.reflec包中的类,示意类的构造方法
获取Class对象的3种办法:
//1Person p = new Person();Class clazz = p.getClass;//2Class clazz = Person.class;//3Class clazz = Class.forName("类的全门路");
创建对象的两种办法
  • 1.应用Class对象的newInstance(),这种办法须要Class对象对应的类有默认的空结构器
  • 2.调用Constructor对象的newInstance(),先通过Class对象获取结构器对象,再通过结构器对象的newInstance()创立

2.请阐明如何通过反射获取和设置对象公有字段的值?

通过类对象的getDeclaredField()办法获取字段对象,而后通过字段对象的setAccessible(true)将其设置为能够拜访,接下来就能够通过Class对象的getMethod办法获取get/set办法来获取/设置字段的值

3.BIO、NIO区别

BIO(Block IO): jkd1.4以前的IO模型,它是一种阻塞IO
NIO(NoN-Block IO):JDK1.4当前才有的IO模型,进步了程序的性能,借鉴比拟先进的设计思维,linux多路复用技术,轮询机制
AIO(Asynchronous IO):JDK1.7当前才有的IO模型,相当于NIO2,学习Linux epoll模式

linux epoll介绍:https://mp.weixin.qq.com/s/YU...

4.Java NIO的原理

  • 1.多路复用技术:建设连贯—发送数据—服务端解决—反馈
  • 2.轮询机制(Select模式)
  • 3.SelectionKey: 牌号,工夫的标识,惟一的身份标识
  • 4.Buffer(数据缓冲区)

Channel实现:FileChannel(文件IO)、DatagramChannel(UDP)、SocketChannel(Client)、ServerSocketChannel(Server)

//实例try(ServerSocketChannel serverSocketChannel = ServerSocketChannel.open()) {            serverSocketChannel.socket().bind(new InetSocketAddress(3388));            Selector selector = Selector.open();            serverSocketChannel.configureBlocking(false);            serverSocketChannel.register(selector, SelectionKey.OP_ACCEPT);            System.out.println("服务器准备就绪,开始监听,端口3388");            while (true) {                int wait = selector.select();                if (wait == 0)                    continue;                Set<SelectionKey> keys = selector.selectedKeys();                Iterator<SelectionKey> iterator = keys.iterator();                ByteBuffer byteBuffer = ByteBuffer.allocate(1024);                while (iterator.hasNext()) {                    SelectionKey key = iterator.next();                    if (key.isAcceptable()) {                        //do something                    } else if (key.isReadable()) {                        //do something                    } else if (key.isWritable()) {                        //do something                    }                    iterator.remove();                }            }        } catch (Exception e) {            e.printStackTrace();        }