当前位置: 首页 > 图灵资讯 > 技术篇> offer Java基础精选从编译到集合

offer Java基础精选从编译到集合

来源:图灵教育
时间:2023-05-04 10:40:59

offer Java基础精选从编译到集合_父类

offer Java基础精选从编译到集合_构造方法_02

offer Java基础精选从编译到集合_构造方法_03

  JRE支持.class文件不对.java .jsp编译class文件

  标识符 _ $

  关键字

  transient volatile

offer Java基础精选从编译到集合_后端_04

  char 2个 字节 16位

  1.4E-14 = 1.4*10^-14

  八进制 0开头 包括0-7

  16进制 0x或0X 包括0-9 a-f A-F

  整形默认是 int

  l L

  默认情况下,Double是浮点类型

  D d

  F f

offer Java基础精选从编译到集合_后端_05

  可以使用字符类型 'A' '65' 'a' '97' '\uxxxx'

  ASCII码标准7 128种字符 表示大小写字母、标点符号、美式英语控制字符

  扩展ASCII码 256个字符(后128位)表示特殊符号,外语字母

  Unicode编码 支持世界上所有的字符集

  '\uxxxx'

offer Java基础精选从编译到集合_后端_06

  数值型 + 字符型 = 将字符转换为数值型进行计算

  数值型 + 字符串型 = 连接运算

  字符串 + 数值型 / 数值型 = 由于/优先级较高,先删除后连接字符串

  变量可以用中文表示

  科学计数法只能用于浮点型

  double d=1.23E5 // d=123000.0 = 1.23*10^5

  float f=1.23e5f

offer Java基础精选从编译到集合_Java_07

  double float将失去精度

  int long 转 float会失去精度

  long 转double会失去精度

  浮点位数过多,输出用科学计数法表示

  表示位数过多时精度不准确

offer Java基础精选从编译到集合_子类_08

offer Java基础精选从编译到集合_Java_09

  最后一个计算结果忽略了单精度的长度

  不考虑最后一个

  小数点后最多保留7位

  这里是8位了

  数据丢失是由于精度不足造成的

  BigDecimal类需要使用。

  使用局部变量必须初始化

  分子分母都是整形手术 商为整形

  13/5=2

  一个分子或分母是浮点型的 浮点型Double

  13.0/5=2.6

  求余数都有整形手术 结果为整形

  13%5=3

  求余数有浮点型 结果是浮点型

  1 3.5%5=3.5D

offer Java基础精选从编译到集合_子类_10

  前++ 先自增后赋值

  后++ 赋值后自增

  'A' > 'B' 为false ASCII比较

  float f=5.0f

  long l=5

  f==l 结果是true 只要相等

  关于 && 与 ||

  a && b:同时trueea和b 才返回 true, 否则,返回false;a || b:任何trueea或b的任何一个 回到true , 否则,返回false

  还要运算 所以n=4

offer Java基础精选从编译到集合_父类_11

  不用运算 所以n=3

offer Java基础精选从编译到集合_父类_12

  boolean?():()

  运算符优先级() ! ++ -- * / % + - >= <= > < == != && & || | = *= += -= %= /=

  ()最高

  =最低

offer Java基础精选从编译到集合_构造方法_13

  switch是一个常量值

  char byte short int Character Byte Short Integer String enum

  new Scanner(System.in)

  scanner.next()

  (int)(Math.random()*10+1)

offer Java基础精选从编译到集合_父类_14

offer Java基础精选从编译到集合_Java_15

offer Java基础精选从编译到集合_构造方法_16

offer Java基础精选从编译到集合_父类_17

  一维数组

  int[] array;

  int array[];

  int[] array;

  array = new int[10];

  int[] array = new int[10];

  int[] array = new int[1,2,3,4}

  int[] array = new int[]{};

  int[] array = {1,2,3,4}

  int[] array = {};

  array.length

  array[array.length-1]

  增强型for循环

  for(:)

  冒泡排序

