论坛首页 Java企业应用论坛

getThis().getEvilAdvocate().setDead(getTrue())

浏览 7665 次
精华帖 (14) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2008-08-14  
ajoo 写道
sorphi 写道
ajoo 写道

我的办法就是:
final class FooAndBar {
  final Foo foo;
  final Bar bar;

  FooAndBar(Foo foo, Bar bar) {...}
}

用C++的术语,struct。


这个FooAndBar只能包内可见,那没法传递给客户端啦?

再,如果碰到了FooAndBarAndOther咋办?


本来就是包内的辅助数据结构,所谓的algebraic type。不需要对外公开。何况即使需要公开,把一切都变成public就是了,毕竟是项目自己用的,又不是jdk。

如果碰到Other,就再加一个field呗。

如果hibernate的话。。。
动态生成get与set
0 请登录后投票
   发表时间:2008-08-14  
Quake Wang 写道
nihongye 写道
引用
它不是public,也没有工具要用java bean api来读它,有必要一本正经地搞getFoo(), getBar()吗?直接就两个foo,bar field,简单点不好?

加get set,propterty语法糖都不需要。简单简单,写java就非得将自己变白痴吗!

因为其他lib都是按照这种"白痴"的方式来读取javabean的属性,比如常见的struts, ognl,如果你直接用public field,和这些lib就很难配合,还得自己额外写一些转化的工具类。

其实这和整个编程语言的习惯有关系,比如在Java中,我们通常用isAdmin做方法名,而在ruby中,就会改用admin?做方法名,整个业界都是用getter/setter,哪怕它很白痴,我们也得随大流。Java语言想做大的改变,很难,毕竟要考虑到那么多历史兼容问题。

看帖不认真,前面已经说了,不需要javabean的方式来读它
0 请登录后投票
   发表时间:2008-08-14  
ajoo 写道
抛出异常的爱 写道
用map代替的话
IDE又不能返回想要的KEY
如果想把get set去的的话
只能在ide上想办法了。

难不成要运行时生成指定的代码?


我的办法就是:
final class FooAndBar {
  final Foo foo;
  final Bar bar;

  FooAndBar(Foo foo, Bar bar) {...}
}

用C++的术语,struct。

整这么麻烦还要多写一个类,直接返回数组
0 请登录后投票
   发表时间:2008-08-14  
主要的成本在于从FooAndBar.foo 到 FooAndBar.getFoo()的重构成本太高,其实需要getter、setter的理由就只有一个
引用
可以在getter()里面封装其它的逻辑,直接操作field没有这个灵活性

可惜java的实现太傻,啥大小写转换规则、is、has的,还不如一个property关键字。
public class FooAndBar{
    public String foo;    
}

想覆盖的时候再慢慢处理
public class FooAndBar{
    public String foo;

    @Porperty.Read
    public String getFoo(){
        println "get foo";
        return foo;
    }
}

这样就不错……Groovy里正是这样干的,但它还是沿用了get、set,没用annotation
0 请登录后投票
   发表时间:2008-08-14  
一般来说,这样的类根本没有存在的必要。
0 请登录后投票
   发表时间:2008-08-14  
我们有一个项目涉及到CA的代码的,但是他们好像都是C的写法,就是直接把字段pbulic出来,我们在使用的时候,无法知道哪些字段是只读的,哪些是可写的.还有就是在使用一个类的时候,无法晓得哪些字段必须得赋值才能使用.如果是set, get, 至少可以知道set可以赋值,在使用的时候再进一步猜一下(之所以用猜是我们大家一般都比较懒,不愿意看文档,实在没有办法了才去找文档)就知道哪些必须要赋值. 

当然我也反对根本就没有必要的get和set, 有些地方一看就永远都用不到的get,set, 还是不要的为好. 因为大家都比较忙,一个类多看两行代码,就会费很多精力.
0 请登录后投票
   发表时间:2008-08-14  
看看古老而又充满活力的Objc-2.0
@interface FooAndBar : NSObject {
NSString* foo;
NSString* bar;

}
@property (readonly) NSString* foo;
@property (copy) NSString* bar;
@end

根据annotation,编译器自动生成 getter/setter.
Java需要反思。。。
我更要反思。。。
0 请登录后投票
   发表时间:2008-08-14  
grandboy 写道
我们有一个项目涉及到CA的代码的,但是他们好像都是C的写法,就是直接把字段pbulic出来,我们在使用的时候,无法知道哪些字段是只读的,哪些是可写的.还有就是在使用一个类的时候,无法晓得哪些字段必须得赋值才能使用.如果是set, get, 至少可以知道set可以赋值,在使用的时候再进一步猜一下(之所以用猜是我们大家一般都比较懒,不愿意看文档,实在没有办法了才去找文档)就知道哪些必须要赋值. 

当然我也反对根本就没有必要的get和set, 有些地方一看就永远都用不到的get,set, 还是不要的为好. 因为大家都比较忙,一个类多看两行代码,就会费很多精力.

mutable的东西,不管有没有getter/setter都不好维护。
immutable的对象,一个final关键字就够了。

在古老的java 1.1.8时代,final关键字编译器处理得有问题,总出编译错误,所以要getter/setter来人为帮助。现在,java bean可以歇一歇了。
0 请登录后投票
   发表时间:2008-08-15  
fyting 写道
主要的成本在于从FooAndBar.foo 到 FooAndBar.getFoo()的重构成本太高,其实需要getter、setter的理由就只有一个
引用
可以在getter()里面封装其它的逻辑,直接操作field没有这个灵活性

可惜java的实现太傻,啥大小写转换规则、is、has的,还不如一个property关键字。
public class FooAndBar{
    public String foo;    
}

想覆盖的时候再慢慢处理
public class FooAndBar{
    public String foo;

    @Porperty.Read
    public String getFoo(){
        println "get foo";
        return foo;
    }
}

这样就不错……Groovy里正是这样干的,但它还是沿用了get、set,没用annotation


很少见到有人在getFoo()里放逻辑的。九成以上都是"return foo"。

而且,“放逻辑”这件事本身也是值得怀疑的。如果你放的东西有副作用(side-effect),比如写个文件数据库什么的,那么对客户代码的影响很有可能是破坏性的。一般来说,我们都认为getFoo()是所谓的"Idempotent",也就是说调用两次和调用一次没区别,而且getFoo()应该是足够快的。可以写成:
if (obj.getFoo().canDoSomething()) {
  obj.getFoo().doSomething();
}

而不需要担心下面的重构会有行为变化:
Foo foo = obj.getFoo();
if (foo.canDoSomething()) {
  foo.doSomething();
}


而不放副作用的话,还有什么可放的?

至于说从foo到getFoo()重构的代价,首先,既然这种重构出现的可能性不大,那么代价大一点也可以接受。而且,我也不觉得有什么了不得的代价,非要用IDE自动化功能的话,可以走这个步骤:
1. 把foo改名成getTheFooThatIWillChangeToGetter。
2。增加getFoo()。
2. 全局替换getTheFooThatIWillChangeToGetter为getFoo()。
4。把getTheFooThatIWillChangeToGetter改回foo。
0 请登录后投票
   发表时间:2008-08-15  
真惨。ruby:
FooAndBar = Struct.new(:foo, :bar)


这个类就有了,反正暴露出来都是method,咱不怕
0 请登录后投票
论坛首页 Java企业应用版

跳转论坛:
Global site tag (gtag.js) - Google Analytics