Java知识总结--SE篇

1-1-什么是Java的跨平台原理

Java通过不同的系统,不同的版本不同的位数的Java虚拟机(JVM)来屏蔽不同的指令集,然后对外提供了统一的Java接口(API),这样,我们的开发者只需按照接口开发即可,如果系统需要部署在不同的环境是,只需要系统上面按照片对应版本的虚拟机即可

想要了解更多Java架构技术的,可以关注我一下,我后续也会整理更多关于架构技术这一块的知识点分享出来,里面会分享一些:spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化,并发编程这些成为架构师必备的知识点。获取方式:关注后私信博主!!!

1.2-JDK 和 JRE 有什么区别?

JDK:java 开发工具包,提供了 java 的开发环境和运行环境。

JRE:java 运行环境,为 java 的运行提供了所需环境。

1.3-Java基本数据类型

1.4-Java基本类型所占字节和范围

1.5-int(long) 和 float(double) 哪个表示的范围大?为什么?

float表示的 范围更大。float 和 int 都是4个字节,而 float 还要表示小数,为什么 float 表示的数字范围大?

int 底层使用的是补码的方式表示一个数:1 位符号位 + 31 位二进制数

float 底层使用的是IEEE 754 浮点单精度数字格式,简单来说就是用指数的形式去表示一个数:1 位符号位 + 8 位指数 + 23位尾数

1.6-Int和Integer的区别,在使用时有什么区别?

Integer是int的包装类,int则是java的一种基本数据类型

Integer变量必须实例化后才能使用,而int变量不需要

Integer实际是对象的引用,当new一个Integer时,实际上是生成一个指针指向此对象;而int则是直接存储数据值

Integer的默认值是null,int的默认值是0

1.7-有了基本的数据类型,为什么还需要包装类型

因为Java是一个面向对象的语言,而基本的数据类型,不具备面向对象的特性

1.8-装箱和拆箱,自动拆箱,自动装箱

装箱:把基本的数据类型转换成对应的包装类型

拆箱:把包装类型转换成对应的基本数据类型

自动装箱:实际上编译时会调用integer.valueOf方法来装箱 Integer i=1;

自动拆箱:实际上编译时会调用intValue方法来拆箱 Int j=i.intValue();

1.9-重写,重载

重载:方法名字相同,而参数不同。返回类型可以相同也可以不同

重写:子类定义的方法与父类中的方法具有相同的方法名字,相同的参数表和相同的返回类型

子类和父类在同一个包中,那么子类可以重写父类所有方法,除了声明为 private 和 final 的方法。

子类和父类不在同一个包中,那么子类只能够重写父类的声明为 public 和 protected 的非 final 方法。

声明为 static 的方法不能被重写,但是能够被再次声明。

子类如果不是抽象类,则必须重写父类中的abstract方法。

如果不能继承一个方法,则不能重写这个方法。

1.10-==和equals方法的区别

==对于基本类型是比较的是值是否相同,对于引用类型比较的是地址是否相同。equals默认情况下是引用的比较,只是很多类重写了 equals的方法,比如spring,integer等把它变成了值比较,所以一般情况下equals比较的是值是否相等

1.11- final 在 java 中有什么作用?

final 修饰的类叫最终类,该类不能被继承。

final 修饰的方法不能被重写。

final 修饰的变量叫常量,常量必须初始化,初始化之后值就不能被修改。

1.12-面向对象的特征有哪些方面

多态,继承,封装, (抽象)

抽象:把一个对象,抽象为类

封装:隐藏类的内部信息,外部类不可以直接访问,可以通过get/set去获取或值改变这个类

继承:通过extends继承父类的基本特征和行为,子类也可以改变这些基本特征和行为

多态:也就是同一个操作作用在不同对象上面的时候可以产生不同的效果

1.13-接口和抽象类(接口的抽象级别最高)

相同点:

不能被实例化。

不同点:

抽象类要被子类继承extends,接口要被类实现implements 。

抽象类可以有构造函数;接口不能有。

接口支持多继承,抽象类只允许单继承。

接口只能做方法声明,抽象类中可以作方法声明,也可以做方法实现。

接口里定义的变量只能是公共的静态的常量,抽象类中的变量是普通变量。

抽象类可以有具体的方法和属性,接口只能有抽象方法和不可变常量。

抽象类可以有 main 方法,并且我们能运行它;接口不能有 main 方法。

