本文主要是介绍core java detail,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
core java -- 概念篇
如果需要知道哪些unicode字符属于java中的 字母 ,可以使用Charactor类的javaIdentifierStart 和 javaIdentifierPart 方法进行检测
const 是java的保留字,但目前还没有使用
整数被0除 将会产生一个异常 而浮点数被0除得到无穷大或NaN
Strictfp —— Java 关键字。 (默认的方式不会产生溢出,严格的方式有可能产生溢出)
strictfp, 即
strict float point (精确浮点)。
strictfp 关键字可应用于类、接口或方法。使用 strictfp 关键字声明一个方法时,该方法中所有的float和double表达式都严格遵守FP-strict的限制,符合IEEE-754规范。当对一个类或接口使用 strictfp 关键字时,该类中的所有代码,包括嵌套类型中的初始设定值和代码,都将严格地进行计算。
public strictfp class MyClass
break 标签
标签必须放到最外层的循环之前 也可以用于if 等
大数值:
BigInteger.valueOf
BigDecimal
java 没有运算符重载功能
Arrays.sort() 优化后的快速排序
类库设计者将保存时间与给时间点命名分开。
标准类库里包含以下两个类:一是用来表示时间点的Date类,二是用来表示大家熟悉的日历表示法的GregorianCalendar类。
事实上GregorianCalendar类扩展了一个更加通用的Calendar类,此类描述了日历后般属性,理论上可以通过扩展Calendar类来实现中国的阴历来阳历,只是标准类库中只实现了Gregorian日历。
将时间 与 日历分开 是一种很好的面向对象设计。
Date.before()
.after()
new GregorianCalendar(2011, 9, 1); //9表示10月
java里有相当于 unix的make工具
javac EmpTest.java 里 如果发现运用到了 Emp.java ,就会自动查找名为Emp.class的文件,如果没有找到这个文件,就会自动搜索Emp.java关对其进行编译。
方法覆盖时,JDK5以前要求返回类型是一样的,JDK5以后允许子类将覆盖方法的返回类型定义为原返回类型的子类型
每次调用方法时都进行搜索的话会效率低,所以虚拟机预先为每个类创建一个方法表(method table) ,
在Object类中,clone方法被声明为protected,因此无法直接调用,,子类必须重新定义clone方法,并将它声明为public,这样才能让所有的方法克隆对象。
Cloneable接口是java提供的几个标记接口(tagging interface)之一。而标记接口没有方法,使用它的唯一目的是可以利用instanceof进行类型检查,
if (obj instanceof Cloneable)
在jdk5以前版本中,clone方法总是返回Object类型,而在jdk5 以后,允许克隆方法声明为public,。如果没有实现Cloneable接口,就会CloneNotSupportException异常
try
{
}
catch (SQLException e)
{
Throwable se = new ServletException("sdddddd ");
se.setCause(se);
throw se;
}
//当捕获到异常时,就可以使用Throwable e = se.getCause() 得到原始的异常
//如果一个方法中出现一个已检查异常,而不允许抛出它,那么包装技术就十分有用,我们可以捕获这个已检查异常, 并将它包装成运行时异常。
java -verbose:class
查看JVM加载类的细节情况
java -verbose:gc
查看JVM中垃圾回收器(Garbage Collector)的细节情况
这篇关于core java detail的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!