offer Java基础精选从编译到集合_Java_18

  二维数组

  int[][] array

  array = new int[3][3]

  int array[][]

  array = new int[3][] 只指定行数

  array[0] = new int[3]

  array[1] = new int[4]

  int[] array[]

  int[][] array = new int[]{1,2,3},{1,2}

  int[][] array = new int[]{},{},{} 4行

  int[][] array = {1,2}

  int[][] array = new int[][][];无列

  int[][] array = {};

  array.length 行数

  array[0].length 第一行列数

  可变参数不能定义为第一位 一种方法只能有一个可变参数

  可以将数组传输给可变参数

  可变参数不能作为参数传递

  (int,int...)

  (int,int[]) 报错 不能重载

  (int,int...)

  (int,int)

  (1、2)不调用可变参数

  scanner.nextInt()

  正确处理异常

offer Java基础精选从编译到集合_父类_19

  声明对象时 栈空间为null

  new时堆空间开辟了内存 堆叠空间的地址引用

  没有指定的结构方法 该系统将自动添加结构方法

  进入结构方法排名第一 this实例对象产生

  赋值本身

offer Java基础精选从编译到集合_父类_20

offer Java基础精选从编译到集合_Java_21

  与结构方法同名的普通方法可以定义

  这种调用方法可以添加this 可不加

  结构方法可以调用

  this() 应该放在结构方法的第一行

offer Java基础精选从编译到集合_构造方法_22

  包装增加了防御性编程

  package包需要放在第一行 只能有一个

offer Java基础精选从编译到集合_构造方法_23

  报错

offer Java基础精选从编译到集合_父类_24

  加载有指定Cat类的包

  *下面是Cat类

offer Java基础精选从编译到集合_父类_25

  跟顺序无关 或者加载有指定Cat类的包

offer Java基础精选从编译到集合_后端_26

  加载只能显示

offer Java基础精选从编译到集合_Java_27

offer Java基础精选从编译到集合_Java_28

offer Java基础精选从编译到集合_构造方法_29

offer Java基础精选从编译到集合_后端_30

offer Java基础精选从编译到集合_构造方法_31

  将静态成员属性定义为斜体

  静态成员可以通过对象名访问

  但应使用类名进行访问

  静态是静态地址 每个对象使用相同的静态地址

  局部变量不能添加staticcc 只能加final

  静态方法 非静态的不能调用 成员方法 不能使用成员属性 不能使用this

  如果需要使用,则需要实例化

  {} 普通代码块 构造代码块

  每次实例化都会调用结构代码块

  static{}静态代码块只能调用一次

  局部变量{} 作用域内

  -表示private

  +表示public

  子 类中 可以访问父类非private成员

  静态成员可以继承

  结构方法不能继承 不能被重写

  静态方法不能重写

offer Java基础精选从编译到集合_子类_32

offer Java基础精选从编译到集合_子类_33

  super 不能调用 自己的 private 成语

  ClassLoader.loadClass(String name) 将字节码加载到JVM中 形成Class类

offer Java基础精选从编译到集合_后端_34

offer Java基础精选从编译到集合_子类_35

  默认情况下,子类会调用父类无参结构方法

  当父亲定义了结构方法时 没有无参结构的方法 因此,默认情况下,提供一种无参结构的方法

  必须在子类中显示 调用

  不能并存

offer Java基础从编译到集合_结构方法_36

offer Java基础精选从编译到集合_Java_37

  Object 类

  equalss没有重写 String 比较内容是否相同 在桶里比较

  equals 就是 ==

  toString 打印普通对象标识 String打印字符内容

  hashCode 普通对象返回对象标识 String返回与字符相关的标志 一般用于放置哪个桶

  比较两个对象的属性是否相等

offer Java基础精选从编译到集合_构造方法_38

