Java面试知识点(零)Java零碎知识点

154 篇文章 5 订阅
150 篇文章 6 订阅
  1. Java文件经过JVM编译成字节码文件,即.class文件,将字节码文件在不同的操作系统中运行时,操作系统再将字节码文件编译成机器码文件。这就是Java跨平台

  1. 首先明确一点,java 的 GC 回收是完全自动的,没有提供相关 api 手动回收,所有的内存分配和回收权限都在 jvm,在开发人员手里没有绝对的强制垃圾回收的方法,不过可以这样去做:
    1. 对于不再引用的对象,及时把它的引用赋为 null。 obj = null;
    2. 如果内存确实很紧张,调用 System.gc () 方法来建议垃圾回收器开始回收垃圾,通知 GC 运行,但是 Java 语言规范并不保证 GC 一定会执行。

  1. java 基本类型的默认值和取值范围
    整数类型 byte(1 个字节)short(2 个字节)int(4 个字节)long(8 个字节)
    字符类型 char(2 个字节)
    浮点类型 float(4 个字节)double(8 个字节)
    在这里插入图片描述

  1. 常见字符的ASCII码值如下:空格的ASCII码值为32;数字0到9的ASCII码值分别为48到57;大写字母“A”到“Z”的ASCII码值分别为65到90;小写字母“a”到“z”的ASCII码值分别为97到到122。

  1. Java 标识符有如下命名规则:
    • 由 26 个英文字母大小写,数字:0-9 符号:_ $ ¥ 组成
    • 标识符应以字母、_ 、$ 开头。
    • 标识符不能是关键字。

  1. 抽象类和接口
    • 关于抽象类
      JDK 1.8 以前,抽象类的方法默认访问权限为 protected
      JDK 1.8 时,抽象类的方法默认访问权限变为 default

    • 关于接口
      JDK 1.8 以前,接口中的方法必须是 public 的
      JDK 1.8 时,接口中的方法可以是 public 的,也可以是 default 的
      JDK 1.9 时,接口中的方法可以是 private 的


  1. 装箱和拆箱
    基本数据类型转化成包装类是装箱 (如: int --> Integer)。
    包装类转化成基本数据类型就是拆箱 (如:Integer --> int)。
    包装类就是引用类型,基本数据类型就是值类型。
    通过 装箱拆箱 操作,能够在值类型和引用类型中架起一做桥梁。换言之,可以轻松的实现值类型与引用类型的互相转换,装箱和拆箱能够统一考察系统,任何类型的值最终都可以按照对象进行处理。

  1. 序列化和反序列化
    Java 在序列化时不会实例化 static 变量和 transient 修饰的变量,因为 static 代表类的成员,transient 代表对象的临时数据,被声明这两种类型的数据成员不能被序列化

  1. Java有两种传递方式,值传递和引用传递。基本类型和以string str = “aaa”;这种方式创建的都是值传递,对象创建和数组都是引用传递,所以在函数的判断形参需要特别注意。

  1. Java垃圾回收机制
    垃圾回收主要针对的是堆区的回收,因为栈区的内存是随着线程而释放的。堆区分为三个区:年轻代(Young Generation)、年老代(Old Generation)、永久代(Permanent Generation,也就是方法区)。
    • 年轻代:对象被创建时(new)的对象通常被放在 Young(除了一些占据内存比较大的对象), 经过一定的 Minor GC(针对年轻代的内存回收)还活着的对象会被移动到年老代(一些具体的移动细节省略)。
    • 年老代:就是上述年轻代移动过来的和一些比较大的对象。Major GC (FullGC) 是针对年老代的回收。
    • 永久代:存储的是 final 常量,static 变量,常量池。

  1. 包引用
    import java.util.* ;
    能访问java/util目录下的所有类,不能访问java/util子目录下的所有类

  1. Java的保留字和关键字
    goto 和 const 是保留字也是关键字。
    • Java 关键字列表 (依字母排序 共 50 组):
      abstract, assert, boolean, break, byte, case, catch, char, class, const(保留关键字), continue, default, do, double, else, enum, extends, final, finally, float, for, goto(保留关键字), if, implements, import, instanceof, int, interface, long, native, new, package, private, protected, public, return, short, static, strictfp, super, switch, synchronized, this, throw, throws, transient, try, void, volatile, while
    • 保留字列表 (依字母排序 共 14 组),Java 保留字是指现有 Java 版本尚未使用,但以后版本可能会作为关键字使用:
      byValue, cast, false, future, generic, inner, operator, outer, rest, true, var, goto (保留关键字) , const (保留关键字) , null

  1. 构造函数不能被继承,构造方法只能被显式或隐式的调用。(有参和无参均是这样)

  1. 文件分为文本文件和二进制文件,计算机只认识二进制,所以实际上都是二进制的不同解释方式。文本文件是以不同编码格式显示的字符,例如 Ascii、Unicode 等,window 中文本文件的后缀名有 “.txt”,".log", 各种编程语言的源码文件等;二进制文件就是用文本文档打开是看不懂乱码,只要能用文本打开的文件都可以算是文本文件,只是显示的结果不是你想要的,二进制文件只有用特殊的应用才能读懂的文件,例如 “.png”,".bmp" 等,计算机中大部分的文件还是二进制文件

  1. servlet 是运行在服务器端的小应用程序,是接收网络服务的请求和产生响应的一种方式。
    servlet 的功能:接受 http 请求,产生动态 http 响应。Web容器负责将 HTTP 请求转换为 HttpServletRequest 对象

  1. 字符流和字节流
    stream 结尾都是字节流,reader 和 writer 结尾都是字符流 两者的区别就是读写的时候一个是按字节读写,一个是按字符。 实际使用通常差不多。 在读写文件需要对内容按行处理,比如比较特定字符,处理某一行数据的时候一般会选择字符流。 只是读写文件,和文件内容无关的,一般选择字节流。

  1. try 只适合处理运行时异常,try+catch 适合处理运行时异常 + 普通异常。也就是说,如果你只用 try 去处理普通异常却不加以 catch 处理,编译是通不过的,因为编译器硬性规定,普通异常如果选择捕获,则必须用 catch 显示声明以便进一步处理。而运行时异常在编译时没有如此规定,所以 catch 可以省略,你加上 catch 编译器也觉得无可厚非。

  1. 泛型仅仅是 java 的语法糖,它不会影响 java 虚拟机生成的汇编代码,在编译阶段,虚拟机就会把泛型的类型擦除,还原成没有泛型的代码,顶多编译速度稍微慢一些,执行速度是完全没有什么区别的.

  1. Set 不能有重复的元素,且是无序的,要有空值也就只能有一个。因为它不允许重复。 L ist 可以有重复元素,且是有序的,要有空值也可以有多个,因为它可重复

  1. DBMS事务的四个特性
    原子性:事务是一组不可分割的操作单元,这组单元要么同时成功要么同时失败(由DBMS的事务管理子系统来实现);
    一致性:事务前后的数据完整性要保持一致(由DBMS的完整性子系统执行测试任务);
    隔离性: 多个用户的事务之间不要相互影响,要相互隔离(由DBMS的并发控制子系统实现);
    持久性: 一个事务一旦提交,那么它对数据库产生的影响就是永久的不可逆的,如果后面再回滚或者出异常,都不会影响已提交的事务(由DBMS的恢复管理子系统实现的)

  1. Java 中的 volatile 关键字的功能
    volatile 是 java 中的一个类型修饰符。它是被设计用来修饰被不同线程访问和修改的变量。如果不加入 volatile,基本上会导致这样的结果:要么无法编写多线程程序,要么编译器 失去大量优化的机会。

    • 可见性
      可见性指的是在一个线程中对该变量的修改会马上由工作内存(Work Memory)写回主内存(Main Memory),所以会马上反应在其它线程的读取操作中。顺便一提,工作内存和主内存可以近似理解为实际电脑中的高速缓存和主存,工作内存是线程独享的,主存是线程共享的。
    • 禁止指令重排序优化
      禁止指令重排序优化。大家知道我们写的代码(尤其是多线程代码),由于编译器优化,在实际执行的时候可能与我们编写的顺序不同。编译器只保证程序执行结果与源代码相同,却不保证实际指令的顺序与源代码相同。这在单线程看起来没什么问题,然而一旦引入多线程,这种乱序就可能导致严重问题。volatile 关键字就可以从语义上解决这个问题。

    注意,禁止指令重排优化这条语义直到 jdk1.5 以后才能正确工作。此前的 JDK 中即使将变量声明为 volatile 也无法完全避免重排序所导致的问题。


  1. Java 跟 C 的区别,C 中赋值后会与 0 进行比较,如果大于 0,就认为是 true;而 Java 不会与 0 比较,整数型就是整型,布尔型就是布尔型。

  1. Math 类中提供了三个与取整有关的方法:ceil,floor,round, 这些方法的作用于它们的英文名称的含义相对应,例如:ceil 的英文意义是天花板,该方法就表示向上取整,Math.ceil(11.3)的结果为 12,Math.ceil (-11.6) 的结果为 - 11;floor 的英文是地板,该方法就表示向下取整,Math.floor (11.6) 的结果是 11,Math.floor (-11.4) 的结果 - 12;最难掌握的是 round 方法,他表示 “四舍五入”,算法为 Math.floor (x+0.5), 即将原来的数字加上 0.5 后再向下取整,所以,Math.round (11.5) 的结果是 12,Math.round (-11.5) 的结果为 - 11.

  1. 不可变类(Immutable Class)是一旦被实例化就不会改变自身状态(或值)的类。
    String 就是一种典型的不可变类。(使用字符串自带的函数改变string内容都是相当于创建一个新的string,即 new String)
    不可变类的主要用途是在多线程环境下确保对象的线程安全。

  1. java中接口的修饰符是public,接口中的变量是 public static final,接口中的方法是public abstract

  1. 类中声明的变量有默认初始值(成员变量);方法中声明的变量没有默认初始值,必须在定义时初始化,否则在访问该变量时会出错(局部变量)。

  1. 方法中不能使用 private 修饰变量(在类中可以)
    因为 private 修饰符是使用在类的 ,如果在在类中声明一个成员变量使用 private 修饰后,这个变量只能被这个类中的方法所访问,而在方法体中声明变量,这个变量的作用域是从这个变量声明直到方法体结束,如果再使用 private 修饰的话两者就会冲突,所以不能在方法体内声明一个变量为 private,而且在方法里声明变量为 private 也没什么意义,方法内声明的变量的作用域本来就在方法体内,也在他本身的类中,自然也不会被其他类中的方法所访问

  1. 管道
    对于管道,有下面这几种类型:
    ①普通管道(PIPE):通常有两种限制,一是单工,即只能单向传输;二是血缘,即常用于父子进程间(或有血缘关系的进程间)。
    ②流管道(s_pipe):去除了上述的第一种限制,实现了双向传输。
    ③命名管道(name_pipe):去除了上述的第二种限制,实现了无血缘关系的不同进程间通信。
    要求是对于不同的服务器之间的通信,是要要求全双工形式的,而管道只能是半双工,虽然可以双向,但是同一时间只能有一个方向传输,全双工和半双工的区别可以如下图示理解:
    在这里插入图片描述

  1. Vector 类 是在 java 中可以实现自动增长的对象数组
    vector 是线程安全的 ArrayList(Vector和 List 用法差不多,不过现在已经很少用了,List 已经能全部取代 Vector 了),在内存中占用连续的空间。初始时有一个初始大小,当数据条数大于这个初始大小后会重写分配一个更大的连续空间。如果 Vector 定义为保存 Object 则可以存放任意类型。

  1. 关于多线程中的start方法和run方法的区别
    启动多线程有两种方式,但是无论是依靠那种方式,最终都是需要调用thread的start方法,而决定了线程去做什么,则需要重写run方法,假如,我们重写了run方法,同时在main线程中new 了一个thread,第一种情况,调用该thread的start方法,这时就产生了一个新的线程,这个线程处于就绪状态,等待CPU调度;第二种情况,调用了该thread的run方法,这时就不会产生新的线程,依旧在main线程中执行。

  1. native关键字
    native 关键字说明其修饰的方法是一个原生态方法,方法对应的实现不是在当前文件,而是在用其他语言(如 C 和 C++)实现的文件中。Java 语言本身不能对操作系统底层进行访问和操作,但是可以通过 JNI 接口——Java Native Interface (Java 本地接口)调用其他语言来实现对底层的访问。

  1. finalize方法
    java 技术允许使用 finalize () 方法在垃圾收集器将对象从内存中清除之前做必要的清理工作。这个方法是在垃圾收集器在确定了,被清理对象没有被引用的情况下调用的。
    finalize () 是 Object 中的方法,当垃圾回收器将要回收对象所占内存之前被调用,即当一个对象被虚拟机宣告死亡时会先调用它 finalize () 方法,让此对象处理它生前的最后事情(这个对象可以趁这个时机挣脱死亡的命运)。

  1. java反射
  • JAVA 反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性;这种动态获取的信息以及动态调用对象的方法的功能称为 java 语言的反射机制。
  • 实际上,我们创建的每一个类也都是对象,即类本身是 java.lang.Class 类的实例对象。这个实例对象称之为类对象,也就是 Class 对象。Class 对象的由来是将 class 文件读入内存,并为之创建一个 Class 对象。
  • 反射就是把 java 类中的各种成分映射成一个个的 Java 对象
    例如:一个类有:成员变量、方法、构造方法、包等等信息,利用反射技术可以对一个类进行解剖,把个个组成部分映射成一个个对象。

  1. 多态
  • 多态就是指程序中定义的引用变量所指向的具体类型和通过该引用变量发出的方法调用在编程时并不确定,而是在程序运行期间才确定,即一个引用变量倒底会指向哪个类的实例对象,该引用变量发出的方法调用到底是哪个类中实现的方法,必须在由程序运行期间才能决定。因为在程序运行时才确定具体的类,这样,不用修改源程序代码,就可以让引用变量绑定到各种不同的类实现上,从而导致该引用调用的具体方法随之改变,即不修改程序代码就可以改变程序运行时所绑定的具体代码,让程序可以选择多个运行状态,这就是多态性。
  • 关于多态的问题,可以大体概括为:
    编译看左边,运行看右边。意思编译时候,看左边有没有该方法,运行的时候结果看 new 的对象是谁,就调用的谁。

  1. 包装类和基本类
    Java 的类型分为两部分,一个是基本类型(primitive),如 int、double 等八种基本数据类型;另一个是引用类型(reference type),如 String、List 等。而每一个基本类型又各自对应了一个引用类型,称为包装类型(或装箱类型,boxed primitive)。
    基本类型:byte、short、int、long、float、double、char、boolean
    包装类:Byte、Short、Integer、Long、Float、Double、Character、Boolean
  • 基本类型只有值,而包装类型则具有与它们的值不同的同一性(identity)。这个同一性是指,两个引用是否指向同一个对象,如果指向同一个对象,则说明具有同一性。(与此类似的还有等同性。)
  • 基本类型只有功能完备的值,而包装类型除了其对应的基本类型所有的功能之外,还有一个非功能值:null。
  • 基本类型通常比包装类型更节省时间与空间。

  1. Java 中 T 和?的区别
  • ? 做对象的泛型来用
  • T 做类的泛型

  1. 类变量和实例变量
    成员变量和局部变量的区别大家都清楚,但是成员变量还具体区分为类变量和实例变量:
  • 类变量:被static修饰的变量成为类变量。
  • 实例变量:没有static修饰,这些变量是类中的成员,称为实例变量。

  1. 数组的创建

创建数组时不指定大小则必须初始化

即:

int[] a = new int[10]; // 数组长度为10
int[] b = new int[]{1,2}; // 数组长度为2

原因:

在new一个对象的时候,jvm开始创建对象,步骤为:

  • 类加载检查
  • 分配内存
  • 初始化零值
  • 设置对象头
  • 执行<init>方法

如果不指定数组的大小或者不初始化,那么第二步的分配内存就无法进行


未完待续…

  • 251
    点赞
  • 902
    收藏
    觉得还不错? 一键收藏
  • 24
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 24
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值