20155336 2016-2017-2《JAVA程序设计》第九周学习总结
教材学习内容总结
第十六章
- JDBC(Java DataBase Connectivity)即java数据库连接,是一种用于执行SQL语句的Java API是用于执行SQL的解决方案,开发人员使用JDBC的标准接口,数据库厂商则对接口进行操作,开发人员无需接触底层数据库驱动程序的差异性。
-
JDBC驱动的四种类型(按操作方式分类的):
- JDBC-ODBC Bridge Driver
- Native API Driver 提供原生链接库
- JDBC-Net Driver 将方法调用转换为特定的网络协议调用
- Native Protocal Driver
-
建立数据库的步骤:
- 注册Driver的操作对象
- 取得Connection操作对象
- 关闭connection操作对象
数据库操作相关的JDBC接口或类都位于java.sql包中。要连接数据库,可以向DriverManager取得Connection对象。Connection是数据库连接的代表对象,一个Connection对象就代表一个数据库连接。SQLException是在处理JDBC时经常遇到的一个异常对象,为数据库操作过程发生错误时的代表对象。
Connection是数据库连接的代表对象,接下来要执行SQL的话,必须取得java.sql.Statement对象,它是SQL语句的代表对象,可以使用Connection的createStatement()来创建Statement对象。
在使用Connection、Statement或ResultSet时,要将之关闭以释放相关资源。
Statement的executeQuery()方法则是用于SELECT等查询数据库的SQL,executeUpdate()会返回int结果,表示数据变动的笔数,executeQuery()会返回java.sql.ResultSet对象,代表查询的结果,查询的结果会是一笔一笔的数据。可以使用ResultSet的next()来移动至下一笔数据,它会返回 true 或 false表示是否有下一笔数据,接着可以使用getXXX()来取得数据。
如果有些操作只是SQL语句中某些参数会有所不同,其余的SQL子句皆相同,则可以使用java.sql.PreparedStatement。可以使用Connection的preparedStatement()方法创建好一个预编译(precompile)的SQL命令,其中参数会变动的部分,先指定“?”这个占位字符。等到需要真正指定参数执行时,再使用相对应的setInt()、setString()等方法,指定“?”处真正应该有的参数。
第十七章
-
运用反射
JAVA真正需要某个类时才会加载对应的.class文档,不是程序启动时就加载所有类。 通过Object的getClass()方法,或者.class常量取得每个对象对应的class对象,如果是基本类型,也可以使用对应的打包类加 上.TYPE取得Class对象。例如,Integer.TYPE可取得代表int的Class对象。 使用`class.forName()的方法来实现动态加载类。 java.lang.reflect.Method实例是方法的代表对象,可以使用invoke()方法来动态调用指定的方法。
-
了解类加载器(ClassLoader)
是指将.class文件中的二进制数据读入到内存中,将其放在运行时数据的方法区内,然后再堆区创建这个类的java.lang.Class对象,用 来封装类在方法区类的对象。 JVM将类加载过程分为三个步骤:装载(Load),链接(Link)和初始化(Initialize)链接又分为三个步骤。
第18章
-
自定义泛型
在定义泛型时,使用extends限定指定T实际类型时,必须是某类的子类。在定义泛型时,使用extends限定指定T实际类型时,必须是某类的子类。 共变性(Covariance):,B是A的子类,Node B可视为一种Node A ,称Node具有共变性。 通配字符“?”与extends限制T的类型,只能通过T声明的名称取得对象指定给Object,或将T声明的名称指定为null。
教材学习中的问题和解决过程
问题一:关于类加载器的知识,分为三个步骤,装在(Load)、链接(Link)和初始化(Initialize)链接又分为三个步骤。 但是不太了解之间的关系,是包含,还是分支类型的?
-
解决:百度查到了一张图片,解决了问题。
代码调试中的问题和解决过程
-
问题一:关于p511页的 MessageDAO.java范例
package cc.openhome;
import java.sql.*;
import java.util.*;
public class MessageDAO {
private String url;
private String user;
private String passwd; public MessageDAO(String url, String user, String passwd) {
this.url = url;
this.user = user;
this.passwd = passwd;
} public void add(Message message)//注释1 {
try(Connection conn = DriverManager.getConnection//注释2(url, user, passwd);
Statement statement = conn.createStatement())//注释3 {
String sql = String.format(
"INSERT INTO t_message(name, email, msg) VALUES ('%s', '%s', '%s')",
message.getName(), message.getEmail(), message.getMsg());
statement.executeUpdate(sql);//**注释4**
} catch(SQLException ex) {
throw new RuntimeException(ex);
}
} public List<Message> get() //注释5{
List<Message> messages = new ArrayList<>();
try(Connection conn = DriverManager.getConnection(url, user, passwd);
Statement statement = conn.createStatement()) {
ResultSet result =
statement.executeQuery("SELECT * FROM t_message");
while (result.next()) {
Message message = toMessage(result);
messages.add(message);
}
} catch(SQLException ex) {
throw new RuntimeException(ex);
}
return messages;
} private Message toMessage(ResultSet result) throws SQLException {
Message message = new Message();
message.setId(result.getLong(1));
message.setName(result.getString(2));
message.setEmail(result.getString(3));
message.setMsg(result.getString(4));
return message;
}
}最开始这段代码还存在一点问题,在自己编译的时候,对于一些函数的具体功能和语句存在问题。后来看了书上关于语法的具体讲解,对于代码的注释上有了了解。
1:注释1:这个方法会在数据库中下新增留言
2:注释2:取得Connection对象
3:注释3:建立Statements对象
4:注释4:执行SQL描述句
5:注释5:这个方法会从数据库中查询所有留言
其他(感悟、思考等,可选)
学习java的时间也有较长的一段时间了,渐渐的对于这种学习方式也有了适应,对于所学习到的知识也有了更深层次的理解和认识,对于java还是其他计算机语言的元知识和硬知识有了较为扎实的功底,但是对于这些语言的软知识还存在问题。所学到目前的知识还不能很好很高效的自己完成程序的设计和程序代码的书写。在一些语言的语法运用上也不是很熟练,总是会出现错误越改越多的情况。总之对于java语言的学习还是有很大的方面需要去提高。
评分标准(满分10分)
- 从0分加到10分为止
- 正确使用Markdown语法(加1分):
- 不使用Markdown不加分
- 有语法错误的不加分(链接打不开,表格不对,列表不正确...)
- 排版混乱的不加分
-
模板中的要素齐全(加1分)
- 缺少“教材学习中的问题和解决过程”的不加分
- 缺少“代码调试中的问题和解决过程”的不加分
- 代码托管不能打开的不加分
- 缺少“结对及互评”的不能打开的不加分
- 缺少“上周考试错题总结”的不能加分
- 缺少“进度条”的不能加分
- 缺少“参考资料”的不能加分
教材学习中的问题和解决过程, 一个问题加1分
代码调试中的问题和解决过程, 一个问题加1分
-
本周有效代码超过300分行的(加2分)
- 一周提交次数少于20次的不加分
6 其他加分: - 周五前发博客的加1分 - 感想,体会不假大空的加1分 - 排版精美的加一分 - 进度条中记录学习时间与改进情况的加1分 - 有动手写新代码的加1分 - 课后选择题有验证的加1分 - 代码Commit Message规范的加1分 - 错题学习深入的加1分 7 扣分: - 有抄袭的扣至0分 - 代码作弊的扣至0分
点评模板:
-
基于评分标准,我给本博客打分:10。得分情况如下:
- 正确使用Markdown语法
- 模板中的要素齐全
- 教材学习中的问题和解决过程, 一个问题加1分,一共俩
- 代码调试中的问题和解决过程, 一个问题加1分,一共俩
- 本周有效代码超过300分行的(加2分)
- 感想,体会不假大空的加1分
- 有动手写新代码的加1分
- 代码Commit Message规范的加1分
- 课后选择题有验证的加1分
就这10分,还是根本不够加的~~~
点评过的同学博客和代码
学习进度条
| 代码行数(新增/累积)| 博客量(新增/累积)|学习时间(新增/累积)|重要成长|
-------- | :----------------:|:----------------:|:---------------: |:-----:|
| 目标 | 5000行 | 30篇 | 400小时 | |
| 第一周 | 200/200 | 2/2 | 20/20 | |
| 第二周 | 300/500 | 2/4 | 18/38 | |
| 第三周 | 500/1000 | 3/7 | 22/60 | |
| 第四周 | 800/1300 | 4/9 | 30/90 | |
| 第五周 | 1800/2000 | 5/9 | 45/100 | |
| 第六周 | 2400/3000 | 6/10 | 60/100 | |
| 第七周 | 3100/4000 | 7/11 | 75/100 | |
| 第八周 | 3700/4500 | 8/12 | 90/110 | |
| 第九周 | 4300/5000 | 9/12 | 105/130 | |
计划学习时间:21小时
实际学习时间:15小时
改进情况: 有空多看看现代软件工程 课件 软件工程师能力自我评价表