Java-Java重点基础知识总结
2015-12-10 13:57
369 查看
1.Java历史:04年Java1.5 06年Java1.6 09年就卖给了Oracle公司 sun公司从此退出舞台 11年Oracle发布1.7 14年发布1.8 1.9很快就来了
2.Java的垃圾回收机制 这个比较复杂 以后会有一章来讲
3.Java的8大数据类型 byte short int long char double float Boolean
4.Java的位运算符
& | ~ ^ 这四个比较简单 与或非异或 与 只有同时为1才为1 或 有一个为1就为1 ~各位取反 包括符号位 异或 不同为1相同为0
<< >> >> 左移 右移 和无符号右移
首先你得了解数值在计算机内是如何存储的 是以补码的形式存储的 什么是补码?对于正数 都不变 负数的话就取反加1
左移 将这个数整体左移一定位数后 右边的用0补充
右移 以符号位补充
无符号右移 都是以0补充 所以才说无符号吗
这个就是比较复杂的事情了 负数还要在底层转来转去的很麻烦
另外 居然还有&& 和& 的区别 叫什么短路与和非短路与
什么意思呢 就是&都是会执行两边的判断语句 可是&&就不一样了 如果左边的为false 那么直接返回 不会再去判断右边的了
||和|也是同样的道理
5.关于Java函数差数的传递类型的区分 我这里再说一次 Java只有值传递 没有引用传递
无论是基本类型参数还是对象类型的传递
只是对象类型的传递有点特殊 它在方法里面可以改变对象的值 让人认为它是引用传递 其实不然
因为一个对象本身在方法栈里面存储的是这个类的引用 如果把它当做差数传递 也是会将这个值复制一份传过去 只是传过去的引用 如果你改变它 对象对应于的值也是会改变的
6.继承的多态 看一下下面的程序
public class Main extends Person {
public static void main(String[] args) {
Person p = new Main();
p.say();// 运行时会执行父类的say方法 这里是重载 它会执行父类的方法
// 因为编译没有错 运行的时候 发现他其实是个Main类 当然执行的是父类的方法
// p.test(); 这个方法会出错 因为p的编译类型是Person 并没有这个方法 所以在编译的时候回出错 这是很正常的
}
public void say() {
System.out.println("父类say");
}
public void test() {
System.out.println("父类的test");
}
}
class Person {
String message = "我是子类";
public void say() {
System.out.println("子类say");
}
}
上面的注解说的很明白
7.关于构造器的初始化的顺序
从父类到子类 从静态到普通代码块 再到构造函数 的顺序依次执行
并且静态代码块和静态变量 只有在类第一次加载的时候才会加载到堆内存中
2.Java的垃圾回收机制 这个比较复杂 以后会有一章来讲
3.Java的8大数据类型 byte short int long char double float Boolean
4.Java的位运算符
& | ~ ^ 这四个比较简单 与或非异或 与 只有同时为1才为1 或 有一个为1就为1 ~各位取反 包括符号位 异或 不同为1相同为0
<< >> >> 左移 右移 和无符号右移
首先你得了解数值在计算机内是如何存储的 是以补码的形式存储的 什么是补码?对于正数 都不变 负数的话就取反加1
左移 将这个数整体左移一定位数后 右边的用0补充
右移 以符号位补充
无符号右移 都是以0补充 所以才说无符号吗
这个就是比较复杂的事情了 负数还要在底层转来转去的很麻烦
另外 居然还有&& 和& 的区别 叫什么短路与和非短路与
什么意思呢 就是&都是会执行两边的判断语句 可是&&就不一样了 如果左边的为false 那么直接返回 不会再去判断右边的了
||和|也是同样的道理
5.关于Java函数差数的传递类型的区分 我这里再说一次 Java只有值传递 没有引用传递
无论是基本类型参数还是对象类型的传递
只是对象类型的传递有点特殊 它在方法里面可以改变对象的值 让人认为它是引用传递 其实不然
因为一个对象本身在方法栈里面存储的是这个类的引用 如果把它当做差数传递 也是会将这个值复制一份传过去 只是传过去的引用 如果你改变它 对象对应于的值也是会改变的
6.继承的多态 看一下下面的程序
public class Main extends Person {
public static void main(String[] args) {
Person p = new Main();
p.say();// 运行时会执行父类的say方法 这里是重载 它会执行父类的方法
// 因为编译没有错 运行的时候 发现他其实是个Main类 当然执行的是父类的方法
// p.test(); 这个方法会出错 因为p的编译类型是Person 并没有这个方法 所以在编译的时候回出错 这是很正常的
}
public void say() {
System.out.println("父类say");
}
public void test() {
System.out.println("父类的test");
}
}
class Person {
String message = "我是子类";
public void say() {
System.out.println("子类say");
}
}
上面的注解说的很明白
7.关于构造器的初始化的顺序
从父类到子类 从静态到普通代码块 再到构造函数 的顺序依次执行
并且静态代码块和静态变量 只有在类第一次加载的时候才会加载到堆内存中
相关文章推荐
- Eclipse问题解决方案,不断更新
- 深入分析JavaWeb Item13 -- jsp指令详解
- Ubuntu开发环境下安装Eclipse
- Ugly Number leetcode java
- 基于Struts2文件上传
- sikuli类、函数使用参考java doc
- JAVA 内部类 总结
- Eclipse中新建Android项目时修改默认选项
- java获取时间并加上2个小时,格式化输出
- 利用Java迭代器删除list中元素
- eclipse创建Servlet报错:提示:The import javax.servlet.Filter cannot be resolved 等
- Java从设计模式[本场比赛状态转换武器]状态分析(State)模式
- Intellij IDEA配置JDK
- Struts2框架的搭建以及架构总结
- js 在myeclipse中报错
- 工作的时候用到spring返回xml view查到此文章亲测可用
- Spring mvc 标签
- ubuntu下JDK环境变量的配置
- spring roo反向工程
- spring roo初体验