在Java8之前,代码编译为class文件后,方法参数的类型固定,但是方法名称会丢失,方法名称会变成arg0、arg1....。而现在,在Java8开始可以在class文件中保留参数名,这就给反射带来了极大的遍历。像mybatis等需要使用反射机制获取方法参数的时候就可以不用像以前一样需要使用类似于@Para
之类的注解。
功能测试:
import java.lang.reflect.Method;
import java.lang.reflect.Parameter;
public class GetRuntimeParameterName {
public void createUser(String name, int age, int version) {
}
public static void main(String[] args) throws Exception {
for (Method m : GetRuntimeParameterName.class.getMethods()) {
System.out.println("--------------------");
System.out.println(" method: " + m.getName());
System.out.println(" return: " + m.getReturnType().getName());
for (Parameter p : m.getParameters()) {
System.out.println("parameter:" + p.getType().getName() + ", " + p.getName());
}
}
}
}
分别测试:
编译命令一:
javac GetRuntimeParameterName.java
测试结果一:
--------------------
method: createUser
return: void
parameter:java.lang.String, arg0
parameter:int, arg1
parameter:int, arg2
编译命令二:(保留参数名)
javac -parameters GetRuntimeParameterName.java
测试结果二:
--------------------
method: createUser
return: void
parameter:java.lang.String, name
parameter:int, age
parameter:int, version
测试结论:由于为了避免.class文件因为保留参数名而导致.class文件过大或者占用更多的内存,另外也避免有些参数(secrect/password)泄露安全信息,JVM即使时1.8默认是不会保留参数名称的。
(1)Eclipse中开启方法:
Preferences->java->Compiler
下勾选Store information about method parameters
选项。
这样在使用eclipse编译java文件的时候就会将参数名称编译到class文件中。
(2)Idea中开启方法:
File->Settings->Build,Execution,Deployment->Java Compiler
下的Additional command line parameters
选项中添加-parameters
。
(3)Maven中开启方法:
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
<compilerArgs>
<arg>-parameters</arg>
</compilerArgs>
</configuration>
</plugin>
</plugins>
</build>
最后,记得重新build下即可: