@@ -197,7 +197,38 @@ System.out.println(person1.getAddress() == person1Copy.getAddress());
197197
198198## Java 常见对象
199199
200- ### String、StringBuffer、StringBuilder的区别?String 为什么是不可变的?
200+ ### Object
201+
202+ #### Object 类的常见方法有哪些?
203+
204+ Object 类是一个特殊的类,是所有类的父类。它主要提供了以下 11 个方法:
205+
206+ ``` java
207+ public final native Class<?> getClass()// native方法,用于返回当前运行时对象的Class对象,使用了final关键字修饰,故不允许子类重写。
208+
209+ public native int hashCode() // native方法,用于返回对象的哈希码,主要使用在哈希表中,比如JDK中的HashMap。
210+ public boolean equals(Object obj)// 用于比较2个对象的内存地址是否相等,String类对该方法进行了重写用户比较字符串的值是否相等。
211+
212+ protected native Object clone() throws CloneNotSupportedException // naitive方法,用于创建并返回当前对象的一份拷贝。一般情况下,对于任何对象 x,表达式 x.clone() != x 为true,x.clone().getClass() == x.getClass() 为true。Object本身没有实现Cloneable接口,所以不重写clone方法并且进行调用的话会发生CloneNotSupportedException异常。
213+
214+ public String toString()// 返回类的名字@实例的哈希码的16进制的字符串。建议Object所有的子类都重写这个方法。
215+
216+ public final native void notify()// native方法,并且不能重写。唤醒一个在此对象监视器上等待的线程(监视器相当于就是锁的概念)。如果有多个线程在等待只会任意唤醒一个。
217+
218+ public final native void notifyAll()// native方法,并且不能重写。跟notify一样,唯一的区别就是会唤醒在此对象监视器上等待的所有线程,而不是一个线程。
219+
220+ public final native void wait(long timeout) throws InterruptedException // native方法,并且不能重写。暂停线程的执行。注意:sleep方法没有释放锁,而wait方法释放了锁 。timeout是等待时间。
221+
222+ public final void wait(long timeout, int nanos) throws InterruptedException // 多了nanos参数,这个参数表示额外时间(以毫微秒为单位,范围是 0-999999)。 所以超时的时间还需要加上nanos毫秒。
223+
224+ public final void wait() throws InterruptedException // 跟之前的2个wait方法一样,只不过该方法一直等待,没有超时时间这个概念
225+
226+ protected void finalize() throws Throwable { }// 实例被垃圾回收器回收的时候触发的操作
227+ ```
228+
229+ ### String
230+
231+ #### String、StringBuffer、StringBuilder 的区别?String 为什么是不可变的?
201232
202233** 可变性**
203234
@@ -253,48 +284,52 @@ abstract class AbstractStringBuilder implements Appendable, CharSequence {
2532842 . 单线程操作字符串缓冲区下操作大量数据: 适用 ` StringBuilder `
2542853 . 多线程操作字符串缓冲区下操作大量数据: 适用 ` StringBuffer `
255286
256- ### String#equals() 和 Object#equals() 有何区别?
257-
258- ` String ` 中的 ` equals ` 方法是被重写过的,比较的是String 字符串的值是否相等。 ` Object ` 的 ` equals ` 方法是比较的对象的内存地址。
287+ #### 字符串拼接用“+” 还是 StringBuilder?
259288
260- ### 字符串常量池的作用了解吗?
261-
262- ** 字符串常量池** 是 JVM 为了提升性能和减少内存消耗针为字符串(String 类)专门开辟的一块区域,主要目的是为了避免字符串的重复创建。
289+ Java 语言本身并不支持运算符重载,“+”和“+=”是专门为 String 类重载过的运算符,也是 Java 中仅有的两个重载过的元素符。
263290
264291``` java
265- String aa = " ab" ; // 放在常量池中
266- String bb = " ab" ; // 从常量池中查找
267- System . out. println(aa== bb);// true
292+ String str1 = " he" ;
293+ String str2 = " llo" ;
294+ String str3 = " world" ;
295+ String str4 = str1 + str2 + str3;
268296```
269297
270- JDK1.7 之前运行时常量池逻辑包含字符串常量池存放在方法区。JDK1.7 的时候,字符串常量池被从方法区拿到了堆中。
271-
272- 你可以在JVM 部分找到更多关于字符串常量池的介绍。
298+ 对象引用和“+”的字符串拼接方式,实际上是通过 ` StringBuilder ` 调用 ` append() ` 方法实现的,拼接完成之后调用 ` toString() ` 得到一个 ` String ` 对象 。
273299
274- ### Object 类的常见方法有哪些?
300+ ![ ] ( https://guide-blog-images.oss-cn-shenzhen.aliyuncs.com/touzi/image-20220131173604062.png )
275301
276- Object 类是一个特殊的类,是所有类的父类。它主要提供了以下 11 个方法:
302+ 不过,在循环内使用“+”进行字符串的拼接的话,存在比较明显的缺陷: ** 编译器不会创建单个 ` StringBuilder ` 以复用,会导致创建过多的 ` StringBuilder ` 对象 ** 。
277303
278304``` java
279- public final native Class<?> getClass()// native方法,用于返回当前运行时对象的Class对象,使用了final关键字修饰,故不允许子类重写。
305+ String [] arr = {" he" , " llo" , " world" };
306+ String s = " " ;
307+ for (int i = 0 ; i < arr. length; i++ ) {
308+ s += arr[i];
309+ }
310+ System . out. println(s);
311+ ```
280312
281- public native int hashCode() // native方法,用于返回对象的哈希码,主要使用在哈希表中,比如JDK中的HashMap。
282- public boolean equals(Object obj)// 用于比较2个对象的内存地址是否相等,String类对该方法进行了重写用户比较字符串的值是否相等。
313+ ` StringBuilder ` 对象是在循环内部被创建的,这意味着每循环一次就会创建一个 ` StringBuilder ` 对象。
283314
284- protected native Object clone() throws CloneNotSupportedException // naitive方法,用于创建并返回当前对象的一份拷贝。一般情况下,对于任何对象 x,表达式 x.clone() != x 为true,x.clone().getClass() == x.getClass() 为true。Object本身没有实现Cloneable接口,所以不重写clone方法并且进行调用的话会发生CloneNotSupportedException异常。
315+ ![ ] ( https://guide-blog-images.oss-cn-shenzhen.aliyuncs.com/touzi/image-20220131175013108.png )
285316
286- public String toString() // 返回类的名字@实例的哈希码的16进制的字符串。建议Object所有的子类都重写这个方法 。
317+ 如果直接使用 ` StringBuilder ` 对象进行字符串拼接的话,就不会存在这个问题了 。
287318
288- public final native void notify() // native方法,并且不能重写。唤醒一个在此对象监视器上等待的线程(监视器相当于就是锁的概念)。如果有多个线程在等待只会任意唤醒一个。
319+ #### String#equals() 和 Object#equals() 有何区别?
289320
290- public final native void notifyAll() // native方法,并且不能重写。跟notify一样,唯一的区别就是会唤醒在此对象监视器上等待的所有线程,而不是一个线程 。
321+ ` String ` 中的 ` equals ` 方法是被重写过的,比较的是 String 字符串的值是否相等。 ` Object ` 的 ` equals ` 方法是比较的对象的内存地址 。
291322
292- public final native void wait( long timeout) throws InterruptedException // native方法,并且不能重写。暂停线程的执行。注意:sleep方法没有释放锁,而wait方法释放了锁 。timeout是等待时间。
323+ #### 字符串常量池的作用了解吗?
293324
294- public final void wait(long timeout, int nanos) throws InterruptedException // 多了nanos参数,这个参数表示额外时间(以毫微秒为单位,范围是 0-999999)。 所以超时的时间还需要加上nanos毫秒。
295-
296- public final void wait() throws InterruptedException // 跟之前的2个wait方法一样,只不过该方法一直等待,没有超时时间这个概念
325+ ** 字符串常量池** 是 JVM 为了提升性能和减少内存消耗针为字符串(String 类)专门开辟的一块区域,主要目的是为了避免字符串的重复创建。
297326
298- protected void finalize() throws Throwable { }// 实例被垃圾回收器回收的时候触发的操作
327+ ``` java
328+ String aa = " ab" ; // 放在常量池中
329+ String bb = " ab" ; // 从常量池中查找
330+ System . out. println(aa== bb);// true
299331```
300332
333+ JDK1.7 之前运行时常量池逻辑包含字符串常量池存放在方法区。JDK1.7 的时候,字符串常量池被从方法区拿到了堆中。
334+
335+ 你可以在 JVM 部分找到更多关于字符串常量池的介绍。
0 commit comments