PLT 板


LINE

看板 PLT  RSS
※ 引述《PsMonkey (痞子軍團團長)》之銘言: : 我不是來護航的,不過被認為是護航的也無訪 : 起因是因為這篇文章我看了很久都看不懂 因為這篇是從影片延伸的,所以有些地方我略過了,另外 其實影片有些地方我不認同,不過我沒提出來。 這裡只是很無聊地把影片裡的例子原封不動的搬出來而已, 所以也沒啥護航不護航的。 基本上,我認為那個影片作者的想要表達的重點只有一個: Java 是個 super verbose 的語言,在可以的情況下快點跳 船吧。XD 另外,他還有另一個影片也很有趣: http://oodt.jpl.nasa.gov/better-web-app.mov 是在講 Web framework 的,裡面的口號是 We Love J2EE!XD : 如果今天比較的論點在於 : Java 要自己寫一堆 getter/setter : 而其他三種語言不用 : 那我不置可否 : 用 Eclipse 的 getter/setter generator 的人好像沒啥資格講話 XD 影片裡有一個論點:程式碼閱讀的次數比撰寫的次數多。 我們不在乎寫一堆 getter/setter,但在閱的時候會產生很多 噪音,造成閱讀上的困擾。 : : 到這邊為止,Python / Ruby / Scala 還是不算完全打敗 Java,畢竟 Java : : 也才九行程式碼,Ruby 也要七行。 : 如果你不用符合 JavaBean 的 spec : 沒有引數的 constructor 可以省略 : (lat, lon 的 field 宣告部份也可以合成一行→無意義 XD) 這裡是為了保持各種語言實作出來的行為一致性,提供一組 default constructor,lat/lon 會是 0,但同時也提供另 一組做初始化,所以沒辦法省。 在這邊 Python / Ruby 都是用 default argument value 的 方式做,Java/Scala 則是提供另一組 constructor。 PS.Scala 2.8 開始也可以用 default value 了。 : : 重點是下面了,現在我們發現原來的設計有問題,因為 lat 不能小於 -90 : : 或是大於 90 ,我們要如何在不更動原有的客戶端的情況下,把這個判斷加 : : 到我們的函式庫呢?Python / Ruby / Scala 都可以很輕鬆的做到。 : 基本上 Java 的教科書(忘記官方 coding style 有沒有這樣建議?) : 都會告訴你去寫 getter/setter 來存取 field : (所以這幾天在寫 GridBagLayout 的時候還頗驚訝 XD) : 你不用 setter 來設定 lat 的值 : 然後說的好像 Java 作不到 : 跟抱怨「Java 裡頭不能操作指標很麻煩」的感覺差不多 : 只能說... 我的功力太低,實在不太懂...... Orz 影片裡在強調這兩點: * Code is read more than written * We are all consenting adults. 解釋:我們知道自己在幹啥事,所以所有的 field 都是 public。XD 而第二點造成了 Python 的可閱讀性。 當然,第二點其實我自己不是很認同就是了。 我們當然可以在 Java 裡用 getter/setter(影片裡一開始的作 法),但會從 9 行程式變成 21 行,成為影片裡說的 super verbose,然後別忘記第一點:Code is read more than written. 但如果我們要用破壞封裝來達成簡潔,就無法達到上面說的當你 有一天發現程式有問題時,可以不用動到客戶端的 code 來做修 正了。 這裡只是簡單的指出在客戶端的程式碼是相同的情況下(都不使 用特殊的函式),如何能夠達到相同的效果,而結論是 Java 本 身是做不到的。 這是程式語言設計上所採用的哲學的問題,在這裡 Java 很明顯 的喜歡 getter/setter,而其他三個語言比較偏好 properpty 的做法。 其實沒啥好壞之分,只是設計的哲學不一樣,但就像你說的,我 也很訝異我在 Android 會看到用 public field 來操作的情況 出現。 Notification 就是一個例子,他有很多 feild 是 public 的。 BTW,我個人比較喜歡有 Uniform access 的這邊,我個人覺得 用 property 的方式,可以很明顯的告訴你『你改掉了某個值』。 val coord = new Coord (10, 20) coord.lat = 20 coord.setLat (20) 在第二行裡我可以一眼就看出來我改了 lat,值是 20,而不是 像第三行先看到 set,所以知道我在改值,接著再看 Lat,拼 湊出『我在改 lat 的值』的簡單的事實。 我知道這和 Java 世界裡的觀念有所差別,不過我比較喜歡第一 種的作法。 而 Ruby/Scala 的好處是由於有 uniform access 你可以很簡單 的控制 getter/setter,讓你也可以讓你在某些情況下使第一行 消效。 Ex. 可以用 coord.lat 讀值,但不能用 coord.lat = 來指定值。 不過這都只是個人偏好就是了。 只能說,習慣了 Ruby/Scala 的簡潔,回頭寫或看 Java 程式碼 有的時候會很覺得痛苦就是了。由簡入奢易,由奢返簡難啊。XD -- ~ 白馬帶著她一步步地回到中原。白馬已經老了,只能慢慢地走, 'v' Brian Hsu 但終是能回到中原的。江南有楊柳、桃花,有燕子、金魚…… // \\ ( 墳 墓 ) /( )\ 但這個美麗的姑娘就像古高昌國人那樣固執。 【白馬嘯西風】 ^`~'^ http://bone.twbbs.org.tw/blog 『那都是很好很好的,可我偏不喜歡。』 --



※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 59.120.199.114







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:BuyTogether站內搜尋

TOP