笔试总结

本文详细介绍了HTTP状态码及其常见应用,包括200、301、302、403、404、500、503状态码的含义和用法。同时,深入讲解了TCP/IP模型和OSI模型的层次结构与功能,以及两种模型之间的映射关系。此外,还提供了Socket编程基础,包括客户端和服务器端的代码实现,帮助开发者快速上手网络编程。
摘要由CSDN通过智能技术生成

一,HTTP状态码常用的有哪些?

2开头的表示成功,主要是200,204,3开头的是重定向,主要是301,302,4开头的表示是客户端错误,主要是403,404,5开头表示服务器错误,主要是500,503

一、200状态码:
成功2××: 成功处理了请求的状态码。
1、200 :服务器已成功处理了请求并提供了请求的网页,服务器成功返回网页
2、204: 服务器成功处理了请求,但没有返回任何内容
二、300状态码:
重定向3×× :每次请求中使用重定向不要超过 5 次。
1、301: 请求的网页已永久移动到新位置。当URLs发生变化时,使用301代码。搜索引擎索引中保存新的URL。
2、302: 请求的网页临时移动到新位置。搜索引擎索引中保存原来的URL。
三、400状态码:
客户端错误4×× :表示请求可能出错,妨碍了服务器的处理。
1、403: 服务器拒绝请求
2、404: 请求页面不存在,服务器找不到请求的网页。服务器上不存在的网页经常会返回此代码。
四、500状态码:
服务器错误5×× :表示服务器在处理请求时发生内部错误。这些错误可能是服务器本身的错误,而不是请求出错。
1、500 :服务器内部遇到错误,无法完成请求。
2、503: 服务器目前无法使用(由于超载或停机维护)
状态参考:http://www.chaoji.com/features/httpstatus.aspx

http://tool.oschina.net/commons?type=5

二,细写TCP/IP模型和OSI模型,以及两种模型的参、层次映射

TCP/IP模型4层结构:应用层,传输层,网际层,网络接口层

应用层:负责实现一切与应用程序相关的功能,对应OSI参考模型的上三层,应用层,表示层,会话层。

协议:FTP(文件传输协议)
           HTTP(超文本传输协议)
           DNS(域名服务器协议)
           SMTP(简单邮件传输协议)

传输层:负责提供可靠的传输服务,它提供了节点间的数据传送服务,对应OSI参考模型的第四层,传输层

协议:TCP(控制传输协议)
           UDP(用户数据报协议)

网际层:负责网络间的寻址、数据传输,对应OSI参考模型的第三层,网络层

协议:IP(网际协议)
           ICMP(网际控制消息协议)
          ARP(地址解析协议)
          RARP(反向地址解析协议)

网络接口层:负责实际数据的传输,对应OSI参考模型的下两层,数据链路层和物理层

协议:PPP(点对点协议)

OSI模型的7层结构:应用层,表示层,会话层,传输层,网络层,数据链路层,物理层

应用层:提供应用程序访问OSI环境的手段,有:HTTP,HTTPS,FTP,TELNET,SSH,SMTP,POP3等。

表示层:这一层根据不同的应用目的将数据处理为不同的格式,表现出来就是我们看到的各种各样的文件扩展名。 数据的压缩、解压,加密、解密都发生在这一层

会话层:负责建立、维护、控制会话,区分不同的会话,以及提供单工(Simplex)、半双工(Half duplex)、全双工(Full duplex)三种通信模式的服务。我们平时所知的NFS,RPC,Windows等都工作在这一层

传输层:负责分割、组合数据,实现端到端的逻辑连接,TCP,UDP

网络层:负责管理网络地址,定位设备,决定路由。我们所熟知的IP地址和路由器就是工作在这一层。上层的数据段在这一层被分割,封装后叫做包(Packet),包有两种,一种叫做用户数据包(Data packets),是上层传下来的用户数据;另一种叫路由更新包(Route update packets),是直接由路由器发出来的,用来和其他路由器进行路由信息的交换。

数据链路层:负责准备物理传输,CRC校验,错误通知,网络拓扑,流控等。我们所熟知的MAC地址和交换机都工作在这一层。上层传下来的包在这一层被分割封装后叫做帧(Frame)

