Skip to content

Commit 2b24867

Browse files
authored
Merge pull request Snailclimb#925 from shellhub/dev
Fixed typo and added features
2 parents 82d037d + 03e82e0 commit 2b24867

File tree

3 files changed

+59
-32
lines changed

3 files changed

+59
-32
lines changed

docs/java/Java疑难点.md

Lines changed: 37 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -52,9 +52,9 @@ Objects.equals(null,"SnailClimb");// false
5252
我们看一下`java.util.Objects#equals`的源码就知道原因了。
5353
```java
5454
public static boolean equals(Object a, Object b) {
55-
// 可以避免空指针异常。如果a==null的话此时a.equals(b)就不会得到执行,避免出现空指针异常。
56-
return (a == b) || (a != null && a.equals(b));
57-
}
55+
// 可以避免空指针异常。如果a==null的话此时a.equals(b)就不会得到执行,避免出现空指针异常。
56+
return (a == b) || (a != null && a.equals(b));
57+
}
5858
```
5959

6060
**注意:**
@@ -104,14 +104,18 @@ System.out.println(a == b);// false
104104
BigDecimal a = new BigDecimal("1.0");
105105
BigDecimal b = new BigDecimal("0.9");
106106
BigDecimal c = new BigDecimal("0.8");
107-
BigDecimal x = a.subtract(b);// 0.1
108-
BigDecimal y = b.subtract(c);// 0.1
109-
System.out.println(x.equals(y));// true
107+
108+
BigDecimal x = a.subtract(b);
109+
BigDecimal y = b.subtract(c);
110+
111+
System.out.println(x); /* 0.1 */
112+
System.out.println(y); /* 0.1 */
113+
System.out.println(Objects.equals(x, y)); /* true */
110114
```
111115

112116
### 1.3.2. BigDecimal 的大小比较
113117

114-
`a.compareTo(b)` : 返回 -1 表示小于,0 表示 等于, 1表示 大于
118+
`a.compareTo(b)` : 返回 -1 表示 `a` 小于 `b`,0 表示 `a` 等于 `b` , 1表示 `a` 大于 `b`
115119

116120
```java
117121
BigDecimal a = new BigDecimal("1.0");
@@ -167,7 +171,7 @@ Reference:《阿里巴巴Java开发手册》
167171
`Arrays.asList()`在平时开发中还是比较常见的,我们可以使用它将一个数组转换为一个List集合。
168172

169173
```java
170-
String[] myArray = { "Apple", "Banana", "Orange" };
174+
String[] myArray = {"Apple", "Banana", "Orange"};
171175
List<String> myList = Arrays.asList(myArray);
172176
//上面两个语句等价于下面一条语句
173177
List<String> myList = Arrays.asList("Apple","Banana", "Orange");
@@ -177,8 +181,9 @@ JDK 源码对于这个方法的说明:
177181

178182
```java
179183
/**
180-
*返回由指定数组支持的固定大小的列表。此方法作为基于数组和基于集合的API之间的桥梁,与 Collection.toArray()结合使用。返回的List是可序列化并实现RandomAccess接口。
181-
*/
184+
*返回由指定数组支持的固定大小的列表。此方法作为基于数组和基于集合的API之间的桥梁,
185+
* 与 Collection.toArray()结合使用。返回的List是可序列化并实现RandomAccess接口。
186+
*/
182187
public static <T> List<T> asList(T... a) {
183188
return new ArrayList<>(a);
184189
}
@@ -197,20 +202,20 @@ public static <T> List<T> asList(T... a) {
197202
`Arrays.asList()`是泛型方法,传入的对象必须是对象数组。
198203

199204
```java
200-
int[] myArray = { 1, 2, 3 };
205+
int[] myArray = {1, 2, 3};
201206
List myList = Arrays.asList(myArray);
202207
System.out.println(myList.size());//1
203208
System.out.println(myList.get(0));//数组地址值
204209
System.out.println(myList.get(1));//报错:ArrayIndexOutOfBoundsException
205-
int [] array=(int[]) myList.get(0);
210+
int[] array = (int[]) myList.get(0);
206211
System.out.println(array[0]);//1
207212
```
208213
当传入一个原生数据类型数组时,`Arrays.asList()` 的真正得到的参数就不是数组中的元素,而是数组对象本身!此时List 的唯一元素就是这个数组,这也就解释了上面的代码。
209214

210215
我们使用包装类型数组就可以解决这个问题。
211216

212217
```java
213-
Integer[] myArray = { 1, 2, 3 };
218+
Integer[] myArray = {1, 2, 3};
214219
```
215220

216221
**使用集合的修改方法:`add()``remove()``clear()`会抛出异常。**
@@ -296,7 +301,7 @@ static <T> List<T> arrayToList(final T[] array) {
296301
for (final T s : array) {
297302
l.add(s);
298303
}
299-
return (l);
304+
return l;
300305
}
301306
```
302307

@@ -344,6 +349,14 @@ List<String> list = new ArrayList<String>();
344349
CollectionUtils.addAll(list, str);
345350
```
346351

352+
**6. 使用 Java9 的 `List.of()`方法**
353+
``` java
354+
Integer[] array = {1, 2, 3};
355+
List<Integer> list = List.of(array);
356+
System.out.println(list); /* [1, 2, 3] */
357+
/* 不支持基本数据类型 */
358+
```
359+
347360
## 2.2. Collection.toArray()方法使用的坑&如何反转数组
348361

349362
该方法是一个泛型方法:`<T> T[] toArray(T[] a);` 如果`toArray`方法中没有传递任何参数的话返回的是`Object`类型数组。
@@ -365,6 +378,16 @@ s=list.toArray(new String[0]);//没有指定类型的话会报错
365378

366379
> **fail-fast 机制** :多个线程对 fail-fast 集合进行修改的时,可能会抛出ConcurrentModificationException,单线程下也会出现这种情况,上面已经提到过。
367380
381+
Java8开始,可以使用`Collection#removeIf()`方法删除满足特定条件的元素,如
382+
``` java
383+
List<Integer> list = new ArrayList<>();
384+
for (int i = 1; i <= 10; ++i) {
385+
list.add(i);
386+
}
387+
list.removeIf(filter -> filter % 2 == 0); /* 删除list中的所有偶数 */
388+
System.out.println(list); /* [1, 3, 5, 7, 9] */
389+
```
390+
368391
`java.util`包下面的所有的集合类都是fail-fast的,而`java.util.concurrent`包下面的所有的类都是fail-safe的。
369392

370393
![不要在 foreach 循环里进行元素的 remove/add 操作](https://my-blog-to-use.oss-cn-beijing.aliyuncs.com/2019/7/foreach-remove:add.png)

docs/java/basic/final,static,this,super.md

Lines changed: 13 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -92,7 +92,7 @@ public class Sub extends Super {
9292

9393
**使用 this 和 super 要注意的问题:**
9494

95-
- 在构造器中使用 `super()` 调用父类中的其他构造方法时,该语句必须处于构造器的首行,否则编译器会报错。另外,this 调用本类中的其他构造方法时,也要放在首行。
95+
- 在构造器中使用 `super()` 调用父类中的其他构造方法时,该语句必须处于构造器的首行,否则编译器会报错。另外,this 调用本类中的其他构造方法时,也要放在首行。
9696
- this、super不能用在static方法中。
9797

9898
**简单解释一下:**
@@ -141,7 +141,7 @@ public class StaticBean {
141141
this.name = name;
142142
}
143143
//静态方法
144-
static void SayHello() {
144+
static void sayHello() {
145145
System.out.println("Hello i am java");
146146
}
147147
@Override
@@ -164,7 +164,7 @@ public class StaticDemo {
164164
StaticBean.age = 33;
165165
System.out.println(staticBean + " " + staticBean2 + " " + staticBean3 + " " + staticBean4);
166166
//StaticBean{name=1,age=33} StaticBean{name=2,age=33} StaticBean{name=3,age=33} StaticBean{name=4,age=33}
167-
StaticBean.SayHello();//Hello i am java
167+
StaticBean.sayHello();//Hello i am java
168168
}
169169

170170
}
@@ -173,7 +173,7 @@ public class StaticDemo {
173173

174174
### 静态代码块
175175

176-
静态代码块定义在类中方法外, 静态代码块在非静态代码块之前执行(静态代码块非静态代码块构造方法)。 该类不管创建多少对象,静态代码块只执行一次.
176+
静态代码块定义在类中方法外, 静态代码块在非静态代码块之前执行(静态代码块 —> 非静态代码块 —> 构造方法)。 该类不管创建多少对象,静态代码块只执行一次.
177177

178178
静态代码块的格式是
179179

@@ -274,7 +274,11 @@ class Foo {
274274

275275
}
276276
```
277-
你可以像这样调用静态方法:`Foo.method1()`。 如果您尝试使用这种方法调用 method2 将失败。 但这样可行:`Foo bar = new Foo(1);bar.method2();`
277+
你可以像这样调用静态方法:`Foo.method1()`。 如果您尝试使用这种方法调用 method2 将失败。 但这样可行
278+
``` java
279+
Foo bar = new Foo(1);
280+
bar.method2();
281+
```
278282

279283
总结:
280284

@@ -285,7 +289,7 @@ class Foo {
285289

286290
相同点: 都是在JVM加载类时且在构造方法执行之前执行,在类中都可以定义多个,定义多个时按定义的顺序执行,一般在代码块中对一些static变量进行赋值。
287291

288-
不同点: 静态代码块在非静态代码块之前执行(静态代码块非静态代码块构造方法)。静态代码块只在第一次new执行一次,之后不再执行,而非静态代码块在每new一次就执行一次。 非静态代码块可在普通方法中定义(不过作用不大);而静态代码块不行。
292+
不同点: 静态代码块在非静态代码块之前执行(静态代码块 -> 非静态代码块 -> 构造方法)。静态代码块只在第一次new执行一次,之后不再执行,而非静态代码块在每new一次就执行一次。 非静态代码块可在普通方法中定义(不过作用不大);而静态代码块不行。
289293

290294
> 修正 [issue #677](https://github.com/Snailclimb/JavaGuide/issues/677):静态代码块可能在第一次new的时候执行,但不一定只在第一次new的时候执行。比如通过 `Class.forName("ClassDemo")`创建 Class 对象的时候也会执行。
291295
@@ -347,6 +351,6 @@ public class Test {
347351

348352
### 参考
349353

350-
- httpsblog.csdn.netchen13579867831articledetails78995480
351-
- httpwww.cnblogs.comchenssyp3388487.html
352-
- httpwww.cnblogs.comQian123p5713440.html
354+
- https://blog.csdn.net/chen13579867831/article/details/78995480
355+
- https://www.cnblogs.com/chenssy/p/3388487.html
356+
- https://www.cnblogs.com/Qian123/p/5713440.html

docs/java/basic/用好Java中的枚举真的没有那么简单.md

Lines changed: 9 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -51,10 +51,7 @@ public class Pizza {
5151
}
5252

5353
public boolean isDeliverable() {
54-
if (getStatus() == PizzaStatus.READY) {
55-
return true;
56-
}
57-
return false;
54+
return getStatus() == PizzaStatus.READY;
5855
}
5956

6057
// Methods that set and get the status variable.
@@ -63,9 +60,9 @@ public class Pizza {
6360

6461
## 3.使用 == 比较枚举类型
6562

66-
由于枚举类型确保JVM中仅存在一个常量实例,因此我们可以安全地使用“ ==”运算符比较两个变量,如上例所示;此外,“ ==”运算符可提供编译时和运行时的安全性。
63+
由于枚举类型确保JVM中仅存在一个常量实例,因此我们可以安全地使用 `==` 运算符比较两个变量,如上例所示;此外,`==` 运算符可提供编译时和运行时的安全性。
6764

68-
首先,让我们看一下以下代码段中的运行时安全性,其中“ ==”运算符用于比较状态,并且如果两个值均为null 都不会引发 NullPointerException。相反,如果使用equals方法,将抛出 NullPointerException:
65+
首先,让我们看一下以下代码段中的运行时安全性,其中 `==` 运算符用于比较状态,并且如果两个值均为null 都不会引发 NullPointerException。相反,如果使用equals方法,将抛出 NullPointerException:
6966

7067
```java
7168
if(testPz.getStatus().equals(Pizza.PizzaStatus.DELIVERED));
@@ -84,9 +81,12 @@ if(testPz.getStatus() == TestColor.GREEN);
8481
```java
8582
public int getDeliveryTimeInDays() {
8683
switch (status) {
87-
case ORDERED: return 5;
88-
case READY: return 2;
89-
case DELIVERED: return 0;
84+
case ORDERED:
85+
return 5;
86+
case READY:
87+
return 2;
88+
case DELIVERED:
89+
return 0;
9090
}
9191
return 0;
9292
}

0 commit comments

Comments
 (0)