1.14-抽象类不是必须要有抽象方法

不需要,抽象类不一定非要有抽象方法。

public abstract class Person{

public static void say() {

System.out.println("HELLO");

}

}

1.15-普通类和抽象类的区别

普通类不能包含抽象方法,抽象类可以包含抽象方法。

抽象类不能直接实例化,普通类可以直接实例化。

1.16-抽象类不能使用 final 修饰

定义抽象类就是让其他类继承的,如果定义为 final 该类就不能被继承,这样彼此就会产生矛盾,所以 final 不能修饰抽象类

1.17-String底层实现,不可变的原因

String的底层是使用char数组的,char数组和String类都是被final修饰的,所以不可以改变

1.18-String 不属于基础的数据类型

String 不属于基础类型,String 属于对象。

1.19-String str="str"与 String str=new String("str")的内存分配

因为内存的分配方式是不一样的,String str="str"的方式,java 虚拟机会将其分配到常量池中;而 String str=new String("str") 则会被分到堆内存中。

1.20- String 类的常用方法

length()字符串的长度

charAt() 截取一个字符

equals()和equalsIgnoreCase() 比较两个字符串

compareTo()和compareToIgnoreCase() 比较字符串

concat() 连接两个字符串

replace() 替换

toUpperCase() /toLowerCase() 转换为大小写

trim() 去掉起始和结尾的空格

String test="abcdefg";

String test2=" ABCDEFG ";

System.out.println("字符串长度=" + test.length());

System.out.println("截取一个字符 = " + test.charAt(2));

int compareTo = test.compareTo(test2);

System.out.println("compareTo = " + compareTo);

int compareToIgnoreCase = test.compareToIgnoreCase(test2);

System.out.println("compareToIgnoreCase = " + compareToIgnoreCase);

boolean b = test.equals(test2);

System.out.println("b = " + b);

boolean b1 = test.equalsIgnoreCase(test2);

System.out.println("b1 = " + b1);

String str=test.concat(test2).concat("test");

System.out.println("str = " + str);

str=str.replace("test","idea");

System.out.println("str = " + str);

str=str.toLowerCase();

System.out.println("str = " + str);

str=str.toUpperCase();

System.out.println("str = " + str);

int test2Length=test2.length();

test2=test2.trim();

System.out.println("test2Length2 = " + test2Length);

int test2Length1=test2.length();

System.out.println("test2Length1 = " + test2Length1);

//字符串长度=7

//截取一个字符 = c

//compareTo = 65

//compareToIgnoreCase = 65

//b = false

//b1 = false

//str = abcdefg ABCDEFG test

//str = abcdefg ABCDEFG idea

//str = abcdefg abcdefg idea

//str = ABCDEFG ABCDEFG IDEA

//test2Length2 = 14

//test2Length1 = 7

1.21-String,StringBuilder,StringBuffer的区别?

String是只读字符,值不可以改变的

StringBuffer的值是可以改变的,线程安全

StringBuilder的值是可以改变的,线程不安全

1.22-什么是值传递和引用传递?

值传递是对基本类型变量而言的,传递的是该变量的一个副本,改变副本不影响原来变量.

引用传递一般是对于对象型变量而言的,传递的是该对象地址的一个副本, 并不是原对象本身 。

一般认为,java内的基础类型数据传递都是值传递. java中实例对象的传递是引用传递

1.23-SimpleDateFormat的作用和用法

SimpleDateFormat的作用是用于设置时间格式的

把日期转换为指定格式的字符串

SimpleDateFormat sdformat = new SimpleDateFormat("yyy y-MM-dd HH:mm:ss");

String text = sdformat .format(new Date());

 

//text = 2020 2020-06-14 16:00:54

把字符串转换为指定格式日期

public static void main(String []args) throws ParseException {

String text = "2020年1月1日 1:11:11";

SimpleDateFormat sdformat= new SimpleDateFormat("yyyy年M月dd日 H:mm:ss");

Date date= sdformat.parse(text);

System.out.println("date = " + date);

}

//date = Wed Jan 01 01:11:11 CST 2020

1.24- java 中 IO 流分类

按功能来分:输入流(input)、输出流(output)。

按类型来分:字节流和字符流。

 

1.25-Java的流

1.26- Files的常用方法

Files.exists():检测文件路径是否存在。

Files.createFile():创建文件。

Files.createDirectory():创建文件夹。

