在struts中 输入页面a.jsp 代码截取片段如下:
<form action="zifuchuan.do" method="post">
<input type="text" name="name"><input type="submit">
</form> 在这里输入abcaction中的代码如下:
ZifuchuanForm zifuchuanForm = (ZifuchuanForm) form;
String str1=(String)zifuchuanForm.getName();
String str2="abc";
if(str1==str2){
return mapping.findForward("chenggong");
}else return mapping.findForward("shibai");}
大家说是转入成功页面 还是失败页面 为了避免大家浪费时间
我可以告诉大家是失败页面 那么谁能告诉我真正的原因。
<form action="zifuchuan.do" method="post">
<input type="text" name="name"><input type="submit">
</form> 在这里输入abcaction中的代码如下:
ZifuchuanForm zifuchuanForm = (ZifuchuanForm) form;
String str1=(String)zifuchuanForm.getName();
String str2="abc";
if(str1==str2){
return mapping.findForward("chenggong");
}else return mapping.findForward("shibai");}
大家说是转入成功页面 还是失败页面 为了避免大家浪费时间
我可以告诉大家是失败页面 那么谁能告诉我真正的原因。
解决方案 »
- 水果验证码中图片不能为中文么
- 求jsp宿舍管理系统一个!
- HashMap排序问题(下拉列表显示顺序)
- extjs菜鸟问题,动态生成accordion的ITEMS,出现莫名错误
- 大家为我抉择
- 用struts标签<logic:iterate>如何实现这样的菜单
- long 的计算问题
- 我的职场第一步.坎坷啊!
- 极其简单的问题
- 偶在win和linux都遇到这样地错误提示:"Is there a server running on localhost:3306?"
- struts 局部跳转的问题?
- 只好请教:同一个jsp文件中前面调用session.getAttribute("id")还能得到值,后面就抛出异常了。。。
String b = "1";这样是:a == b 是为true的,因为JVM会优化字符串的常量减少占用的内存也就是JVM内部有一个字符串的常量池,在代码中使用到的常量都会尽量使用这个池中的引用,减少新创建出对象
但是你看看这个为什么false?我不明白
既然ZifuchuanForm zifuchuanForm = (ZifuchuanForm) form 里面得到的是“abc”
那么后面 String str2="abc"; 应该是前面已经得到啊
为什么还会返回false呢?
equals() 比较值
这句话新创建了一个字符串对象,指向的不是字符串常量池中的"abc"
String str2="abc";
str2指向字符串常量池中的"abc"str1==str2
是比较两个对象的引用,由于str1和str2指向的是不同对象,所以为falsestr1.equal(str2)等于true是由于String类型实现了基类的equal方法,比较的是字符串的值,你自己写类的时候也可以实现这个方法来完成你的特殊要求
结果为: true true 首先,我们要知结果为道Java会确保一个字符串常量只有一个拷贝。 因为例子中的s0和s1中的”kvill”都是字符串常量,它们在编译期就被确定了,所以s0==s1为true;
而”kv”和”ill”也都是字符串常量,当一个字符串由多个字符串常量连接而成时,它自己肯定也是字符串常量,
所以s2也同样在编译期就被解析为一个字符串常量,所以s2也是常量池中”kvill”的一个引用。 所以我们得出s0==s1==s2; 用new String() 创建的字符串不是常量,不能在编译期就确定,所以new String() 创建的字符串不放入常量池中,它们有自己的地址空间。 看例2: String s0=”kvill”; String s1=new String(”kvill”); String s2=”kv” + new String(“ill”); System.out.println( s0==s1 ); System.out.println( s0==s2 ); System.out.println( s1==s2 ); 结果为: false false false
例2中s0还是常量池中”kvill”的应用,s1因为无法在编译期确定,所以是运行时创建的新对象”kvill”的引用,
s2因为有后半部分new String(“ill”)所以也无法在编译期确定,所以也是一个新创建对象”kvill”的应用;明白了这些也就知道为何得出此结果了。JVM为运行一个程序定义了几种数据区(Data Area),包括:pc寄存器、JVM堆栈、堆、方法区(Method Area)、
运行时常量池(Runtime Constant Pool)以及本机方法堆栈(Native Method Stacks),这些数据区根据其生存期可以分为两种,
一种就是和JVM的生存期相同(包括堆和方法区),一种和线程的生存期相同(其它的),和JVM生存期相同的数据区在JVM启动的时候被创建并在JVM退出的时候被销毁,
而和线程生存期相同的数据区是每个线程一个的,他们在线程创建的时候被创建,在线程被销毁的时候被销毁。
String str="Hello World";---〉运行时常量池
String str=new String("Hello World");--->堆