offer Java基础精选从编译到集合_构造方法_39

  final + 类 代表 没有子类

  final + 方法 不能被重写 可被继承

  final + 局部变量 不能被修改

  final + 成员的基本类型属性 不能被修改

  final + 对象类型 引用不能修改 内容可修改

  不能用于结构方法

  final 修饰 只能在 定义时 构造代码块 静态代码块的结构方法 赋值

  提高性能

offer Java基础精选从编译到集合_构造方法_40

  编译时去掉 @Override

offer Java基础精选从编译到集合_Java_41

  编译时注解 源码 .class文件都有

  @Autowired 运行时注解

  元注解 注解的注解

  饿汉式

offer Java基础精选从编译到集合_Java_42

offer Java基础精选从编译到集合_Java_43

  懒汉式 线程不安全

offer Java基础精选从编译到集合_构造方法_44

  可提高性能

offer Java基础精选从编译到集合_后端_45

  instanceof 运算符 只要这一类与这一类兼容 类型 将返回true

  JVM来了抽象类 实例化的

  如果抽象方法不实现,就会变成抽象类 含接口

  包括抽象方法的类是抽象类

  抽象类 没有抽象的方法

  static final private 不能与 abstract 并存

offer Java基础精选从编译到集合_后端_46 style=

 

访问private成员的类外使用对象名不能访问

offer Java基础精选从编译到集合_Java_47

  接口中的 final 在定义时需要初始化

  接口成员属性 默认是 public static final 成员属性名 = 赋值

  接口静态常量可通过 接口名 或者 接口变量名 调用

  INet.TEMP

  inet.TEMP

  可通过TEMP直接调用实现类

  public class ImplementsClass implements INet{

  {

  System.out.println(TEMP);

  }

  }

  在实现类实例化时,可以通过对象名.TEMP调用

  ImplementsClass implementsClass;

  implementsClass.TEMP;

  接口中的静态属性可以实现类继承 因为这是继承父类的时候了 同样的调用方法

  没有重写属性的说法

  静态方法不能重写

  抽象方法只能重写

  不重写必须将子类定义为抽象类 继承下去

  默认接口方法可以带来方法 用 default 修饰

  接口静态方法可以带来方法

  默认方法可以被子类重写

  INet.super.connection(); 调用接口默认方法

  接口中的默认方法可以继承

  可采用接口静态法 接口名称。静态方法名称调用

  INet.stop(); 调用接口中的静态方法 父类也可以

  静态方法不能通过界面的变量名调用 而父类可以

  接口不能通过实现对象名调用 父类可以通过子类对象名调用

  在实现类中,接口中的静态方法名不能直接调用到接口中 在子类中,父类可以通过父类的静态方法名直接调用

  接口中的静态方法 类别不能实现 和子接口 继承

  一个类实现两个接口默认同名的方法

  该类别需要重写默认同名的方法 否则报错

  重写后调用类重写

  父亲成员的默认方法与两个接口同名

  子类不需要重写调用 父类成员的方法

  调用父亲成员的方法

  如果子类重写了该方法,则调用子类方法

  子类继承父类和实现两个界面都定义了同名静态成员属性的常量

  同名静态成员属性常量名直接访问

  当子类只继承一个父类时,可以直接调用父类的静态成员属性常量

  实现单接口的子类也可以直接调用静态成员属性常量

  同名静态成员属性常量名只能在子类中重写

  调用父类和两个接口的同名静态成员属性常量,多种方式失效。

  一个子接口继承两个父接口有同名的默认方法

  同名的默认方法需要重写子接口 单个就不用

  成员内部类 普通内部类

