十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
Java中Bean属性命名规范有哪些,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
成都创新互联专注于乳源网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供乳源营销型网站建设,乳源网站制作、乳源网页设计、乳源网站官网定制、微信小程序服务,打造乳源网络公司原创品牌,更为您提供乳源网站排名全网营销落地服务。
问题由来:
最近在一个java bean类中定义了一个boolean类型的变量:
//boolean属性:是否显示 private boolean isShowCode ; //使用Eclipse自动生成getter/setter方法如下: public boolean isShowCode() { return isShowCode; } public void setShowCode(boolean isShowCode) { this.isShowCode = isShowCode; }
spring在给java bean 设置值的时候, 抛出异常:
Caused by: org.springframework.beans.NotWritablePropertyException: Invalid property 'isShowCode' of bean class [com.codemouse.beans.Country]: Bean property 'isShowCode' is not writable or has an invalid setter method. Did you mean 'showCode'? at org.springframework.beans.BeanWrapperImpl.setPropertyValue(BeanWrapperImpl.java:1064)
代码运行环境: jdk 1.6 + eclipse 3.2 + spring 3.1, 本文下面的代码都在该环境下测试。
原因跟踪分析:跟踪Spring源码, 可以看到下面这段代码:
private CachedIntrospectionResults(Class beanClass, boolean cacheFullMetadata) throws BeansException { ... ... this.beanInfo = new ExtendedBeanInfo(Introspector.getBeanInfo(beanClass)); ... ... }
方法Introspector.getBeanInfo(beanClass)返回的时候,获取到的java bean 信息中的isShowCode属性的名称已经被改成了"showCode"。
到这里可以确定问题不是出在spring代码中, 网上有不少帖子说是spring的处理规则导致了这个问题,这里是不是可以否定这种看法?
问题跟踪到这,也即跟踪到了java.beans包。尝试继续跟踪JDK源码,可能由于我的JDK的jar包和源码不匹配的原因, eclipse总是监控不到中间变量。也就没有再跟踪进去了。可以知道的是,javabean中 的isShowCode 属性 和 对应的getter/setter方法应该是没有遵循javabean规范。Eclipse自动生成的getter/setter方法看来也是存在一些问题的。
Eclipse自动生成boolean类型属性的方法是不是有点奇怪呢? 属性 isShowCode 的getter访问器是isShowCode()而不是getIsShowCode(), setter设值器是setShowCode()而不是setIsShowCode()。原来在java bean 规范关于中提到, boolean属性
public boolean is
来代替
public boolean get
Javabean 规范(下载链接:http://download.oracle.com/otndocs/jcp/7224-javabeans-1.01-fr-spec-oth-JSpec/ ) 在8.3 章节"Design Patterns for Properties" 中的描述:
Eclipse根据这种方式生成getter访问器和setter设值器, 由于属性名isShowCode的is没有去掉, 以致java bean类违背了java bean 的命名规范。
JavaBean 的属性名和getter/setter存取方法规则小结:
1. 对于常规属性
2. 对于布尔类型
3. 对于非常规属性
3.1 ) 对应的getter/setter方法名可以为:get/set +
中国 CN true
private String pName; public String getPName() { return pName; } public void setPName(String name) { pName = name; }
3.2 )对应的getter/setter方法名也可以为:get/set+
代码片段:
中国 CN true
private String pName; public String getpName() { return pName; } public void setpName(String name) { pName = name; }
4. 对于非常规属性
对应的getter/setter方法名为: get/set +
spring3.1 配置文件代码片段:
中国 CN true
private String PName; public String getPName() { return PName; } public void setPName(String name) { PName = name; }
5. 对于非常规属性
(如帖子1: http://lzh266.iteye.com/blog/631838 ;
帖子2: http://hi.baidu.com/w8y56f/blog/item/4fd037e845bbbe372cf5342a.html)。我在我的 环境下测试了下, 是不会报错的,可以正常运行,虽然这种命名方式是令人难以忍受的:
中国 CN true 12.345
private String PropertyName; public String getPropertyName() { return PropertyName; } public void setPropertyName(String propertyName) { PropertyName = propertyName; } private Double Xcoordinate; public Double getXcoordinate() { return Xcoordinate; } public void setXcoordinate(Double xcoordinate) { Xcoordinate = xcoordinate; }
测试方法: ***个@test方法用普通javabean调用方式测试; 第二个@test方法使用spring创建bean
@Test public void testJavaBeanNamingRule0(){ Country country = new Country(); country.setPropertyName("中国"); country.setXcoordinate(Double.valueOf(123.456f)); System.out.println(country.getPropertyName()); System.out.println(country.getXcoordinate()); } @Test public void testJavaBeanNamingRule(){ ApplicationContext ctx = new ClassPathXmlApplicationContext("myBeans.xml"); Country country = (Country)ctx.getBean("country"); System.out.println(country.getPropertyName()); System.out.println(country.getXcoordinate()); }
运行结果:都可以正常运行。
中国 123.45600128173828 log4j:WARN No appenders could be found for logger (org.springframework.core.env.StandardEnvironment). log4j:WARN Please initialize the log4j system properly. 中国 12.345
总结:
1. javabean属性命名尽量使用常规的驼峰式命名规则
2. 属性名***个单词尽量避免使用一个字母:如eBook, eMail。
3. boolean属性名避免使用 “is” 开头的名称
4. 随着jdk, eclipse, spring 等软件版本的不断提高, 底版本的出现的问题可能在高版本中解决了, 低版本原来正常的代码可能在高版本环境下不再支持。
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联的支持。