Java文件编译的两种方式以及在SpringMVC传参中带来的问题
2013-08-26 10:31
513 查看
一、基本概念
java编译成.class 有两种方式。使用javac,默认使用的release方式,而使用的MyEclipse工具,用的是debug模式。值得注意的是使用release模式下对于函数参数会改变。
public class Test{
private static void sayHello(){
System.out.println("Hello world");
}
public static void main(String[] args){
sayHello();
}
}
以上代码分别用javac命令和MyEclipse IDE编译,然后使用jd-gui.exe查看Test.class,可以发现区别。
使用MyEclipse编译(debug)
public class Test
{
private static void sayHello()
{
System.out.println("Hello world");
}
public static void main(String[] args) {
sayHello();
}
}
使用javac编译(release)
public class Test
{
private static void sayHello()
{
System.out.println("Hello world");
}
public static void main(String[] paramArrayOfString) {
sayHello();
}
}
二、发现问题
以SpringMVC为例
@RequestMapping(/test/{str})
public String test(@PathVariable String str){
System.out.println(str);
return null;
}
实际项目部署使用的是release版本,这样str经过编译后就和RequestMapping中的{str}这样就对应不起来了。而这样的问题在开发中是不会发现的。这也可以解释为什么在spring MVC 中controller的注解初始化参数建议指定名称。建议写法如下:
@RequestMapping(/test/{str})
public String test(@PathVariable("str") String str){
System.out.println(str);
return null;
}
原帖地址:http://blog.csdn.net/ping_qc/article/details/7265814
java编译成.class 有两种方式。使用javac,默认使用的release方式,而使用的MyEclipse工具,用的是debug模式。值得注意的是使用release模式下对于函数参数会改变。
public class Test{
private static void sayHello(){
System.out.println("Hello world");
}
public static void main(String[] args){
sayHello();
}
}
以上代码分别用javac命令和MyEclipse IDE编译,然后使用jd-gui.exe查看Test.class,可以发现区别。
使用MyEclipse编译(debug)
public class Test
{
private static void sayHello()
{
System.out.println("Hello world");
}
public static void main(String[] args) {
sayHello();
}
}
使用javac编译(release)
public class Test
{
private static void sayHello()
{
System.out.println("Hello world");
}
public static void main(String[] paramArrayOfString) {
sayHello();
}
}
二、发现问题
以SpringMVC为例
@RequestMapping(/test/{str})
public String test(@PathVariable String str){
System.out.println(str);
return null;
}
实际项目部署使用的是release版本,这样str经过编译后就和RequestMapping中的{str}这样就对应不起来了。而这样的问题在开发中是不会发现的。这也可以解释为什么在spring MVC 中controller的注解初始化参数建议指定名称。建议写法如下:
@RequestMapping(/test/{str})
public String test(@PathVariable("str") String str){
System.out.println(str);
return null;
}
原帖地址:http://blog.csdn.net/ping_qc/article/details/7265814
相关文章推荐
- Java文件编译的两种方式以及在SpringMVC传参中带来的问题
- springmvc 上传文件两种方式比较以及上传问题解决
- springmvc常用注、上传文件以及后台返回前台数据的两种方式
- Easyui 创建dialog的两种方式,以及他们带来的问题
- android读取文件时乱码的问题,以及eclipse中java编码查看方式
- Java多线程的两种实现方式的区别以及同步问题中的锁对象深刻解析
- java实现简单文件复制(文件上传)以及springMVC中上传文件方式
- 关于java基础类型与引用类型内存存储问题,以及string.intern()方法(String两种创建方式的区别)
- springMVC实现REST开发详解(补充Json解析问题以及静态文件404错误解决办法)
- 浅析java中Integer传参方式的问题
- GRPC编译工具protoc-gen-grpc-java编译proto文件的方式
- JAVA随笔篇三(读写Properties配置文件以及路径问题详解)
- Java文件上传的机制与原理以及几种协议方式
- java实现文件下载的两种方式
- JAVAWEB开发之Hibernate详解(三)——Hibernate的检索方式、抓取策略以及利用二级缓存进行优化、解决数据库事务并发问题
- Android DES加解密的两种实现方式 - Java DES与Android DES不兼容问题
- Java中加载配置文件的集中方式,以及利用ClassLoader加载文件 .
- C# 修改保存 配置文件的两种方式以及区别
- WCF Rest:不使用UriTemplate使用post方式传参解决HTTP400问题以及参数映射问题