offer Java基础精选从编译到集合_后端_48

  在外部类方法内访问内部类别

  {

  new Heart().temp = 12;

  }

  内部类实例化

  Person.Heart myHeart = new Person().new Heart();

  Person lili = new Person();

  Person.Heart myHeart2 = lili.new Heart();

  lili.getHeart();(在getheart方法中 return new 内部类名();)

  如果出现相同的名字,可以直接在内部调用父类成员(直接使用名称),访问内部类

  Person.this.age 直接访问外部类

  public class outerClass{

  int age;

  public class innerClass{

  public void method(){

  System.out.println(age);外部类

  }

  }

  public class innerClass{

  int age;

  public void method(){

  System.out.println(age);内部类

  System.out.println(Person.this.age);外部类

  }

  }

  }

offer Java基础精选从编译到集合_子类_49

  offer Java基础精选从编译到集合

  静态内部类

  new Person().eat() 静态内部类访问外部类非静态成员 必须采用实例化的方式

  Person.age 访问外部静态成员的静态成员

  静态内部类访问静态内部类的实例成员不需要静态修改 需要外部访问

offer Java基础精选从编译到集合_父类_50

offer Java基础精选从编译到集合_子类_51

  在外部方法内访问静态内部类

  {

  new Heart().temp = 12;(在外部方法内)

  }

  Person.Heart myHeart = new Person.Heart();

  Person.Heart myHeart2 = new Person().getHeart(); 外部方法 return new Heart();

  Person.Heart.say();访问静态内部静态成员的方法

  方法内部类 局部内部类

  staticcccticcc类不能定义 访问修饰符不能使用

  classs在外部类方法中定义 关键字

  可以使用 abstract final

offer Java基础精选从编译到集合_父类_52

  public Object getHeart() {

  abstract/final class Heart {

  public String beat() {

  new Person().eat();

  return Person.age;

  }

  }

  return new Heart().beat();

  }

  Person lili = new Person();

  lili.getHeart(); Object中的方法只能使用

offer Java基础精选从编译到集合_后端_53

  匿名内部类

offer Java基础精选从编译到集合_构造方法_54

  结构方法不能使用

  构造代码块可以使用

  静态成员不能使用

  匿名内部类是在定义中使用的方法参数

  这种方法需要在外部main方法中调用

  在jdk7需要finall之前,需要final

  jdk8后匿名内部类访问外部局部变量不需要使用finall 但是匿名内部类内部不能改变

offer Java基础精选从编译到集合_构造方法_55

  peopletest1.getRead(new Person(){

  {

  // 构造代码块

  }

  @Override

  public void reat(){

  System.out.println(“男生喜欢看科幻书”);

  }

  });

offer Java基础精选从编译到集合_Java_56

offer Java基础精选从编译到集合_Java_57

offer Java基础精选从编译到集合_后端_58

offer Java基础精选从编译到集合_Java_59

offer Java基础精选从编译到集合_父类_60

  finally不能执行。

  finally 有return 只会回到finally

  当 try 或者在cache中,returnn

  finally没有returnn 遇见return finally中的代码块将首先执行 后执行 try returnnn在cache中

  多个,

offer Java基础精选从编译到集合_后端_61

  两个异常抛出 A I 无法捕获到 因为这里 Exception抛出 需要捕获为抛出的类别 或者父类 不能是兄弟 子类

  public int test(){

  throw new Exception();

  }

offer Java基础精选从编译到集合_子类_62

offer Java基础精选从编译到集合_子类_63

  throw new的类 在throws

  只能是throw new的父类不能是兄弟类

  不能是子类

  Throwable是Exception的父类

offer Java基础精选从编译到集合_父类_64

offer Java基础精选从编译到集合_Java_65

offer Java基础精选从编译到集合_Java_66

  throws只能是父类或相同类型,即本类