物理层:就是实实在在的物理链路,负责将数据以比特流的方式发送、接收



三,Socket编程,分别写出客户端和服务器端代码

客户端:

import java.io.*;
  import java.net.*;
  public class TalkClient {
    public static void main(String args[]) {
      try{
        Socket socket=new Socket("127.0.0.1",10000);
        //向本机的10000端口发出客户请求
        BufferedReader sin=new BufferedReader(new InputStreamReader(System.in));
        //由系统标准输入设备构造BufferedReader对象
        PrintWriter os=new PrintWriter(socket.getOutputStream());
        //由Socket对象得到输出流,并构造PrintWriter对象
        BufferedReader is=new BufferedReader(new InputStreamReader(socket.getInputStream()));
        //由Socket对象得到输入流,并构造相应的BufferedReader对象
        String readline;
        readline=sin.readLine(); //从系统标准输入读入一字符串
        while(!readline.equals("bye")){
        //若从标准输入读入的字符串为 "bye"则停止循环
          os.println(readline);
          //将从系统标准输入读入的字符串输出到Server
          os.flush();
          //刷新输出流,使Server马上收到该字符串
          System.out.println("Client:"+readline);
          //在系统标准输出上打印读入的字符串
          System.out.println("Server:"+is.readLine());
          //从Server读入一字符串,并打印到标准输出上
          readline=sin.readLine(); //从系统标准输入读入一字符串

        } //继续循环
        os.close(); //关闭Socket输出流
        is.close(); //关闭Socket输入流
        socket.close(); //关闭Socket
      }catch(Exception e) {
        System.out.println("Error"+e); //出错,则打印出错信息
      }
  }
}
服务器端:

import java.io.*;
  import java.net.*;
  import java.applet.Applet;
  public class TalkServer{
    public static void main(String args[]) {
      try{
       ServerSocket server=null;
        try{
          server=new ServerSocket(4700);
        //创建一个ServerSocket在端口4700监听客户请求
        }catch(Exception e) {
          System.out.println("can not listen to:"+e);        //出错,打印出错信息
        }
        Socket socket=null;
        try{
          socket=server.accept();
          //使用accept()阻塞等待客户请求,有客户
          //请求到来则产生一个Socket对象,并继续执行
        }catch(Exception e) {
          System.out.println("Error."+e);
          //出错,打印出错信息
        }

        String line;
        BufferedReader is=new BufferedReader(new InputStreamReader(socket.getInputStream()));
         //由Socket对象得到输入流,并构造相应的BufferedReader对象
        PrintWriter os=newPrintWriter(socket.getOutputStream());
         //由Socket对象得到输出流,并构造PrintWriter对象
       BufferedReader sin=new BufferedReader(new InputStreamReader(System.in));
         //由系统标准输入设备构造BufferedReader对象
        System.out.println("Client:"+is.readLine());
        //在标准输出上打印从客户端读入的字符串
        line=sin.readLine();
        //从标准输入读入一字符串
       while(!line.equals("bye")){
        //如果该字符串为 "bye",则停止循环
          os.println(line);
          //向客户端输出该字符串
          os.flush();
          //刷新输出流,使Client马上收到该字符串
          System.out.println("Server:"+line);
          //在系统标准输出上打印读入的字符串
         System.out.println("Client:"+is.readLine());
          //从Client读入一字符串,并打印到标准输出上
          line=sin.readLine();
          //从系统标准输入读入一字符串
        }  //继续循环
        os.close(); //关闭Socket输出流
        is.close(); //关闭Socket输入流
        socket.close(); //关闭Socket
        server.close(); //关闭ServerSocket
      }catch(Exception e){
        System.out.println("Error:"+e);
        //出错,打印出错信息
      }
    }
  }

四,堆和栈的区别

堆:

1,存储的都是对象,每个对象都包含一个对应的class信息

2,JVM只有一个堆被所有的线程共享,堆中不存放基本类型和对象引用,只存放对象本身

栈:

1,每个线程都包含一个栈,栈中只保存基础数据和对象的引用。

2,每个栈中的数据都是私有的,其他栈不能方法

3,分为三个部分:基本变量区,执行上下文,操作指令区



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值