20165228 2017-2018-2 《Java程序设计》第9周学习总结

教材学习内容总结

  • URL类是java.net包中的一个重要的类,URL的实例封装着一个统一资源定位符(Uniform Resource Locator),使用URL创建对象的应用程序称作客户端程序
  • URL对象最基本的信息:协议、地址、资源
  • 创建一个URL对象
public URL(String spec) throws MalformedURLException
public URL(String protocol, String host,String file) throws MalformedURLException
  • 读取URL中的资源:

    URL对象调用
InputStream openStream()

返回一个输入流,该输入流指向URL对象所包含的资源

  • Internet上的主机的两种方式表示地址:域名、IP地址
  • 获取地址
    • Internet上主机的地址:

      1.InetAddress类的静态方法getByName(String s);

      2.获得一个InetAddress对象,该对象含有主机地址的域名和IP地址
    • 获取本地机的地址:通过InetAddress类的静态方法getLocalHost()
  • 套接字:IP地址标识Internet上的计算机,端口号标识正在计算机上运行的进程(程序)。端口号被规定为一个16位的0~65535之间的整数,端口号与IP地址的组合得出一个网络套接字。当两个程序需要通信时,它们可以通过使用Socket类建立套接字对象并连接在一起。
  • 建立连接到服务器的套接字对象:
    try{  Socket mysocket=new Socket(“http://192.168.0.78”,1880);
}
catch(IOException e) {
}
  • mysocket相关的方法

    • getInputStream()获得一个输入流
    • getOutputStream()获得一个输出流
    • 用getInputStream()得到的输入流接到另一个DataInputStream数据流上
    • 用getOutputStream()得到的输出流接到另一个DataOutputStream数据流上
  • 服务器必须建立一个ServerSocket对象,该对象通过将客户端的套接字对象和服务器端的一个套接字对象连接起来,从而达到连接的目的
 	  try{  ServerSocket  serverForClient =new ServerSocket(2010);
}
catch(IOException e){
}
  • accept()将客户的套接字和服务器端的套接字连接起来:

    ···

    try{ Socket sc= serverForClient .accept();

    }

    catch(IOException e){}

    ···
  • 接收客户的套接字连接:accept()方法会返回一个和客户端Socket对象相连接的Socket对象
  • 客户端的套接字获得的输入\输出流和服务器端的套接字获得的输出\输入流互相连接.
  • 使用Socket类不带参数的构造方法Socket()创建一个套接字对象,该对象需调用
public void connect(SocketAddress endpoint) throws IOException
  • 请求和参数SocketAddress指定地址的套接字建立连接
  • 为了使用connect方法,可以使用SocketAddress的子类InetSocketAddress创建一个对象,InetSocketAddress的构造方法是:
InetSocketAddress(InetAddress addr, int port)
  • 基于UDP通信的基本模式是:

    1.将数据打包,称为数据包(好比将信件装入信封一样),然后将数据包发往目的地。

    2.接受别人发来的数据包(好比接收信封一样),然后查看数据包中的内容。
  • 用DatagramPacket类创建一个对象,称为数据包
  • DatagramPacket的以下两个构造方法创建待发送的数据包:
DatagramPacket(byte data[],int length,InetAddtress address,int port)
DatagramPack(byte data[],int offset,int length,InetAddtress address,int port)
  • 用DatagramSocket类的不带参数的构造方法:DatagramSocket()创建一个对象,该对象负责发送数据包。
DatagramSocket  mail_out=new DatagramSocket();
mail_out.send(data_pack);
  • 接受数据包:

    • DatagramSocket的另一个构造方法DatagramSocket(int port) 创建一个对象,其中的参数必须和待接收的数据包的端口号相同
DatagramSocket mail_in=new DatagramSocket(端口号);
  • 然后对象mail_in使用方法receive(DatagramPacket pack)接受数据包。
  • 用 DatagramPack类的另外一个构造方法: DatagramPack(byte data[],int length)创建一个数据包,用于接收数据包
byte data[]=new byte[100];
int length=90;
DatagramPacket pack=new DatagramPacket(data,length);
mail_in.receive(pack);
  • 远程对象:

    驻留在(远程)服务器上的对象是客户要请求的对象,称作远程对象。
  • 代理的特点是它与远程对象实现了相同的接口。
  • 存根(Stub):一种特殊的字节码,并让这个存根产生的对象为作为远程对象的代理
  • Remote接口:RMI为了标识一个对象是远程对象,即可以被客户请求的对象,要求远程对象必须实现java.rmi包中的Remote接口

教材学习中的问题和解决过程

  • 问题1:基于UDP的通信和基于TCP的通信不同点是什么?
  • 问题1解决方案:基于UDP的信息传递更快,但不提供可靠性保证

代码调试中的问题和解决过程

  • 问题1:敲代码的时候出现了这样的差错,在没仔细看程序的情况下,没能根据错误提示排除原因
  • 问题1解决方案:仔细阅读代码后,发现这是一句输出语句,system中间误输了一个空格

代码托管

这周好像修改了部分之前的代码,所以算到这周的代码量了。实际上代码量为516

(statistics.sh脚本的运行结果截图)

上周考试错题总结

  • 错题1:对于下列程序,哪个叙述是正确的? A

    A.JVM认为这个应用程序共有两个线程。

    B.JVM认为这个应用程序只有一个主线程。

    C.JVM认为这个应用程序只有一个thread线程。

    D.程序有编译错误,无法运行。
  • 错题2:进程的基本状态有:新建、运行、阻塞、死亡。 A

    A.true

    B.false

其他(感悟、思考等,可选)

本周学习的知识让我认识到java不限于本地的应用,除了数据库外,还可以通过网络传输和接受数据包并且实现一些操作。

学习进度条

代码行数(新增/累积) 博客量(新增/累积) 学习时间(新增/累积) 重要成长
目标 5000行 25篇 400小时
第一周 235/235 1/1 15/15
第二周 224/459 2/3 15/30
第三周 443/902 1/4 15/73
第四周 577/1479 2/6 17/90
第五周 1222/2360 1/7 14/104
第六周 1527/3294 1/8 14/118
第七周 591/3883 1/9 14/132
第八周 1705/5158 1/10 12/144
第九周 516/5674 1/11 14/158

20165228 2017-2018-2 《Java程序设计》第9周学习总结的更多相关文章

  1. 学号 20175212 《Java程序设计》第九周学习总结

    学号 20175212 <Java程序设计>第九周学习总结 教材学习内容总结 一.MySQL数据库管理系统 1.在官网上下载并安装MySQL 2.在IDEA中输入测试代码Connectio ...

  2. 20145213《Java程序设计》第九周学习总结

    20145213<Java程序设计>第九周学习总结 教材学习总结 "五一"假期过得太快,就像龙卷风.没有一点点防备,就与Java博客撞个满怀.在这个普天同庆的节日里,根 ...

  3. 20145213《Java程序设计》第二周学习总结

    20145213<Java程序设计>第二周学习总结 教材学习内容总结 本周娄老师给的任务是学习教材的第三章--基础语法.其实我觉得还蛮轻松的,因为在翻开厚重的书本,一股熟悉的气息扑面而来, ...

  4. 20145213《Java程序设计》第一周学习总结

    20145213<Java程序设计>第一周学习总结 教材学习内容总结 期待了一个寒假,终于见识到了神秘的娄老师和他的Java课.虽说算不上金风玉露一相逢,没有胜却人间无数也是情理之中,但娄 ...

  5. 21045308刘昊阳 《Java程序设计》第九周学习总结

    21045308刘昊阳 <Java程序设计>第九周学习总结 教材学习内容总结 第16章 整合数据库 16.1 JDBC入门 16.1.1 JDBC简介 数据库本身是个独立运行的应用程序 撰 ...

  6. 20145330孙文馨 《Java程序设计》第一周学习总结

    20145330孙文馨 <Java程序设计>第一周学习总结 教材学习内容总结 刚开始拿到这么厚一本书说没有压力是不可能的,开始从头看觉得很陌生进入不了状态,就稍微会有一点焦虑的感觉.于是就 ...

  7. 20145337 《Java程序设计》第九周学习总结

    20145337 <Java程序设计>第九周学习总结 教材学习内容总结 数据库本身是个独立运行的应用程序 撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的增删查找 JDBC可以 ...

  8. 20145337 《Java程序设计》第二周学习总结

    20145337 <Java程序设计>第二周学习总结 教材学习内容总结 Java可分基本类型与类类型: 基本类型分整数(short.int.long).字节(byte).浮点数(float ...

  9. 20145218《Java程序设计》第一周学习总结

    20145218 <Java程序设计>第一周学习总结 教材学习内容总结 今天下午看了Java学习的视频,感觉很是新奇,之前觉得Java学起来是艰难枯燥的,但通过第一章的学习觉得如果自己可以 ...

  10. 《Java程序设计》第九周学习总结

    20145224 <Java程序设计>第九周学习总结 第十六章 整合数据库 JDBC入门 ·数据库本身是个独立运行的应用程序 ·撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的 ...

随机推荐

  1. MYSQL--三大范式

    MYSQL--三大范式 范式简介: 设计关系数据库时,遵从不同的规范要求,设计出合理的关系型数据库,这些不同的规范要求被称为不同的范式,各种范式呈递次规范,越高的范式数据库冗余越小.目前关系数据库有六 ...

  2. Hadoop---HDFS读写流程

    Hadoop---HDFS HDFS 性能详解 HDFS 天生是为大规模数据存储与计算服务的,而对大规模数据的处理目前还有没比较稳妥的解决方案. HDFS 将将要存储的大文件进行分割,分割到既定的存储 ...

  3. WebAPi获取请求头中对应键值

    /// <summary> /// 依据键获取请求头中值数据 /// </summary> /// <param name="request"> ...

  4. ActiveMQ 的连接和会话

    要了解 connection 和 session 的概念,可以先从 ConnectionState 和 SessionState 入手: // 省略部分代码 public class Connecti ...

  5. npm使用国内淘宝镜像的方法

    一.通过命令配置 1. 命令 npm config set registry https://registry.npm.taobao.org 2. 验证命令 npm config get regist ...

  6. Oracle常用表和常见操作命令

    一.说明 Oracle数据库数据库名.表名.字段名等不区分大小写,字段值区分大小写. Oracle单词之间一般用下划线连接:表名最后一般加s字段名最后一般没s. 二.常见数据表 dba_*DBA拥有的 ...

  7. JQuery操作input

    // 不可编辑 $("#id").attr("disabled","disabled"); $("#id").remov ...

  8. ubuntu下唤醒或休眠远程计算机

    ubuntu让我明白,没有什么完美的东西,要想完美必须付出代价.要么花时间折腾,要么花时间赚钱买系统. 人生也是一样,所以不要期待什么完美.哪有那么好的人,在合适的时间合适的地点让你遇见,还对你有感觉 ...

  9. ueditor自定义额外参数

    <script>ue.ready(function () { ue.setContent('123456');//设置富文本编辑器初始化数据 ue.execCommand('serverp ...

  10. QuickStart系列:docker部署之redis

    在centos7的docker中部署 redis,这里只介绍 单节点的部署. docker run -p 6379:6379 -v $PWD/data:/data -d redis:latest re ...