offer Java基础精选从编译到集合_构造方法_67

  自定义异常 继承Exception

  使用抛出的异常方法 throw new 自定义异常 类

  使用自定义捕获异常的异常类别

  e.getMessage() 获得自定义异常错误信息 Exception 以上的父类 方法

  异常链

  public static void main(args){

  在main方法中调用异常尾部的最后一种方法

  捕获异常

  打印所有异常信息

  }

  第一种方法是抛出自定义异常

  第一种方法被第二种方法调用 捕获到异常

  抛出新的异常

  throw new Exception(异常信息”,e);

  第三种方法调用第二种方法捕获 到异常

  抛出新的异常

  Exception e1 = new Exception(异常信息);

  e1.initCause(e);

  throw e1

  异常重写问题

  异常是自定义异常 继承 Exception

  父类的方法 throws 自定义异常

  父类的方法是扔出去 throw 自定义异常

  子类重写

  方法 throws 自定义异常 本类

  方法 throws 继承Exception的子类 也就是自定义异常的兄弟类

  方法 throws 继承自定义异常子类

  throwss方法重写 必须是兄弟(继承同一个父亲)或者这个类别 或者子类 不能是父类

offer Java基础精选从编译到集合_父类_69

  对象常量池

  int t1 = 5;

  Integer t2 = t1; 自动装箱 通过赋值直接使用 -128<=值<=127 隐式调用了 Integer.valueOf(); 不在这个范围内 否则,new将被隐式调用

  Integer t3 = new Integer(t1); 手动装箱 通过 new 的方式

  int t4 = t2; 自动拆箱 通过赋值直接使用

  int t5 = t2.intValue(); 手动拆箱通过调用手动拆箱完成

  double t6 = t2.dobuleValue(); double类型的手动拆箱

  int t1 = 2;

  String t2 = Integer.toString(t1); 整形转换 String

  int t3 = Integer.paseInt(t2) 将字符串转换为整形手术

  int t4 = Integer.valueOf(t2) 字符串转换为包装Integer 然后自动拆箱 整形

  -128<=值<=127

offer Java基础精选从编译到集合_父类_70

offer Java基础精选从编译到集合_Java_71

offer Java基础精选从编译到集合_子类_72

  indexOf(int)

  indexOf(String)

  lastIndexOf(int)

  lastIndexOf(String)

  indexOf(String,int)

  getBytes()

  new String(Byte[],String(字符集)

offer Java基础精选从编译到集合_后端_73

offer Java基础精选从编译到集合_Java_74

offer Java基础精选从编译到集合_构造方法_75

  字符串的 equals 比较内容

  = 相比之下,引用是否相等

  每次更改字符串的内容 都会创造新的对象 原对象不变

  String s = ""; 这种定义方法将放在常量池上

  new String(); 定义堆上

  每次修改在堆上创建新的字符串对象

  StringBuffer 线程安全

  StringBuilder 性能高

  默认字符容量 16

  StringBuilder 每次在自己的堆上改变 具有可变性

offer Java基础精选从编译到集合_Java_76

offer Java基础精选从编译到集合_父类_77

  append(char)

  append(String) 添加字符串

  delete(int,int) 删除字符串

  replace(int,int,String) 在指定 位置修改字符串

  subString(int,int)

  Stringbuilder经常操作 使用Stringg操作简单

  Math.random() 返回[0,1)

  Math.random()*10 返回[0,10)

  Math.random()*10+1返回[1,11)

  int(Math.random()*10+1) 返回整数

  Scanner sc = new Scanner(Systam.in);

  sc.netxt();

  数组.length

  Set表示集

  ArrayList数组序列 数组长度动态增长

  LinkedList链表

  Hashset哈希集

  Hashmap哈希表

offer Java基础精选从编译到集合_子类_78

  list 可重复的有序顺序

  ArrayList 底层是动态数组

  优点

  尾部添加 或 删除数据 效率高

  适用于搜索和修改

  元素可以是null

  初始容量为10个元素

  add(Object) 添加元素

  add(int,Object) 从第 int条 后面添加元素

  size() 长度

  get(int) 查询元素

  remove(int)删除元素

  set(int,Object) 从 第int条 替换元素

  Date 类

  new Date() 返回当前时间

  开源笔记

  可 Pull Requests 合作写开源笔记

  如果笔记图片无法访问 请访问 teambition 原始开源笔记