Javascript 设计模式零碎解说与利用
百度网盘链接
Java 基础常见学识点 & 面试题总结
面向对象基础
面向对象和面向过程的区别
两者的次要区别在于解决问题的形式不同:
面向过程把解决问题的过程拆成一个个方法,通过一个个方法的执行解决问题。
面向对象会先抽象出对象,而后用对象执行方法的形式解决问题。
另外,面向对象开发的程序一般更易保护、易复用、易扩大。
相干 issue : 面向过程:面向过程性能比面向对象高??
成员变量与局部变量的区别
语法形式:从语法形式上看,成员变量是属于类的,而局部变量是在代码块或方法中定义的变量或是方法的参数;成员变量可能被 public,private,static 等修饰符所润饰,而局部变量不能被访问控制修饰符及 static 所润饰;然而,成员变量和局部变量都能被 final 所润饰。
存储形式:从变量在内存中的存储形式来看, 如果成员变量是使用 static 润饰的,那么这个成员变量是属于类的,如果没有使用 static 润饰,这个成员变量是属于实例的。而对象存在于堆内存,局部变量则存在于栈内存。
生存工夫:从变量在内存中的生存工夫上看,成员变量是对象的一部分,它随着对象的创建而存在,而局部变量随着方法的调用而主动生成,随着方法的调用结束而沦亡。
默认值:从变量是否有默认值来看,成员变量如果没有被赋初始值,则会主动以类型的默认值而赋值(一种情况例外: 被 final 润饰的成员变量也必须显式地赋值),而局部变量则不会主动赋值。
创建一个对象用什么运算符? 对象实体与对象引用有何不同?
new 运算符,new 创建对象实例(对象实例在堆内存中),对象引用指向对象实例(对象引用存放在栈内存中)。
一个对象引用可能指向 0 个或 1 个对象(一根绳子可能不系气球,也可能系一个气球); 一个对象可能有 n 个引用指向它(可能用 n 条绳子系住一个气球)。
对象的相等和引用相等的区别
对象的相等一般比较的是内存中存放的内容是否相等。
引用相等一般比较的是他们指向的内存地址是否相等。
类的构造方法的作用是什么?
构造方法是一种非凡的方法,次要作用是实现对象的初始化工作。
如果一个类没有申明构造方法,该程序能正确执行吗?
如果一个类没有申明构造方法,也可能执行!因为一个类即使没有申明构造方法也会有默认的不带参数的构造方法。如果咱们自己增加了类的构造方法(无论是否有参),Java 就不会再增加默认的无参数的构造方法了,咱们一直在人不知; 鬼不觉地使用构造方法,这也是为什么咱们在创建对象的时候前面要加一个括号(因为要调用无参的构造方法)。如果咱们重载了有参的构造方法,记得都要把无参的构造方法也写进去(无论是否用到),因为这可能帮助咱们在创建对象的时候少踩坑。
构造方法有哪些个性?是否可被 override?
构造方法个性如下:
名字与类名雷同。
没有返回值,但不能用 void 申明结构函数。
生成类的对象时主动执行,无需调用。
构造方法不能被 override(重写), 然而可能 overload(重载), 所以你可能看到一个类中有多个结构函数的情况。
面向对象三大特色
封装
封装是指把一个对象的状态信息(也就是属性)躲藏在对象外部,不容许内部对象间接拜访对象的外部信息。然而可能提供一些可能被外界拜访的方法来操作属性。就好像咱们看不到挂在墙上的空调的外部的整机信息(也就是属性),然而可能通过遥控器(方法)来管制空调。如果属性不想被外界拜访,咱们大可不必提供方法给外界拜访。然而如果一个类没有提供应外界拜访的方法,那么这个类也没有什么意义了。就好像如果没有空调遥控器,那么咱们就无奈操控空凋制冷,空调本身就没有意义了(当然现在还有很多其余方法,这里只是为了举例子)。
public class Student {
private int id;//id 属性私有化
private String name;//name 属性私有化
// 获取 id 的方法
public int getId() {return id;}
// 设置 id 的方法
public void setId(int id) {this.id = id;}
// 获取 name 的方法
public String getName() {return name;}
// 设置 name 的方法
public void setName(String name) {this.name = name;}
}
复制代码
继承
不同类型的对象,相互之间常常有肯定数量的共同点。例如,小明同学、小红同学、小李同学,都共享学生的个性(班级、学号等)。同时,每一个对象还定义了额定的个性使得他们不同凡响。例如小明的数学比较好,小红的性情惹人喜爱;小李的力量比较大。继承是使用已存在的类的定义作为基础建立新类的技术,新类的定义可能减少新的数据或新的功能,也可能用父类的功能,但不能选择性地继承父类。通过使用继承,可能疾速地创建新的类,可能提高代码的重用,程序的可维护性,俭约大量创建新类的工夫,提高咱们的开发效率。
对于继承如下 3 点请记住:
子类具备父类对象所有的属性和方法(包含公有属性和公有方法),然而父类中的公有属性和方法子类是无法访问,只是具备。
子类可能具备自己属性和方法,即子类可能对父类进行扩大。
子类可能用自己的形式实现父类的方法。(当前介绍)。
多态
多态,顾名思义,示意一个对象具备多种的状态,具体体现为父类的引用指向子类的实例。
多态的个性:
对象类型和引用类型之间具备继承(类)/ 实现(接口)的关系;
引用类型变量收回的方法调用的到底是哪个类中的方法,必须在程序运行期间才能必定;
多态不能调用“只在子类存在但在父类不存在”的方法;
如果子类重写了父类的方法,真正执行的是子类覆盖的方法,如果子类没有覆盖父类的方法,执行的是父类的方法。
接口和抽象类有什么共同点和区别?
共同点:
都不能被实例化。
都可能蕴含抽象方法。
都可能有默认实现的方法(Java 8 可能用 default 关键字在接口中定义默认方法)。
区别:
接口次要用于对类的行为进行束缚,你实现了某个接口就具备了对应的行为。抽象类次要用于代码复用,强调的是所属关系(比方说咱们抽象了一个发送短信的抽象类,)。
一个类只能继承一个类,然而可能实现多个接口。
接口中的成员变量只能是 public static final 类型的,不能被修改且必须有初始值,而抽象类的成员变量默认 default,可在子类中被从新定义,也可被从新赋值。
深拷贝和浅拷贝区别了解吗?什么是引用拷贝?
对于深拷贝和浅拷贝区别,我这里先给论断:
浅拷贝:浅拷贝会在堆上创建一个新的对象(区别于引用拷贝的一点),不过,如果原对象外部的属性是引用类型的话,浅拷贝会间接复制外部对象的引用地址,也就是说拷贝对象和原对象共用同一个外部对象。
深拷贝:深拷贝会残缺复制整个对象,包含这个对象所蕴含的外部对象。
下面的论断没有残缺理解的话也没关系,咱们来看一个具体的案例!
浅拷贝
浅拷贝的示例代码如下,咱们这里实现了 Cloneable 接口,并重写了 clone() 方法。
clone() 方法的实现很简略,间接调用的是父类 Object 的 clone() 方法。
public class Address implements Cloneable{
private String name;
// 省略结构函数、Getter&Setter 方法
@Override
public Address clone() {
try {return (Address) super.clone();} catch (CloneNotSupportedException e) {throw new AssertionError();
}
}
}
public class Person implements Cloneable {
private Address address;
// 省略结构函数、Getter&Setter 方法
@Override
public Person clone() {
try {Person person = (Person) super.clone();
return person;
} catch (CloneNotSupportedException e) {throw new AssertionError();
}
}
}
复制代码
测试:
Person person1 = new Person(new Address(“ 武汉 ”));
Person person1Copy = person1.clone();
// true
System.out.println(person1.getAddress() == person1Copy.getAddress());
复制代码
从输入结构就可能看出,person1 的克隆对象和 person1 使用的仍然是同一个 Address 对象。
深拷贝
这里咱们简略对 Person 类的 clone() 方法进行修改,连带着要把 Person 对象外部的 Address 对象一起复制。
@Override
public Person clone() {
try {Person person = (Person) super.clone();
person.setAddress(person.getAddress().clone());
return person;
} catch (CloneNotSupportedException e) {throw new AssertionError();
}
}
复制代码
测试:
Person person1 = new Person(new Address(“ 武汉 ”));
Person person1Copy = person1.clone();
// false
System.out.println(person1.getAddress() == person1Copy.getAddress());
复制代码
从输入结构就可能看出,诚然 person1 的克隆对象和 person1 蕴含的 Address 对象已经是不同的了。