扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
本篇内容介绍了“有哪些Java基础知识”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
创新互联10多年成都定制网站服务;为您提供网站建设,网站制作,网页设计及高端网站定制服务,成都定制网站及推广,对成都边坡防护网等多个领域拥有多年的营销推广经验的网站建设公司。
面向对象与面向过程的区别
首先面向过程和面向对象的语言没有具体的性能高下之分,要依据每种语言的设计来做参考。个人认为面向过程和面向对象的最大区别在于:面向过程的语言是结构化的,面向对象的语言是模块化的。模块化的代码比结构化的代码更易于维护,复用与扩展。
OracleJDK与OpenJDK的区别
OpenJDK是基于Sun捐赠的HotSpot的源代码开发的,是开源的。OracleJDK是Oracle对JDK商业化版本,由Oracle发布并维护,因此OracleJDK比OpenJDK更可靠。
Java与C++的异同
Java和C++都是基于面向对象的语言。
Java不提供指针来访问内存,C++运行指针访问内存。
垃圾回收机制。Java无需开发者手动释放内存,因为Java由垃圾回收机制自动回收内存;C++则需要开发者手动释放内存。因此Java在内存管理上相对C++更安全。
Java不支持多继承,而C++支持。
JVM、JDK和JRE的区别
JVM:(java virtual machine)是java虚拟机
JRE:(java runtime environment)是java运行时环境
JDK:(java development kit)是java开发工具包,不仅包含来jre和jvm,还提供来javac编译器和javadoc等其他开发所需工具
Java语言的特点
面向对象
平台无关性,也就是跨平台(依靠JVM)
垃圾回收机制(GC)
支持多线程
支持便捷的网络编程
编译和解释(JIT)
安全
面向对象的特征
面向对象的三大特征:封装、继承、多态。
封装:封装是隐藏对象属性和实现细节,只对外提供可访问或修改的接口的技术。封装的目的是为了简化编程和增加程序的安全性,使得使用者无需了解对象的具体实现细节。
继承:继承是在已存在的类上定义新的类的技术。在Java中,已存在的类被成为基类(父类),新的类叫派生类(子类)。子类拥有父类所有属性、方法。但是子类对父类中私有的方法或属性并不拥有,并不能访问和使用。继承的目的主要是为零代码的复用。
多态:多态指的是相同类型的对象,调用其相同的方法,参数也相同,但是它的表现形式也就是结果不同。多态的目的是为了程序的可扩展性和维护性。在java中可以使用继承和接口2大特性实现多态。
重载和重写的区别
个人认为重载和重写完全没有可比性,不知道为啥老有人喜欢拿图吗做笔记。
重载:重载是描述一个类中有多个方法名相同的方法,但是它们的参数、类型、返回值、参数顺序可能不同,表现形式也就不同。
重写:重写是描述子类对父类的某个方法的逻辑进行重新编写,但重写的只是方法的内容,方法名、参数、类型、顺序、返回值都不变的。
接口和抽象类的区别
接口需要被实现,而抽象类是需要被继承的。
接口里的方法都是公共抽象的,而抽象类几允许抽象也允许非抽象的方法(在JDK8中,接口被允许定义defalut方法,JDK9中还允许定义private私有方法)。
一个类允许实现多个接口,但只允许继承一个抽象父类。
接口是对类的规范,规范的是行为能力。而抽象类是对类的抽象,抽象的是逻辑。
Object类方法有哪些?
getClass
equals
hashCode
toString
wait
wait(long):让当前对象进入TIMED_WATING状态
wait(long,int):让当前对象进入TIMED_WATING状态
notify
notifyAll
clone
finalize
静态属性方法和成员属性方法区别
静态属性和方法属于类Class,而成员属性和方法属于实例化的对象。
静态方法只能使用静态方法和静态属性,不能使用成员属性和方法。因为静态属性和方法在对象还没有实例化的时候就存在类。
简单理解就是不允许一个已经在的事物使用一个不存在的事物。
子类属性与父类属性初始好顺序
无论如何,静态数据首先加载,所以先初始化父类静态变量和静态初始块(静态变量和静态初始块按源代码编写的顺序执行,普通初始化块和普通成员变量也是如此),再初始化子类静态变量和静态初始化块。
普通初始化块和普通成员变量优先于构造方法,所以接下来加载父类的普通初始化块和普通成员变量,再调用父类构造方法。
调用子类普通代码块,普通变量和构造方法。
自动拆箱和装箱
自动拆箱和装箱实际上是Java编译器的一个语法糖。
自动装箱是指:将基本数据类型转为对应的包装类对象的过程。
自动拆箱是指:将包装类型转为对应的基本数据类型。
自动装箱实际上是调用类包装类对象的valueof方法,如:Integer.valueof(1)
自动拆箱实际上是调用类包装类的xxxValue方法,如:Integer.intValue()
在自动装箱的时候,如果包装类允许缓存并且值在缓存的范围内,那么装箱生产的对象会被缓存到常量池中。
Integer、Byte、Short、Long、Character包装类型具有缓存池,而其他三种:Float、Double、Boolean不具有缓存池。
包装类的缓存池缓存范围基本都为:-128—— 127之间,除了Character的缓存范围为0——127。
String为什么不可变?
先说下我的看法:String是Java中最常使用的类没有之一,如果String时可变的,那么会发生非常多数不清的问题。如IP地址、人名、邮箱非常多的敏感数据。如果String时可变的,就会发生安全问题,且字符串常量池也就无从谈起了。
String时不可变的,那么它的本质上也是线程安全的。不可变类的缺点就是每个不同值需要创建一个对象。
String是用final修饰的,保证类String类不能被扩展。String内部的字段时用final修饰的,并且没有对外提供修改字段的方法。这也是为什么String不可变的原理。
final关键字的作用
被final修饰的类,不能被继承,并且这个类所有成员方法都为final,不能被重写。
被final修饰的属性变量,不能被修改。如果该变量是基本数据类型,那么其值在初始化后不能被修改。如果该变量是引用类型,那么该引用不能再指向其他对象。
被final修饰的方法不能被子类重写。
StringBuilder和StringBuffer区别
StringBuilder 和 StringBuffer 都是可变的字符串,但是StringBuilder线程不安全的。
StringBuffer是线程安全的。因此单线程情况下考虑使用StringBuilder,多线程考虑使用StringBuffer。
他们之间的关系就好比HashMap和HashTable的关系。
equals知识点
== 与 equals区别
==,如果是基本数据类型,比较的是值,如果是引用数据类型,比较的是对象的内存地址;equals比较的是对象的值。因此在java中比较2个对象的值是否相等使用equals,判断2个对象释放是一个对象,使用==。
hashCode方法返回:
equals方法重写要求
自反性:x.equals(x) == true 永远成立
非空性:x.equals(null) == false 永远成立
对称性:如果x.equals(y) == true,那y.equals(x) == true
传递性:如果x.equals(y) == tue,并且y.equals(z) == true,那么一定满足x.equals(z) == true
一致性:如果x.equals(y) == true,那么只要x和y的值不变,那么x.equals(y) == true 永远成立
为什么重写equals方法一定要重写hashcode方法?
在普通环境下(不涉及hash表),equals方法和hashcode方法一毛钱关系没有的,此时重写equals但不重写hashcode是没有关系的。但当使用map、set这些散列表时,它们会根据对象的hashcode来计算对象在散列表中的位置的。试想下,如果2个对象的值相等,但是由于它们是2个对象,hashcode却不相等。 那么即使放入map,set(map)仍会存在重复数据。
深拷贝和浅拷贝
深拷贝:拷贝所有的内容,除了基本数据类型变量复制一份,连引用类型变量也复制一份。
浅拷贝:复制基本数据类型变量,对于引用类型的变量,直接返回这个引用本身。
IO流分类
按照流的流向,分为:输入流和输出流。
按照操作单元,分为:字节流和字符流。
使用字节流还是字符流?
考虑通用性,应该使用字节流。如果只是文本文件的操作,可以使用字符流。
BigDecimal
BigDecimal时Java中表示大浮点数的类型。
在Java中,如果遇到浮点数的判断,可以使用BigDecimal来做计算,因为如果使用普通数据类型很可能会发生精度丢失的情况,这个时候的结果可能会出乎意料之外。
Java异常体系结构
在Java中,异常分为 Exception和Error,这2个类都继承自Throwable。
Exception: Exception异常是程序本身可以处理的。Exception 分为运行时异常(RuntimeException)和 非运行时异常(CheckedException)。
RuntimeException: RuntimeException(运行时异常)是在程序运行时可能会发生的异常,如NullPointException, 这类异常往往是不可预料的,编译器也不会要求你手动try catch或throws。
CheckedException: CheckedException(非运行时异常)是RuntimeException以外的异常,如IOException, 这类异常要求必须显示的try catch或throws , 如果不处理,那么编译就不会通过。
Error: Error错误是程序无法处理的,表示程序或JVM出现了很严重的,无法解决的问题。
Comparable和Comparator
Comparable: 自然排序接口。实现了它的类意味着就支持排序。
Comparator: 外部比较器。无需让需要排序的对象实现排序逻辑,而是根据Comparator定义的逻辑来排序。 Comparator相较于Comparable更加的灵活。
为什么要慎用 Arrays.asList()?
因为Arrays.asList这个方法返回的根本就不是我们期盼的ArrayList, 而是Arrays类内部实现的ArrayList,这个内部类只支持访问和set操作, 并不支持remove,add,clear等修改操作。
Java中引用的类型
Java中引用类型总共有四种: 强引用,软引用,弱引用,虚引用。
强引用(Strong Reference): Java程序中绝大部分都是强引用,一般使用new关键字创建的对象就是强引用。 只要强引用存在,强引用的对象就不会被回收,除非不可达(参考jvm部分)
软引用(Soft Reference): 软引用一般不会被回收,但是当堆内存不够的时候, 比如几乎快要发生OOM的时候,就会回收掉软引用对象。
弱引用(Weak Reference): 只要垃圾回收开始,就会回收掉弱引用的对象。
虚引用(Phantom Reference,又称幽灵引用): 和其他几种引用不同,虚引用不决定对象的生命周期, 它在任何时候都可能被回收掉。
“有哪些Java基础知识”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流