Files.delete():删除一个文件或目录。

Files.copy():复制文件。

Files.move():移动文件。

Files.size():查看文件个数。

Files.read():读取文件。

Files.write():写入文件。

 

1.27-如何创建文件和目录?

File file = new File("D:", "one");

//创建文件夹

file .mkdir();

//创建文件

file .createNewFile();

//删除文件

file .delete();

1.28-面向对象编程的六大原则

1、开闭原则(Open Close Principle)

开闭原则的意思是:对扩展开放,对修改关闭。在程序需要进行拓展的时候,不能去修改原有的代码,实现一个热插拔的效果。简言之,是为了使程序的扩展性好,易于维护和升级。想要达到这样的效果,我们需要使用接口和抽象类。

2、里氏代换原则(Liskov Substitution Principle)

里氏代换原则是面向对象设计的基本原则之一。 里氏代换原则中说,任何基类可以出现的地方,子类一定可以出现。LSP 是继承复用的基石,只有当派生类可以替换掉基类,且软件单位的功能不受到影响时,基类才能真正被复用,而派生类也能够在基类的基础上增加新的行为。里氏代换原则是对开闭原则的补充。实现开闭原则的关键步骤就是抽象化,而基类与子类的继承关系就是抽象化的具体实现,所以里氏代换原则是对实现抽象化的具体步骤的规范。

3、依赖倒转原则(Dependence Inversion Principle)

这个原则是开闭原则的基础,具体内容:针对接口编程,依赖于抽象而不依赖于具体。

4、接口隔离原则(Interface Segregation Principle)

这个原则的意思是:使用多个隔离的接口,比使用单个接口要好。它还有另外一个意思是:降低类之间的耦合度。由此可见,其实设计模式就是从大型软件架构出发、便于升级和维护的软件设计思想,它强调降低依赖,降低耦合。

5、迪米特法则,又称最少知道原则(Demeter Principle)

最少知道原则是指:一个实体应当尽量少地与其他实体之间发生相互作用,使得系统功能模块相对独立。

6、单一职责原则(Single responsibility principle)

单一职责原则是指:一个类应该只有一个发生变化的原因,即一个类只负责一项职责。

如果一个类有多个职责,这些职责就耦合在了一起。当一个职责发生变化时,可能会影响其它的职责。另外,多个职责耦合在一起会影响复用性。

此原则的核心是解耦和增强内聚性。

1.29-设计模式

​​​​​单例模式(饱汉模式,饥汉模式)

1)构造方法私有化,让除了自己类能创建外其他地方都不可以创建

2)在自己的类中创建一个单实例(饱汉模式一出来就创建单实例,饥汉模式需要的时候才 创建)

3)提供一个方法获取该实例对象(饥汉模式创建时需要进行方法同步)

工程模式:spring的IOC就是使用工程模式

对象的创建交给一个工厂创建

代理模式:Spring的AOP就是使用的动态代理

包装模式

1.30- 运行时异常与一般异常的区别

异常表示程序运行过程中可能出现的非正常状态,运行时异常表示虚拟机的通常操作中可能遇到的异常,是一种常见运行错误。java编译器要求方法必须声明抛出可能发生的非运行时异常,但是并不要求必须声明抛出未被捕获的运行时异常。

1.31-&和&&的区别

&是位运算符,表示按位与运算,&&是逻辑运算符,表示逻辑与(and)

 

1.32-final, finally, finalize的区别。

final 用于声明属性,方法和类,分别表示属性不可变,方法不可覆盖,类不可继承。

finally是异常处理语句结构的一部分,表示总是执行。

finalize是Object类的一个方法,在垃圾收集器执行的时候会调用被回收对象的此方法,可以覆盖此方法提供垃圾收集时 的其他资源回收,例如关闭文件等。

1.33-error和exception的区别。

error 表示恢复不是不可能但很困难的情况下的一种严重问题。比如说内存溢出。不可能指望程序能处理这样的情况。

exception 表示一种设计或实现问题。也就是说,它表示如果程序运行正常,从不会发生的情况。

1.34-Math.round(9.5)等多少? Math.round(-9.5)等多少?

Math.round(9.5) =10

Math.round(-9.5) =-9

数轴上取值时,中间值(0.5)向右取整,所以正 9.5 是往上取整,负 9.5 是直接舍弃。

你可能感兴趣的:(Java知识总结--SE篇)