Skip to content

Commit 0aa32cb

Browse files
committed
[wip]ch 20.5
1 parent 43f5e9a commit 0aa32cb

12 files changed

Lines changed: 289 additions & 1 deletion

src/main/java/ch20/PasswordUtil.java

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,7 @@
11
package ch20;
22

3+
import ch20.unitTest.UseCase;
4+
35
import java.util.List;
46

57
/**

src/main/java/ch20/UseCaseTracker.java

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,7 @@
11
package ch20;
22

3+
import ch20.unitTest.UseCase;
4+
35
import java.lang.reflect.Method;
46
import java.util.ArrayList;
57
import java.util.Collections;
Lines changed: 25 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,25 @@
1+
package ch20.unitTest;
2+
3+
import java.io.File;
4+
import java.util.ArrayList;
5+
import java.util.List;
6+
7+
/**
8+
* @author: yuki
9+
* @date: 2018/11/1
10+
*/
11+
public class AtUnit implements ProcessFiles.Strategy {
12+
13+
static Class<?> testClass;
14+
static List<String> failedTests = new ArrayList<>();
15+
static long testsRun = 0;
16+
static long failures = 0;
17+
18+
@Override
19+
public void process(File file) {
20+
try{
21+
} catch (Exception e){
22+
23+
}
24+
}
25+
}
Lines changed: 55 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,55 @@
1+
package ch20.unitTest;
2+
3+
4+
import java.io.BufferedInputStream;
5+
import java.io.File;
6+
import java.io.FileInputStream;
7+
import java.io.IOException;
8+
import java.util.Arrays;
9+
10+
/**
11+
* @author yuzhe
12+
* @since 10/12/18
13+
*/
14+
public class BinaryFile {
15+
16+
17+
public static byte[] read(File bFile) throws IOException {
18+
BufferedInputStream in = new BufferedInputStream(
19+
new FileInputStream(bFile)
20+
);
21+
try {
22+
byte[] data = new byte[in.available()];
23+
in.read(data);
24+
return data;
25+
} catch (IOException e) {
26+
e.printStackTrace();
27+
throw e;
28+
}
29+
}
30+
31+
public static byte[] read(String path) throws IOException {
32+
return read(new File(path).getAbsoluteFile());
33+
}
34+
35+
public static void main(String[] args) {
36+
String path = "target/classes/ch18/TextFile.class";
37+
try {
38+
byte[] data = read(path);
39+
byte[] magic = new byte[4];
40+
Integer num = 0;
41+
for(int i = 0; i < 4; i++){
42+
magic[i] = data[i];
43+
num <<= 8;
44+
num += (magic[i] & 0Xff);
45+
}
46+
System.out.println(Arrays.toString(magic));
47+
System.out.println(Integer.toBinaryString(num));
48+
System.out.println(Integer.toHexString(num));
49+
} catch (IOException e) {
50+
e.printStackTrace();
51+
}
52+
53+
}
54+
55+
}
Lines changed: 102 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,102 @@
1+
package ch20.unitTest;
2+
3+
import com.alibaba.fastjson.JSON;
4+
5+
import java.io.ByteArrayInputStream;
6+
import java.io.DataInputStream;
7+
import java.io.IOException;
8+
import java.util.HashMap;
9+
import java.util.Map;
10+
11+
/**
12+
* @author: yuki
13+
* @date: 2018/11/2
14+
*/
15+
public class ClassNameFinder {
16+
17+
public static String thisClass(byte[] classBytes) {
18+
19+
Map<Integer, Integer> offsetTable = new HashMap<>();
20+
Map<Integer, String> classNameTable = new HashMap<>();
21+
try {
22+
//解析字节流
23+
DataInputStream data = new DataInputStream(
24+
new ByteArrayInputStream(classBytes)
25+
);
26+
// 0xcafebabe
27+
int magic = data.readInt();
28+
int minorVersion = data.readShort();
29+
int majorVersion = data.readShort();
30+
31+
int constant_pool_count = data.readShort();
32+
int[] constant_pool = new int[constant_pool_count];
33+
for (int i = 1; i < constant_pool_count; i++) {
34+
int tag = data.read();
35+
int tableSize;
36+
//JVM Page 169
37+
switch (tag) {
38+
case 1:
39+
//UTF 编码的字符串
40+
int length = data.readShort();
41+
char[] bytes = new char[length];
42+
for (int k = 0; k < bytes.length; k++) {
43+
bytes[k] = (char) data.read();
44+
}
45+
String className = new String(bytes);
46+
classNameTable.put(i, className);
47+
break;
48+
case 5:
49+
//long
50+
case 6:
51+
//double
52+
data.readLong();
53+
i++;
54+
break;
55+
case 7:
56+
//class
57+
int offset = data.readShort();
58+
offsetTable.put(i, offset);
59+
break;
60+
case 8:
61+
//String 字符串类型字面量
62+
data.readShort();
63+
break;
64+
case 3:
65+
//integer
66+
case 4:
67+
//float
68+
case 9:
69+
//field ref
70+
case 10:
71+
//method ref
72+
case 11:
73+
//interface method ref
74+
case 12:
75+
// name and type
76+
data.readInt();
77+
break;
78+
default:
79+
throw new RuntimeException("Bad tag " + tag);
80+
}
81+
}
82+
short access_flag = data.readShort();
83+
int this_class = data.readShort();
84+
int super_class = data.readShort();
85+
System.out.println(this_class);
86+
System.out.println(JSON.toJSON(offsetTable).toString());
87+
System.out.println(JSON.toJSON(classNameTable).toString());
88+
return classNameTable.get(offsetTable.get(this_class))
89+
.replace('/', '.');
90+
91+
} catch (Exception e) {
92+
throw new RuntimeException(e);
93+
}
94+
}
95+
96+
public static void main(String[] args) throws IOException {
97+
String path ="target/classes/ch20/unitTest/Testable2.class";
98+
String result = thisClass(BinaryFile.read(path));
99+
System.out.println(result);
100+
}
101+
102+
}
Lines changed: 23 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,23 @@
1+
package ch20.unitTest;
2+
3+
import lombok.AllArgsConstructor;
4+
5+
import java.io.File;
6+
import java.io.IOException;
7+
8+
/**
9+
* @author yuzhe
10+
* @since 10/9/18
11+
*/
12+
@AllArgsConstructor
13+
public class ProcessFiles {
14+
15+
//纯粹为了使用接口从ch18复制过来,lombok插件和编译期注解蜜汁冲突
16+
public interface Strategy {
17+
void process(File file);
18+
}
19+
20+
private Strategy strategy;
21+
private String ext;
22+
23+
}
Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,15 @@
1+
package ch20.unitTest;
2+
3+
import java.lang.annotation.ElementType;
4+
import java.lang.annotation.Retention;
5+
import java.lang.annotation.RetentionPolicy;
6+
import java.lang.annotation.Target;
7+
8+
/**
9+
* @author: yuki
10+
* @date: 2018/11/1
11+
*/
12+
@Target(ElementType.METHOD)
13+
@Retention(RetentionPolicy.RUNTIME)
14+
public @interface Test {
15+
}
Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,15 @@
1+
package ch20.unitTest;
2+
3+
import java.lang.annotation.ElementType;
4+
import java.lang.annotation.Retention;
5+
import java.lang.annotation.RetentionPolicy;
6+
import java.lang.annotation.Target;
7+
8+
/**
9+
* @author: yuki
10+
* @date: 2018/11/1
11+
*/
12+
@Target(ElementType.METHOD)
13+
@Retention(RetentionPolicy.RUNTIME)
14+
public @interface TestObjectCleanup {
15+
}
Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,15 @@
1+
package ch20.unitTest;
2+
3+
import java.lang.annotation.ElementType;
4+
import java.lang.annotation.Retention;
5+
import java.lang.annotation.RetentionPolicy;
6+
import java.lang.annotation.Target;
7+
8+
/**
9+
* @author: yuki
10+
* @date: 2018/11/1
11+
*/
12+
@Target(ElementType.METHOD)
13+
@Retention(RetentionPolicy.RUNTIME)
14+
public @interface TestObjectCreate {
15+
}
Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,15 @@
1+
package ch20.unitTest;
2+
3+
import java.lang.annotation.ElementType;
4+
import java.lang.annotation.Retention;
5+
import java.lang.annotation.RetentionPolicy;
6+
import java.lang.annotation.Target;
7+
8+
/**
9+
* @author: yuki
10+
* @date: 2018/11/1
11+
*/
12+
@Retention(RetentionPolicy.RUNTIME)
13+
@Target({ElementType.FIELD, ElementType.METHOD})
14+
public @interface TestProperty {
15+
}

0 commit comments

Comments
 (0)