zoukankan      html  css  js  c++  java
  • Java高级技术点面试问题-IO相关面试问题

    java网络编译:

    • 基础知识:
      ①、ip地址和端口号:
      ip地址是用来识别网络中的一个实体,而这个实体可以理解为一个主机,而端口号则是用来区分具体的通讯程序的。
      ②、tcp / udp协议:
      tcp是一个可靠数据传输:http和ftp都是采用的它;而udp是一个无连接的协议。如qq聊天。
      ③、URL:统一资源定位器,指向了互联网的一个资源,下面看一下通过URL来获取数据示例:

      ④、InetAddress:这个是java中代表IP地址的类。

    • socket:
      ①、创建socket实例:

      ②、客户端连接:
              1、创建Socket对象:
              2、连接建立后,通过输出流向服务器端发送请求信息。
              3、通过输入流获取服务器响应的信息。
              4、关闭响应资源。
      其示例代码如下:

      ③、服务端连接:
             1、创建ServerSocket对象,绑定监听接口。
             2、通过accept()方法监听客户端请求。
             3、连接建立后,通过输入流读取客户端发送的请求信息。
             4、通过输出流向客户端发送信息。
             5、关闭相关资源。
      其示例代码如下:

      ④、总结:
             1、创建ServerSocket和Socket。
             2、打开连接到Socket的输入/输出流。
             3、按照协议对Socket进行读/写操作。
             4、关闭输入输出流、关闭Socket。

    阻塞IO:

    • java的I/O接口:
      ①、基于字节操作的I/O接口:
      ②、基于字符操作的I/O接口:
      ③、基于磁盘操作的I/O接口:
      ④、基于网络操作的I/O接口:
    • 阻塞IO的通信模型:

      也就是在调用read()是阻塞的,会一直等待有数据时才会返回,socket.accept()就是阻塞的,当接收到客服端的请求之后就会开启一个线程去处理客户端的请求,但是这个模型存在一些缺点:1是客服端很多的时候,会创建大量的处理线程,而且每个线程都会占用栈空间和CPU的时间,2是阻塞可能带来频繁的上下文切换,而大部份上下文切换可能是无意义的,也加得了CPU的负担。

    • 总结: 
      1、BIO数据在写入OutputStream或者从InputStream读取时都有可能会阻塞。
      2、当前一些需要大量HTTP长连接的情况。
      3、需要另一种新的I/O操作方式,也就是NIO。

    NIO:

    • 工作原理:

      其实它的工作原理很简单:有一个专门的线程来处理所有的IO事件,同时它又是事件驱动机制的,当事件到来的时候会触发,而不是同步的去监视事件,另外它有线程之间的通讯方式,线程之间是通过wait和notify进行通讯的,而且每一次上下文切换都是有意义的,这样就减少了无意义的切换,提高了CPU的使用率,那这种机制到底是怎么来实现的呢?

    • 通信模型:

      其实就是客服端与服务器端各自维护一个管理通道对象,也就是图中的Selector,它可以监测一个或多个Channel上的事件,如果服务端注册一个读事件,这个时候客服端给服务端发送了一些数据,NIO的服务端就会在Selector添加一个读事件,服务端的处理线程就会轮循的访问Selector,如果访问Selector有感兴趣的事件到达,那么就处理这个事件,如果没有感兴趣的事件到达,则一直会阻塞直到感兴趣的事件到达。

    • 实例:
      客户端:

      服务器端:

  • 相关阅读:
    21. Merge Two Sorted Lists
    496. Next Greater Element I
    (转载)深度学习的weight initialization
    Python collections模块
    Iterables vs. Iterators vs. Generators
    (转)iPhone开发关于UDID和UUID的一些理解
    uniqueIdentifier在ios7不支持后的替代方法
    Android——列表视图 ListView(一)Arrayadapter
    Android——对话框2(日期和时间对话框)
    Android——子线程操作主线程
  • 原文地址:https://www.cnblogs.com/webor2006/p/8998377.html
Copyright © 2011-2022 走看看