- Java语言具备哪些特点?
- 面向对象的三大个性?
- 字节序定义以及Java属于哪种字节序?
- JDK与JRE有什么区别?
- 简述Java拜访修饰符
- 构造方法、成员变量初始化以及动态成员变量三者的初始化程序?
- 接口和抽象类的相同点和区别?
- 为什么Java语言不反对多重继承?
- Java提供的多态机制?
- 重载与笼罩的区别?
- final、finally和finalize的区别是什么?
- 呈现在Java程序中的finally代码块是否肯定会执行?
- Java语言中关键字static的作用是什么?
- Java代码块执行程序
- Java中一维数组和二维数组的申明形式?
- String和StringBuffer有什么区别?
- 判等运算符==与equals的区别?
- 为什么要把String设计为不变量?
- 序列化是什么?
- 简述Java中Class对象
- Java反射机制是什么?
- 简述注解
- 简述元注解
- 简述Java异样的分类
- 简述throw与throws的区别
- 简述泛型
- 简述泛型擦除
- 简述Java根本数据类型
- 简述主动装箱拆箱
- 简述重载与重写的区别
- 简述java的多态
- 简述抽象类与接口的区别
- 简述==与equals办法的区别
- 简述Object类罕用办法
- 简述外部类及其作用
- 简述String/StringBuffer与StringBuilder
- 简述Java序列化与反序列化的实现
- 简述JAVA的List
- Java中线程平安的根本数据结构有哪些
- 简述JAVA的Set
- 简述JAVA的HashMap
- 为何HashMap线程不平安
- 简述java的TreeMap
- Collection和Collections有什么区别?
- ArrayList、Vector和LinkedList有什么共同点与区别?
- HashMap和Hashtable有什么区别?
- 如何决定应用HashMap还是TreeMap?
- fail-fast和fail-safe迭代器的区别是什么?
- HashSet中,equals与hashCode之间的关系?
背之前先来看看阿里巴巴的常问Java根底你们会几个?
Java语言具备哪些特点?
- Java为纯面向对象的语言。它可能间接反馈现实生活中的对象。
- 具备平台无关性。java利用Java虚拟机来源gao*daima.com搞@代#码网运行字节码,无论是在Windows、Linux还是MacOS等其它平台对Java程序进行编译,编译后的程序可在其它平台运行。
- Java为解释型语言,编译器把Java代码编译成平台无关的中间代码,而后在JVM上解释运行,具备很好的可移植性。
- Java提供了很多内置类库。如对多线程反对,对网络通信反对,最重要的一点是提供了垃圾回收器。
- Java具备较好的安全性和健壮性。Java提供了异样解决和垃圾回收机制,去除了C++中难以了解的指针个性。
- Java语言提供了对Web利用开发的反对。
面向对象的三大个性?
- 继承:对象的一个新类能够从现有的类中派生,派生类能够从它的基类那继承办法和实例变量,且派生类能够批改或新增新的办法使之更适宜非凡的需要。
- 封装:将客观事物形象成类,每个类能够把本身数据和办法只让可信的类或对象操作,对不可信的进行信息暗藏。
- 多态:容许不同类的对象对同一音讯作出响应。不同对象调用雷同办法即便参数也雷同,最终体现行为是不一样的。
字节序定义以及Java属于哪种字节序?
字节序是指多字节数据在计算机内存中存储或网络传输时个字节的存储程序。通常由小端和大端两组形式。
- 小端:低位字节寄存在内存的低地址端,高位字节寄存在内存的高地址端。
- 大端:高位字节寄存在内存的低地址端,低位字节寄存在内存的高地址端。
Java语言的字节序是大端。
JDK与JRE有什么区别?
- JDK:Java开发工具包(Java Development Kit),提供了Java的开发环境和运行环境。
- JRE:Java运行环境(Java Runtime Environment),提供了Java运行所需的环境。
JDK蕴含了JRE。如果只运行Java程序,装置JRE即可。要编写Java程序需装置JDK.
简述Java拜访修饰符
- default: 默认拜访修饰符,在同一包内可见
- private: 在同一类内可见,不能润饰类
- protected : 对同一包内的类和所有子类可见,不能润饰类
- public: 对所有类可见
构造方法、成员变量初始化以及动态成员变量三者的初始化程序?
先后顺序:动态成员变量、成员变量、构造方法。
具体的先后顺序:父类动态变量、父类动态代码块、子类动态变量、子类动态代码块、父类非动态变量、父类非动态代码块、父类构造函数、子类非动态变量、子类非动态代码块、子类构造函数。
接口和抽象类的相同点和区别?
相同点:
- 都不能被实例化。
- 接口的实现类或抽象类的子类需实现接口或抽象类中相应的办法能力被实例化。
不同点:
- 接口只能有办法定义,不能有办法的实现,而抽象类能够有办法的定义与实现。
- 实现接口的关键字为implements,继承抽象类的关键字为extends。一个类能够实现多个接口,只能继承一个抽象类。
- 当子类和父类之间存在逻辑上的层次结构,举荐应用抽象类,有利于性能的累积。当性能不须要,心愿反对差异较大的两个或更多对象间的特定交互行为,举荐应用接口。应用接口能升高软件系统的耦合度,便于日后保护或增加删除办法。
为什么Java语言不反对多重继承?
- 为了程序的构造可能更加清晰从而便于保护。假如Java语言反对多重继承,类C继承自类A和类B,如果类A和B都有自定义的成员办法f(),那么当代码中调用类C的f()会产生二义性。Java语言通过实现多个接口间接反对多重继承,接口因为只蕴含办法定义,不能有办法的实现,类C继承接口A与接口B时即便它们都有办法f(),也不能间接调用办法,需实现具体的f()办法能力调用,不会产生二义性。
- 多重继承会使类型转换、构造方法的调用程序变得复杂,会影响到性能。
Java提供的多态机制?
Java提供了两种用于多态的机制,别离是重载与笼罩。
- 重载:重载是指同一个类中有多个同名的办法,但这些办法有不同的参数,在编译期间就能够确定调用哪个办法。
- 笼罩:笼罩是指派生类重写基类的办法,应用基类指向其子类的实例对象,或接口的援用变量指向其实现类的实例对象,在程序调用的运行期依据援用变量所指的具体实例对象调用正在运行的那个对象的办法,即须要到运行期能力确定调用哪个办法。
重载与笼罩的区别?
- 笼罩是父类与子类之间的关系,是垂直关系;重载是同一类中办法之间的关系,是程度关系。
- 笼罩只能由一个办法或一对办法产生关系;重载是多个办法之间的关系。
- 笼罩要求参数列表雷同;重载要求参数列表不同。
- 笼罩中,调用办法体是依据对象的类型来决定的,而重载是依据调用时实参表与形参表来对应抉择办法体。
- 重载办法能够扭转返回值的类型,笼罩办法不能扭转返回值的类型。
final、finally和finalize的区别是什么?
- final用于申明属性、办法和类,别离示意属性不可变、办法不可笼罩、类不可继承。
- finally作为异样解决的一部分,只能在try/catch语句中应用,finally附带一个语句块用来示意这个语句最终肯定被执行,常常被用在须要开释资源的状况下。
- finalize是Object类的一个办法,在垃圾收集器执行的时候会调用被回收对象的finalize()办法。当垃圾回收器筹备好开释对象占用空间时,首先会调用finalize()办法,并在下一次垃圾回收动作产生时真正回收对象占用的内存。
呈现在Java程序中的finally代码块是否肯定会执行?
当遇到上面状况不会执行。
- 当程序在进入try语句块之前就出现异常时会间接完结。
- 当程序在try块中强制退出时,如应用System.exit(0),也不会执行finally块中的代码。
其它状况下,在try/catch/finally语句执行的时候,try块先执行,当有异样产生,catch和finally进行解决后程序就完结了,当没有异样产生,在执行完finally中的代码后,前面代码会继续执行。值得注意的是,当try/catch语句块中有return时,finally语句块中的代码会在return之前执行。如果try/catch/finally块中都有return语句,finally块中的return语句会笼罩try/catch模块中的return语句。
Java语言中关键字static的作用是什么?
static的次要作用有两个:
- 为某种特定数据类型或对象调配与创建对象个数无关的繁多的存储空间。
- 使得某个办法或属性与类而不是对象关联在一起,即在不创建对象的状况下可通过类间接调用办法或应用类的属性。
具体而言static又可分为4种应用形式:
- 润饰成员变量。用static关键字润饰的动态变量在内存中只有一个正本。只有动态变量所在的类被加载,这个动态变量就会被调配空间,能够应用”类.动态变量”和”对象.动态变量”的办法应用。
- 润饰成员办法。static润饰的办法无需创建对象就能够被调用。static办法中不能应用this和super关键字,不能调用非static办法,只能拜访所属类的动态成员变量和动态成员办法。
- 润饰代码块。JVM在加载类的时候会执行static代码块。static代码块罕用于初始化动态变量。static代码块只会被执行一次。
- 润饰外部类。static外部类能够不依赖外部类实例对象而被实例化。动态外部类不能与外部类有雷同的名字,不能拜访一般成员变量,只能拜访外部类中的动态成员和动态成员办法。
Java代码块执行程序
- 父类动态代码块(只执行一次)
- 子类动态代码块(只执行一次)
- 父类结构代码块
- 父类构造函数
- 子类结构代码块
- 子类构造函数
- 一般代码块
Java中一维数组和二维数组的申明形式?
一维数组的申明形式:
- type arrayName[]
- type[] arrayName
二维数组的申明形式:
- type arrayName[][]
- type[][] arrayName
- type[] arrayName[]
其中type为根本数据类型或类,arrayName为数组名字
String和StringBuffer有什么区别?
String用于字符串操作,属于不可变类。String对象一旦被创立,其值将不能被扭转。而StringBuffer是可变类,当对象创立后,依然能够对其值进行批改。
判等运算符==与equals的区别?
== 比拟的是援用,equals比拟的是内容。
- 如果变量是根底数据类型,== 用于比拟其对应值是否相等。如果变量指向的是对象,== 用于比拟两个对象是否指向同一块存储空间。
equals是Object类提供的办法之一,每个Java类都继承自Object类,所以每个对象都具备equals这个办法。Object类中定义的equals办法外部是间接调用 == 比拟对象的。但通过笼罩的办法能够让它不是比拟援用而是比拟数据内容。
为什么要把String设计为不变量?
- 节俭空间:字符串常量存储在JVM的字符串池中能够被用户共享。
- 提高效率:String会被不同线程共享,是线程平安的。在波及多线程操作中不须要同步操作。
平安:String常被用于用户名、明码、文件名等应用,因为其不可变,可防止黑客行为对其歹意批改。
序列化是什么?
序列化是一种将对象转换成字节序列的过程,用于解决在对对象流进行读写操作时所引发的问题。序列化能够将对象的状态写在流里进行网络传输,或者保留到文件、数据库等零碎里,并在须要的时候把该流读取进去从新结构成一个雷同的对象。
简述Java中Class对象
java中对象能够分为实例对象和Class对象,每一个类都有一个Class对象,其蕴含了与该类无关的信息。
获取Class对象的办法:
- Class.forName(“类的全限定名”)
- 实例对象.getClass()
- 类名.class
Java反射机制是什么?
Java反射机制是指在程序的运行过程中能够结构任意一个类的对象、获取任意一个类的成员变量和成员办法、获取任意一个对象所属的类信息、调用任意一个对象的属性和办法。反射机制使得Java具备动静获取程序信息和动静调用对象办法的能力。能够通过以下类调用反射API。
- Class类:可取得类属性办法
- Field类:取得类的成员变量
- Method类:获取类的办法信息
- Construct类:获取类的构造方法等信息
简述注解
Java 注解用于为 Java 代码提供元数据。作为元数据,注解不间接影响你的代码执行,但也有一些类型的注解实际上能够用于这一目标。
其能够用于提供信息给编译器,在编译阶段时给软件提供信息进行相干的解决,在运行时解决写相应代码,做对应操作。
简述元注解
元注解能够了解为注解的注解,即在注解中应用,实现想要的性能。其具体分为:
- @Retention: 示意注解存在阶段是保留在源码,还是在字节码(类加载)或者运行期(JVM中运行)。
- @Target:示意注解作用的范畴。
- @Documented:将注解中的元素蕴含到 Javadoc 中去。
- @Inherited:一个被@Inherited注解了的注解润饰了一个父类,如果他的子类没有被其余注解润饰,则它的子类也继承了父类的注解。
- @Repeatable:被这个元注解润饰的注解能够同时作用一个对象屡次,然而每次作用注解又能够代表不同的含意。
简述Java异样的分类
Java异样分为Error(程序无奈解决的谬误),和Exception(程序自身能够解决的异样)。这两个类均继承Throwable。
Error常见的有StackOverFlowError,OutOfMemoryError等等。
Exception可分为运行时异样和非运行时异样。对于运行时异样,能够利用try catch的形式进行解决,也能够不解决。对于非运行时异样,必须解决,不解决的话程序无奈通过编译。
简述throw与throws的区别
throw个别是用在办法体的外部,由开发者定义当程序语句呈现问题后被动抛出一个异样。
throws个别用于办法申明上,代表该办法可能会抛出的异样列表。
简述泛型
泛型,即“参数化类型”,解决不确定对象具体类型的问题。在编译阶段无效。在泛型应用过程中,操作的数据类型被指定为一个参数,这种参数类型在类中称为泛型类、接口中称为泛型接口和办法中称为泛型办法。
简述泛型擦除
Java编译器生成的字节码是不包涵泛型信息的,泛型类型信息将在编译解决是被擦除,这个过程被称为泛型擦除。
简述Java根本数据类型
- byte: 占用1个字节,取值范畴-128 ~ 127
- short: 占用2个字节,取值范畴-2^15^ ~ 2^15^-1
- int:占用4个字节,取值范畴-2^31^ ~ 2^31^-1
- long:占用8个字节
- float:占用4个字节
- double:占用8个字节
- char: 占用2个字节
boolean:占用大小依据实现虚拟机不同有所差别
简述主动装箱拆箱
对于Java根本数据类型,均对应一个包装类。
装箱就是主动将根本数据类型转换为包装器类型,如int->Integer
拆箱就是主动将包装器类型转换为根本数据类型,如Integer->int
简述重载与重写的区别
重写即子类重写父类的办法,办法对应的形参和返回值类型都不能变。
重载即在一个类中,办法名雷同,参数类型或数量不同。
简述java的多态
Java多态能够分为编译时多态和运行时多态。
编译时多态次要指办法的重载,即通过参数列表的不同来辨别不同的办法。
运行时多态次要指继承父类和实现接口时,可应用父类援用指向子类对象。
运行时多态的实现:次要依附办法表,办法表中最先寄存的是Object类的办法,接下来是该类的父类的办法,最初是该类自身的办法。如果子类改写了父类的办法,那么子类和父类的那些同名办法共享一个办法表项,都被认作是父类的办法。因而能够实现运行时多态。
简述抽象类与接口的区别
抽象类:体现的是is-a的关系,如对于man is a person,就能够将person定义为抽象类。
接口:体现的是can的关系。是作为模板实现的。如设置接口fly,plane类和bird类均可实现该接口。
一个类只能继承一个抽象类,但能够实现多个接口。
简述==与equals办法的区别
对于==,在根本数据类型比拟时,比拟的是对应的值,对援用数据类型比拟时,比拟的是其内存的寄存地址。
对于equals办法,在该办法未被重写时,其成果和==统一,但用户能够依据对应需要对判断逻辑进行改写,比方间接比拟对象某个属性值是否雷同,雷同则返回true,不同则返回false。需保障equals办法雷同对应的对象hashCode也雷同。
简述Object类罕用办法
- hashCode:通过对象计算出的散列码。用于map型或equals办法。
须要保障同一个对象屡次调用该办法,总返回雷同的整型值。 - equals:判断两个对象是否统一。需保障equals办法雷同对应的对象hashCode也雷同。
- toString: 用字符串示意该对象
- clone:深拷贝一个对象
简述外部类及其作用
- 成员外部类:作为成员对象的外部类。能够拜访private及以上外部类的属性和办法。外部类想要拜访外部类属性或办法时,必须要创立一个外部类对象,而后通过该对象拜访外部类的属性或办法。外部类也可拜访private润饰的外部类属性。
- 部分外部类:存在于办法中的外部类。拜访权限相似局部变量,只能拜访外部类的final变量。
- 匿名外部类:只能应用一次,没有类名,只能拜访外部类的final变量。
- 动态外部类:相似类的动态成员变量。
简述String/StringBuffer与StringBuilder
String类采纳利用final润饰的字符数组进行字符串保留,因而不可变。如果对String类型对象批改,须要新建对象,将老字符和新减少的字符一并存进去。
StringBuilder,采纳无final润饰的字符数组进行保留,因而可变。但线程不平安。
StringBuffer,采纳无final润饰的字符数组进行保留,可了解为实现线程平安的StringBuilder。
简述Java序列化与反序列化的实现
序列化:将java对象转化为字节序列,由此能够通过网络对象进行传输。
反序列化:将字节序列转化为java对象。
具体实现:实现Serializable接口,或实现Externalizable接口中的writeExternal()与readExternal()办法。
简述JAVA的List
List是一个有序队列,在JAVA中有两种实现形式:
ArrayList 应用数组实现,是容量可变的非线程平安列表,随机拜访快,汇合扩容时会创立更大的数组,把原有数组复制到新数组。
LinkedList 实质是双向链表,与 ArrayList 相比插入和删除速度更快,但随机拜访元素很慢。
Java中线程平安的根本数据结构有哪些
HashTable: 哈希表的线程平安版,效率低
ConcurrentHashMap:哈希表的线程平安版,效率高,用于代替HashTable
Vector:线程平安版Arraylist
Stack:线程平安版栈
BlockingQueue及其子类:线程平安版队列
简述JAVA的Set
Set 即汇合,该数据结构不容许元素反复且无序。JAVA对Set有三种实现形式:
HashSet 通过 HashMap 实现,HashMap 的 Key 即 HashSet 存储的元素,Value零碎自定义一个名为 PRESENT 的 Object 类型常量。判断元素是否雷同时,先比拟hashCode,雷同后再利用equals比拟,查问O(1)
LinkedHashSet 继承自 HashSet,通过 LinkedHashMap 实现,应用双向链表保护元素插入程序。
TreeSet 通过 TreeMap 实现的,底层数据结构是红黑树,增加元素到汇合时依照比拟规定将其插入适合的地位,保障插入后的汇合依然有序。查问O(logn)
简述JAVA的HashMap
JDK8 之前底层实现是数组 + 链表,JDK8 改为数组 + 链表/红黑树。次要成员变量包含存储数据的 table 数组、元素数量 size、加载因子 loadFactor。
HashMap 中数据以键值对的模式存在,键对应的 hash 值用来计算数组下标,如果两个元素 key 的 hash 值一样,就会产生哈希抵触,被放到同一个链表上。
table 数组记录 HashMap 的数据,每个下标对应一条链表,所有哈希抵触的数据都会被寄存到同一条链表,Node/Entry 节点蕴含四个成员变量:key、value、next 指针和 hash 值。在JDK8后链表超过8会转化为红黑树。
若以后数据/总数据容量>负载因子,Hashmap将执行扩容操作。
默认初始化容量为 16,扩容容量必须是 2 的幂次方、最大容量为 1<< 30 、默认加载因子为 0.75。
为何HashMap线程不平安
在JDK1.7中,HashMap采纳头插法插入元素,因而并发状况下会导致环形链表,产生死循环。
尽管JDK1.8采纳了尾插法解决了这个问题,然而并发下的put操作也会使前一个key被后一个key笼罩。
因为HashMap有扩容机制存在,也存在A线程进行扩容后,B线程执行get办法呈现失误的状况。
简述java的TreeMap
TreeMap是底层利用红黑树实现的Map构造,底层实现是一棵均衡的排序二叉树,因为红黑树的插入、删除、遍历工夫复杂度都为O(logN),所以性能上低于哈希表。然而哈希表无奈提供键值对的有序输入,红黑树能够依照键的值的大小有序输入。
Collection和Collections有什么区别?
- Collection是一个汇合接口,它提供了对汇合对象进行基本操作的通用接口办法,所有汇合都是它的子类,比方List、Set等。
- Collections是一个包装类,蕴含了很多静态方法、不能被实例化,而是作为工具类应用,比方提供的排序办法:
Collections.sort(list);提供的反转办法:Collections.reverse(list)。
ArrayList、Vector和LinkedList有什么共同点与区别?
- ArrayList、Vector和LinkedList都是可伸缩的数组,即能够动静扭转长度的数组。
- ArrayList和Vector都是基于存储元素的Object[] array来实现的,它们会在内存中开拓一块间断的空间来存储,反对下标、索引拜访。但在波及插入元素时可能须要挪动容器中的元素,插入效率较低。当存储元素超过容器的初始化容量大小,ArrayList与Vector均会进行扩容。
- Vector是线程平安的,其大部分办法是间接或间接同步的。ArrayList不是线程平安的,其办法不具备同步性质。LinkedList也不是线程平安的。
- LinkedList采纳双向列表实现,对数据索引须要从头开始遍历,因而随机拜访效率较低,但在插入元素的时候不须要对数据进行挪动,插入效率较高。
HashMap和Hashtable有什么区别?
- HashMap是Hashtable的轻量级实现,HashMap容许key和value为null,但最多容许一条记录的key为null.而HashTable不容许。
- HashTable中的办法是线程平安的,而HashMap不是。在多线程拜访HashMap须要提供额定的同步机制。
- Hashtable应用Enumeration进行遍历,HashMap应用Iterator进行遍历。
如何决定应用HashMap还是TreeMap?
如果对Map进行插入、删除或定位一个元素的操作更频繁,HashMap是更好的抉择。如果须要对key汇合进行有序的遍历,TreeMap是更好的抉择。
fail-fast和fail-safe迭代器的区别是什么?
- fail-fast间接在容器上进行,在遍历过程中,一旦发现容器中的数据被批改,就会立即抛出ConcurrentModificationException异样从而导致遍历失败。常见的应用fail-fast形式的容器有HashMap和ArrayList等。
- fail-safe这种遍历基于容器的一个克隆。因而对容器中的内容批改不影响遍历。常见的应用fail-safe形式遍历的容器有ConcurrentHashMap和CopyOnWriteArrayList。
HashSet中,equals与hashCode之间的关系?
equals和hashCode这两个办法都是从object类中继承过去的,equals次要用于判断对象的内存地址援用是否是同一个地址;hashCode依据定义的哈希规定将对象的内存地址转换为一个哈希码。HashSet中存储的元素是不能反复的,次要通过hashCode与equals两个办法来判断存储的对象是否雷同:
- 如果两个对象的hashCode值不同,阐明两个对象不雷同。
- 如果两个对象的hashCode值雷同,接着会调用对象的equals办法,如果equlas办法的返回后果为true,那么阐明两个对象雷同,否则不雷同。