传智播客学习笔记4.19
三层结构:
表示层
业务逻辑层
DAO层
数据库
异常的处理
e.printstacktrace();//无必要
throw new RuntimeException;
jsp页面会自动对错误进行捕获
catch(Exception e){
throw new RuntimeException("……",e);//同时输出e的错误信息
}
1/一定要抛出原来的异常
2、出错时注意检查是否有异常已经被捕获
String str = "aa" + "bb";
共出现3个对象
String str = "aa" + "bb" +"cc";
5个对象
反编译工具JAD
反编译工具jad简单用法
反编译工具jad简单用法
以下假设jad.exe在c:/java目录下
一、基本用法
Usage: jad [option(s)] <filename(s)>
直接输入类文件名,且支持通配符,如下所示。
c:/java/>jad example1.class
c:/java/>jad *.class
结果是将example1.class反编译为example1.jad。将example1.jad改为example1.java即得源文件。
二、Option -o
不提示,覆盖源文件
三、Option -s
c:/java/>jad -sjava example1.class
反编译结果以.java为扩展名。
四、Option -p
将反编译结果输出到屏幕
c:/java/>jad -p example1.class
将反编译结果重定向到文件
c:/java/>jad -p example1.class>example1.java
五、Option -d
指定反编译的输出文件目录
c:/java/>jad -o -dtest -sjava *.class
命令行选择的列表
-a - 用JVM字节格式来注解输出
-af - 同 -a,但是注解的时候用全名称
-clear - 清除所有的前缀
-b - 输出多于的括号 (e.g., if(a) { b(); }, default: no)
-d <dir> - 指定输出文件的文件目录
-dead -试图反编译代码的dead 部分(default: no)
-disass - 不用用字节码的方式反编译 (no JAVA source generated)
-f - 输出整个的名字,无论是类还是方法
-ff -输出类的成员在方法之前 (default: after methods)
-i - 输出所有的变量的缺省的最初值
-l<num> - 将strings分割成指定数目的块的字符 (default: no)
-lnc - 将输出文件用行号来注解 (default: no)
-nl - 分割strings用新行字符 newline character (default: no)
-nodos -不要去检查class文件是否以dos方式写 (CR before NL, default: check)
-nocast - 不要生成辅助文件
-nocode -不要生成方法的源代码
-noconv - 不要转换java的定义符 (default: do)
-noctor - 不允许空的构造器存在
-noinner -关掉对内部类的支持 (default: turn on)
-nolvt - 忽略局部变量的表信息
-nonlb - 不要输出一个新行在打开一个括号之前 (default: do)
-o - 无需确认直接覆盖输出 (default: no)
-p - 发送反编译代码到标准输出 STDOUT (e.g., for piping)
可以安装ECLIPSE的插件
JDBC连接:先开后关
prepareStatement
java.util.Date
java.sql.Date
数据库驱动的几种类型
第一类:JDBC-ODBC桥。
第二类:部分本地API部分Java的驱动程序。
第三类:JDBC网络纯Java驱动程序。
第四类:本地协议的纯 Java 驱动程序。
第三、四两类都是纯Java的驱动程序,因此,对于Java开发者来说,它们在性能、可移植性、功能等方面都有优势。
注册驱动
Class.forName(“com.mysql.jdbc.Driver”);
DriverManager.registerDriver(com.mysql.jdbc.Driver);
会造成DriverManager中产生两个一样的驱动,并会对具体的驱动类产生依赖。
事务
事务保证操作的ACID性
ACID:原子性--atomicity、一致性--consistency、隔离性--isolation、持久性--durability
mysql默认自动提交
connection.setAutoCommit(false)
commit;
rollback;
savepoint ;
rollback是自动完成
begin;
sql注入
PreparedStatement
1/没有注入问题
2、效率更高(多次执行的条件下)??
实验时,直接提交速度更快
带有属性的参数,需要用PreparedStatement (select * from user where name = ?)
ctrl+shift+f:格式化代码
java.sql.date从java.util.date中继承而来
王老师讲课很全面,涉及范围也很广。同时对课程中遇到问题的细节讲解也非常清楚。