JAVA知识点总结一
1 Java中一个char类型可以存放一个汉字吗?为什么?
可以。因为JVM的最小单位是两个字节,而java中以unicode存放汉字了,unicode占用了两个字节。
2 Java中实现多线程的方法有几种?怎样实现同步?
实现多线程的方法有两种:1 扩展Thread类;2 实现Runnable接口
实现方法同步有两种:1 在方法前面加sychronized
2 在方法中调用wait()和notify()或者notifyall();
3 抽象类和接口
抽象类:至少有一个方法不完整的类叫抽象类.抽象类不能被实例化.继承该抽象类的类可以是抽象类,也可以是非抽象类.抽象类用语实现公用代码.
接口:纯粹的抽象类.他的所有方法都没有实现.抽象类用于概括共同行为.
一个类可以实现多个接口,但是只能扩展一个类.接口不能扩展其他类.
何时用抽象类?何时用接口?
当要定义行为模型时用接口,而当实现公共代码时用抽象类.
收获1:
在使用PreparedStatement类的时候。我需要给它set一个时间类型的变量。保存年月日。一直没有意识到这个问题。我只知道 PreparedStatement中的setDate(index.java.sql.Date),方法可以处理。只知道java.sql.Date是 java.util.Date的一个子类。保存数据库中一直是yyyy-MM-dd格式的日期。一直没太注意。现在想保存年月日时分秒了。才想到处理它。
但 是我怎么设置都是年月日。后来看看了jdk的源码,才知道这个date类只能保存年月日。又发现了一个 setTime(index,java.sql.Time)类,高兴了。这次可以了吧。但是还不行。结果只有;时分秒,而没有年月日。看源码才知道他也是 java。Util.Date的一个子类。只保存时分秒。
我郁闷了。难道没有一个保存完整日期的么。再看发现了一个。 setTimestamp(index,
java.sql.Timestamp),哦,这个java.sql.Timestamp应该可以的。不错。他果然支持。这次也顺便看了一眼 java.sql.Timestamp类的源码。不错。今天认识了一下这几个类。
收获2:
今天在写一个循环处理中发现了一个重大的习惯性错误:
代码如下:
for (int j = 0; j < itemList.size(); j++) {
ItemLoginForm item = (ItemLoginForm) itemList.get(j);
String name=form.getForm_id()+"_"+item.getItem_code();
if(request.getParameter(name)!=null)
item.setItem_value(request.getParameter(name));
else
itemList.remove(j); //这里应该是itemList.remove(j--);
}
想法很简单,就是想过滤一下集合。不满足条件的remove掉。但在测试中发现问题。某些元素不参加判断。郁闷了。看了好久才发现原来。List集合在对 他的元素进行处理的时候。执行remove操作。Size会自动减减。所有的元素前移。而变量j的值没有变,这样就错过了下一个元素。确实很难发现。如果 移除某个元素的时候,是j--,这样才能从下一个元素顺次进行。
这个错误使我也清楚地认识了许多细节的东西应该好好的理解,减少这种bug的发生。
1. jvm内部分为主工作区和线程工作区。主工作区是实例的所有线程共有,线程工作区是实例的每个线程专有的工作区,其中包括一些主工作区的一些实例字段数据的拷贝。
2. 服务器一般都有线程池,线程资源是可以重复利用的。你20xx个用户在线,不见得能又200个用户同时(或者说并发)访问。再说,只要对象不是太大,我宁愿用200个拷贝,也不想让用户在这个200个任务的队列里等待。
3. 两个DB之间的复制数据,每个DB各自使用自己的Sequane来生成id。复制数据时,如果DB中的外键是由DB维护的,则不会产生id冲突,如果外键是由外部程序维护的,则可能会产生错误!
4. 对于非static的类的数据成员来说,在该类产生的实例中都有一份,并且相互独立(修改后并不影响其他实例), 但static的数据成员则变成了每个类只有一份,即在该类产生的所有实例共享这一个数据成员, 该数据成员的改变会影响到其他的实例. 而static的方法则是让你不用创建对象及能调用这个方法.
5. ThreadLocal的作用就是将经常要用到的对象的引用放到属于线程自己的一个存储空间中,在该线程的执行过程中,可以通过类的静态的ThreadLocal来方便的获取到这个对象,而不用通过参数的形式传来传去。
第二篇:java知识总结
1、 对象的初始化
(1) 非静态对象的初始化
在创建对象时,对象所在类的所有数据成员会首先进行初始化。
基本类型:int型,初始化为0。如果为对象这些对象会按顺序初始化。
※在所有类成员初始化完成之后,才调用本类的构造方法创建对象。构造方法的作用就是初始化。
(2) 静态对象的初始化
程序中主类的静态变量会在main方法执行前初始化。不仅第一次创建对象时,类中的所有静态变量都初始化,并且第一次访问某类(注意此时未创建此类对象)的静态对象时,所有的静态变量也要按它们在类中的顺序初始化。
2、继承时,对象的初始化过程
(1) 主类的超类由高到低按顺序初始化静态成员,无论静态成员是否为private。
(2) 主类静态成员的初始化。
(3) 主类的超类由高到低进行默认构造方法的调用。注意,在调用每一个超类的默认构造方法前,先进行对此超类进行非静态对象的初始化。
(4) 主类非静态成员的初始化。
(5) 调用主类的构造方法。
3、 关于构造方法
(1) 类可以没有构造方法,但如果有多个构造方法,就应该要有默认的构造方法,否则在继承此类时,需要在子类中显式调用父类的某一个非默认的构造方法了。
(2) 在一个构造方法中,只能调用一次其他的构造方法,并且调用构造方法的语句必须是第一条语句。
4、有关public、private和protected
(1) 无public修饰的类,可以被其他类访问的条件是:
a.两个类在同一文件中b.两个类在同一文件夹中c.两个类在同一软件包中。
(2) protected:继承类和同一软件包的类可访问。
(3) 如果构造方法为private,那么在其他类中不能创建该类的对象。
5、 抽象类
(1) 抽象类不能创建对象。
(2) 如果一个类中一个方法为抽象方法,则这个类必须为abstract抽象类。
(3) 继承抽象类的类在类中必须实现抽象类中的抽象方法。
(4) 抽象类中可以有抽象方法,也可有非抽象方法。抽象方法不能为private。
(5) 间接继承抽象类的类可以不给出抽象方法的定义。
6、 final关键字
(1) 一个对象是常量,不代表不能转变对象的成员,仍可以其成员进行操作。
(2) 常量在使用前必须赋值,但除了在声明的同时初始化外,就只能在构造方法中初始化。
(3) final修饰的方法不能被重置(在子类中不能出现同名方法)。
(4) 如果声明一个类为final,则所有的方法均为final,无论其是否被final修饰,但数据成员可为final也可不是。
7、 接口interface (用implements来实现接口)
(1) 接口中的所有数据均为 static和final即静态常量。尽管可以不用这两个关键字修饰,但必须给常量赋初值。
(2) 接口中的方法均为public,在实现接口类中,实现方法必须可public关键字。
(3) 如果使用public来修饰接口,则接口必须与文件名相同。
8、 多重继承
(1) 一个类继承了一个类和接口,那么必须将类写在前面,接口写在后面,接口之间用逗号分隔。
(2) 接口之间可多重继承,注意使用关键字extends。
(3) 一个类虽只实现了一个接口,但不仅要实现这个接口的所有方法,还要实现这个接口继承的接口的方法,接口中的所有方法均须在类中实现。
9、 接口的嵌入
(1) 接口嵌入类中,可以使用private修饰。此时,接口只能在所在的类中实现,其他类不能访问。
(2) 嵌入接口中的接口一定要为public。
10、类的嵌入
(1) 类可以嵌入另一个类中,但不能嵌入接口中。
(2) 在静态方法或其他方法中,不能直接创建内部类对象,需通过手段来取得。 手段有两种:
class A {
class B {}
B getB() {
B b = new B();
return b;
}
}
static void m() {
A a = new A();
A.B ab = a.getB(); // 或者是 A.B ab = a.new B();
}
(3) 一个类继承了另一个类的内部类,因为超类是内部类,而内部类的构造方法不能自动被调用,这样就需要在子类的构造方法中明确的调用超类的构造方法。
接上例:
class C extends A.B {
C() {
new A().super(); // 这一句就实现了对内部类构造方法的调用。
}
}
构造方法也可这样写:
C(A a) {
a.super();
} // 使用这个构造方法创建对象,要写成C c = new C(a); a是A的对象。
11、异常类
JAVA中除了RunTimeException 类,其他异常均须捕获或抛出。