精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Scala代碼編寫中常見的十大陷阱

原創
開發 后端
很多Java開發者在學習Scala語言的時候,往往覺得Scala的語法和用法有些過于復雜,充滿語法糖,太“甜”了。在使用Scala編寫代碼時,由于語法和編寫習慣的不同,很多開發者會犯相同或相似的錯誤。一位Scala狂熱愛好者近日總結了十大這樣的錯誤,以供參考。

【51CTO精選譯文】對于支持并發和分布式處理、高可擴展、基于組件的應用程序來說,Scala的功能是很強大的。它利用了面向對象和函數式程序設計的優點。這種基于Java虛擬機的語言在宣布Twitter正使用它時受到了最多的沖擊(相關51CTO評論:從Scala進駐Twitter看多語言混雜系統的前景)。如果使用正確,Scala可以大量減少應用程序對代碼的需求。

對于Scala編程, 我們收集了這些常見代碼編寫中的陷阱。這些技巧來自于Daniel Sobral,一個曾參加過FreeBSD項目和Java軟件開發工程的Scala狂熱愛好者。

1. 語法錯誤

認為  “yield” 像 ”return” 一樣。有人會這樣寫:

  1. for(i <- 0 to 10) {  
  2.   if (i % 2 == 0)  
  3.     yield i  
  4.   else 
  5.     yield -i  

正確的表示應該是:

  1. for(i <- 0 to 10)   
  2. yield {  
  3.   if (i % 2 == 0)  
  4.     i  
  5.   else 
  6.     -i  

2. 誤用和語法錯誤

濫用scala.xml.XML.loadXXX。這個的語法分析器試圖訪問外部的DTD、strip組件或類似的東西。在scala.xml.parsing.ConstructingParser.fromXXX中有另一個可選的語法分析器。同時,在處理XML時忘記了等號兩端的空格。比如:

  1. val xml=<root/> 

這段代碼真正的意思是:

  1. val xml.$equal$less(root).$slash$greater  
  2.   

這種情況的發生是由于操作符相當隨意,而且scala采用這樣一種事實:字母數字字符與非字母數字字符通過下劃線可以結合成為一個有效的標識符。這也使得“x+y”這樣的表達式不會被當成一個標識符。而應該注意 “x_+”是一個有效的標識符。所以,賦值標識符的寫法應該是:

  1. val xml = <root/> 

3. 用法錯誤

為那些根本不是無關緊要的應用加入Application特征。

  1. object MyScalaApp extends Application {    
  2.   // ... body ...  

#t#示例部分的問題在于,body部分在單元對象初始化時執行。首先,單元初始化的執行是異步的,因此你的整個程序不能與其它線程交互;其次,即時編譯器(JIT)不會優化它,因此你的程序速度慢下來,這是沒有必要的。

另外,不能與其它線程的交互也意味著你會忘記測試應用程序的GUI或者Actors。

4. 用法錯誤

試圖模式匹配一個字符串的正則表達式,而又假定該正則表達式是無界的:

  1. val r = """(\d+)""".r  
  2. val s = "--> 5 <---" 
  3. s match {  
  4.   case r(n) => println("This won't match")  
  5.   case _ => println("This will")  

此處的問題在于, 當模式模式匹配時, Scala的正則表達式表現為如同開始于”^”,結束于”$”。使之工作的正確寫法是:

  1. val r = """(\d+)""".r  
  2. val s = "--> 5 <---" 
  3. r findFirstIn s match {  
  4.   case Some(n) => println("Matches 5 to "+n)  
  5.   case _ => println("Won't match")  

或者確保模式能匹配任意前綴和后綴:

  1. val r = """.*(\d+).*""".r  
  2. val s = "--> 5 <---" 
  3. s match {  
  4.   case r(n) => println("This will match the first group of r, "+n+", to 5")  
  5.   case _ => println("Won't match")  

#p#

5. 用法錯誤

把var和val認為是字段(fields):

Scala強制使用統一訪問準則(Uniform Access Principle),這使得我們無法直接引用一個字段。所有對任意字段的訪問只能通過getters和setters。val和var事實上只是定義一個字段,getter作為val字段,對于var則定義一個setter。

#t#Java程序員通常認為var和val是字段,而當發現在他們的方法中它們共享相同的命名空間時,常常覺得驚訝。因此,不能重復使用它們的名字。共享命名空間的是自動定義的getter和setter而不是字段本身。通常程序員們會試圖尋找一種訪問字段的方法,從而可以繞過限制——但這只是徒勞,統一訪問準則是無法違背的。它的另一個后果是,當進行子類化時val會覆蓋def。其它方法是行不通的,因為val增加了不變性保證,而def沒有。

當你需要重載時,沒有任何準則會指導你如何使用私有的getters和setters。Scala編譯器和庫代碼常使用私有值的別名和縮寫,反之公有的getters和setters則使用fullyCamelNamingConventions(一種命名規范)。其它的建議包括:重命名、實例中的單元化,甚至子類化。這些建議的例子如下:

重命名

  1. class User(val name: String, initialPassword: String) {  
  2.   private lazy var encryptedPassword = encrypt(initialPassword, salt)  
  3.   private lazy var salt = scala.util.Random.nextInt  
  4.  
  5.   private def encrypt(plainText: String, salt: Int): String = { ... }  
  6.   private def decrypt(encryptedText: String, salt: Int): String = { ... }  
  7.  
  8.   def password = decrypt(encryptedPassword, salt)  
  9.   def password_=(newPassword: String) = encrypt(newPassword, salt)  

單例模式(Singleton)

  1. class User(initialName: String, initialPassword: String) {  
  2.    private object fields {  
  3.      var name: String = initialName;  
  4.      var password: String = initialPassword;  
  5.    }  
  6.    def name = fields.name  
  7.    def name_=(newName: String) = fields.name = newName  
  8.    def password = fields.password  
  9.    def password_=(newPassword: String) = fields.password = newPassword  
  10.  } 

或者,對于一個類來說,可以為相等關系或hashCode自動定義可被重用的方法

  1. class User(name0: String, password0: String) {  
  2.   private case class Fields(var name: String, var password0: String)  
  3.   private object fields extends Fields(name0, password0)  
  4.  
  5.  
  6.   def name = fields.name  
  7.   def name_=(newName: String) = fields.name = newName  
  8.   def password = fields.password  
  9.   def password_=(newPassword: String) = fields.password = newPassword  

子類化

  1. case class Customer(name: String)  
  2.  
  3. class ValidatingCustomer(name0: String) extends Customer(name0) {  
  4.   require(name0.length < 5)  
  5.  
  6.   def name_=(newName : String) =  
  7.     if (newName.length < 5) error("too short")  
  8.     else super.name_=(newName)  
  9. }  
  10.  
  11. val cust = new ValidatingCustomer("xyz123"

6. 用法錯誤

忘記類型擦除(type erasure)。當你聲明了一個類C[A]、一個泛型T[A]或者一個函數或者方法m[A]后,A在運行時并不存在。這意味著,對于實例來講,任何參數都將被編譯成AnyRef,即使編譯器能夠保證在編譯過程中類型不會被忽略掉。

這也意味著在編譯時你不能使用類型參數A。例如,下面這些代碼將不會工作:

  1. def checkList[A](l: List[A]) = l match {  
  2.   case _ : List[Int] => println("List of Ints")  
  3.   case _ : List[String] => println("List of Strings")  
  4.   case _ => println("Something else")  

在運行時,被傳遞的List沒有類型參數。 而List[Int]和List[String]都將會變成List[_]. 因此只有第一種情況會被調用。

你也可以在一定范圍內不使用這種方法,而采用實驗性的特性Manifest, 像這樣:

  1. def checkList[A](l: List[A])(implicit m: scala.reflect.Manifest[A]) = m.toString match {  
  2.   case "int" => println("List of Ints")  
  3.   case "java.lang.String" => println("List of Strings")  
  4.   case _ => println("Something else")  

#p#

7. 設計錯誤

Implicit關鍵字的使用不小心。Implicits非常強大,但要小心,普通類型不能使用隱式參數或者進行隱匿轉換。

例如,下面一個implicit表達式:

  1. implicit def string2Int(s: String): Int = s.toInt 

這是一個不好的做法,因為有人可能錯誤的使用了一個字符串來代替Int。對于上面的這種情況,更好的方法是使用一個類。

  1. case class Age(n: Int)  
  2. implicit def string2Age(s: String) = Age(s.toInt)  
  3. implicit def int2Age(n: Int) = new Age(n)  
  4. implicit def age2Int(a: Age) = a.n 

這將會使你很自由的將Age與String或者Int結合起來,而不是讓String和Int結合。類似的,當使用隱式參數時,不要像這樣做:

  1. case class Person(name: String)(implicit age: Int) 

這不僅因為它容易在隱式參數間產生沖突,而且可能導致在毫無提示情況下傳遞一個隱式的age, 而接收者需要的只是隱式的Int或者其它類型。同樣,解決辦法是使用一個特定的類。

另一種可能導致implicit用法出問題的情況是有偏好的使用操作符。你可能認為”~”是字符串匹配時最好的操作符,而其他人可能會使用矩陣等價(matrix equivalence),分析器連接等(符號)。因此,如果你使用它們,請確保你能夠很容易的分離其作用域。

8. 設計錯誤

設計不佳的等價方法。尤其是:

◆試著使用“==”代替“equals”(這讓你可以使用“!=”)

◆使用這樣的定義:

  1. def equals(other: MyClass): Boolean 

而不是這樣的:

  1. override def equals(other: Any): Boolean  
  2.   

◆忘記重載hashCode,以確保當a==b時a.hashCode==b.hashCode(反之不一定成立)。

◆不可以這樣做交換: if a==b then b==a。特別地,當考慮子類化時,超類是否知道如何與一個子類進行對比,即使它不知道該子類是否存在。如果需要請查看canEquals的用法。

◆不可以這樣做傳遞: if a==b and b ==c then a==c。

9. 用法錯誤

在Unix/Linux/*BSD的系統中,對你的主機進行了命名卻沒有在主機文件中聲明。特別的,下面這條指令不會工作:

  1. ping `hostname`  
  2.   

#t#在這種情況下,fsc和scala都不會工作,而scalac則可以。這是因為fsc運行在背景模式下,通過TCP套接字監聽連接來加速編譯,而scala卻用它來加快腳本的執行速度。

10.風格錯誤

使用while。雖然它有自己的用處,但大多數時候使用for往往更好。在談到for時,用它們來產生索引不是一個好的做法。

避免這樣的使用:

  1. def matchingChars(string: String, characters: String) = {  
  2.   var m = "" 
  3.   for(i <- 0 until string.length)  
  4.     if ((characters contains string(i)) && !(m contains string(i)))  
  5.       m += string(i)  
  6.   m  

而應該使用:

  1. def matchingChars(string: String, characters: String) = {  
  2.   var m = "" 
  3.   for(c <- string)  
  4.     if ((characters contains c) && !(m contains c))  
  5.       m += c  
  6.   m  

如果有人需要返回一個索引,可以使用下面的形式來代替按索引迭代的方法。如果對性能有要求,它可以較好的應用在投影(projection)(Scala 2.7)和視圖(Scala 2.8)中。

  1. def indicesOf(s: String, c: Char) = for {  
  2.   (sc, index) <- s.zipWithIndex  
  3.   if c == sc  
  4. } yield index   

【51CTO.com譯稿,合作站點轉載請注明原文譯者和出處為51CTO.com,且不得修改原文內容。】

原文:10 Scala Programming Pitfalls  作者:mitchp

責任編輯:yangsai 來源: 51CTO.com
相關推薦

2013-10-23 14:34:15

2024-08-16 21:38:43

Python代碼編程

2010-08-16 13:51:22

DIV+CSS

2013-04-27 17:09:29

安全管理IT技術

2010-10-26 10:16:36

求職

2015-06-08 13:51:56

WiFi

2011-06-07 15:34:15

2020-08-13 06:43:41

React前端開發

2014-02-13 11:06:52

系統架構移動互聯網

2014-02-14 16:23:03

移動互聯網系統架構

2023-06-08 00:16:58

2010-08-26 08:55:08

IE6CSS兼容性

2010-08-18 13:13:04

CSS兼容性IE6

2015-02-05 08:48:07

云遷移云資源管理

2018-10-31 08:55:02

2009-07-21 10:04:57

Scala編程語言

2024-03-04 13:23:00

數字化轉型

2025-01-06 00:02:51

2020-03-16 09:00:00

Linux郵件客戶端

2011-04-29 10:37:01

CRM
點贊
收藏

51CTO技術棧公眾號

亚洲视频一二三| 麻豆国产91在线播放| 日韩成人高清在线| 亚洲天堂av线| 91福利国产在线观看菠萝蜜| 99久久精品一区| 国产欧美日韩中文字幕| 久久久久久久久久一区二区三区| 久久365资源| 欧美色大人视频| 日本xxxxxxxxxx75| 在线观看h片| 成人福利视频网站| 国产日韩精品入口| 国产毛片aaa| 在线观看免费一区二区| 亚洲精品一区二区三区不| 欧美成人三级在线播放| 成年网站在线视频网站| 日本一区二区不卡视频| 国产欧美精品一区二区三区| 在线观看免费观看在线| 日韩一级精品| 久久色免费在线视频| 成人免费毛片糖心| 7m精品国产导航在线| 欧美丝袜丝交足nylons图片| 国产综合av在线| 综合久久2o19| 国产精品嫩草影院com| 欧美日韩高清在线一区| 日韩中文字幕影院| 国产高清亚洲一区| 国产欧美日韩免费| 亚洲永久精品一区| 国产精品乱看| 亚州成人av在线| 欧美日韩国产精品一区二区三区| 日韩电影在线视频| 欲色天天网综合久久| 丰满少妇一区二区三区| 2021年精品国产福利在线| 欧美一区二区性放荡片| 不用播放器的免费av| 国产91在线播放精品| 色先锋资源久久综合| 国产午夜伦鲁鲁| 97人人在线视频| 亚洲综合偷拍欧美一区色| 国产av第一区| caopo在线| 亚洲猫色日本管| 欧美日韩亚洲国产成人| 黄网站视频在线观看| 中文字幕一区二区三区蜜月| 亚洲国产成人不卡| 69视频在线| 国产精品九色蝌蚪自拍| 亚洲一区二区三区午夜| 成人在线免费电影| 中文一区在线播放| 亚洲国产精品一区二区第四页av| av资源在线观看免费高清| 国产视频一区二区在线| 日韩精品久久一区| 午夜视频在线观看网站| 中文字幕亚洲一区二区va在线| 亚洲精品乱码久久久久久蜜桃91| 91在线高清| ...av二区三区久久精品| 欧美日韩一级在线| 任你弄在线视频免费观看| 亚洲国产一区在线观看| 国产伦精品一区二区三区四区视频_| 俄罗斯一级**毛片在线播放| 欧美日韩中文在线| 一区二区三区韩国| 国产电影一区| 亚洲黄色在线看| 日韩人妻无码精品综合区| 久久精品99久久无色码中文字幕| 久久视频在线直播| www.日本精品| 久久精品99国产精品日本| 91在线观看免费| 国 产 黄 色 大 片| 久久久美女毛片| www亚洲国产| 大桥未久在线视频| 欧美视频在线观看一区二区| 久久久久久久高清| 精品嫩草影院| 色偷偷偷亚洲综合网另类| 校园春色 亚洲| 久久精品国语| 亚洲iv一区二区三区| 先锋av资源站| 综合精品久久久| 久久国产成人精品国产成人亚洲| 日本午夜精品久久久久| 亚洲成人免费网站| 欧美极品jizzhd欧美18| 在线精品一区| 国产日韩中文在线| 亚洲av片在线观看| 最近中文字幕一区二区三区| 日本www在线播放| 嫩呦国产一区二区三区av| 精品呦交小u女在线| 高h视频免费观看| 日韩一区欧美二区| 国产精品久久久久久久久婷婷 | 日本在线高清| 欧美男女性生活在线直播观看| 精品国产av色一区二区深夜久久 | xvideos成人免费中文版| 日韩精品一区二区不卡| 激情综合色播五月| 日韩欧美电影一区二区| 2020av在线| 欧美一级久久久| 成人一级片免费看| 亚洲综合国产| 国产一区视频观看| www在线观看播放免费视频日本| 一本一道久久a久久精品综合蜜臀| 好吊操视频这里只有精品| 日韩精品电影| 国产精品久久久久久久久久小说 | 日本一区免费视频| 欧美日韩在线一| 国产精品久久久久av蜜臀| 精品国产欧美成人夜夜嗨| 夜夜爽妓女8888视频免费观看| 成人国产精品免费| 女人被男人躁得好爽免费视频| 久久免费影院| 色一情一乱一区二区| 成人免费一级片| 国产女人18水真多18精品一级做 | 久草视频在线资源站| 日韩国产欧美三级| 欧美激情一区二区三区在线视频| 岛国av在线网站| 亚洲黄色成人网| 日韩污视频在线观看| 高清不卡一区二区在线| 日韩视频 中文字幕| 免费在线成人激情电影| 在线视频日韩精品| 亚洲手机在线观看| 国产精品久久久久久久岛一牛影视 | 欧美一区二区三区在线免费观看| 国偷自产一区二区免费视频| 亚洲精品日韩久久久| 国产免费观看av| 91丨porny丨在线| 免费黄色特级片| 欧美一二区在线观看| 国产精品va在线播放我和闺蜜| 国产精品一区二区婷婷| 欧美性一二三区| 午夜激情视频在线播放| 精品一区二区三区在线观看 | 国产精品实拍| 日韩一级成人av| 久久久久成人片免费观看蜜芽| 国产成人免费av在线| www.好吊操| 欧美电影免费网站| 国产不卡av在线免费观看| 极品美乳网红视频免费在线观看| 欧美在线免费观看视频| 少妇高潮惨叫久久久久| 国产毛片精品视频| 搞av.com| 欧美美女一区| 91嫩草免费看| 欧美调教sm| 自拍偷拍亚洲欧美| 精品国产无码一区二区| 午夜精品爽啪视频| 五月天精品视频| 激情综合色综合久久| 黄色成人在线看| 精品日韩毛片| 成人在线视频电影| 国产极品人妖在线观看| 亚洲精品一区二区久| 一级全黄少妇性色生活片| 一区二区三区小说| 国产男男chinese网站| 精品一区二区国语对白| 800av在线免费观看| 奇米色欧美一区二区三区| 成人性生交大片免费看视频直播| 白浆在线视频| 日韩中文字幕精品| 熟妇高潮一区二区三区| 精品视频免费看| 亚洲激情视频一区| 中文字幕视频一区二区三区久| 成年人的黄色片| 久久99国产精品麻豆| 玩弄中年熟妇正在播放| 97国产精品| 欧美精品一区二区三区在线四季| www一区二区三区| 国产成人av在线| 波多野结衣中文在线| 最近2019年手机中文字幕| 日本高清视频免费看| 欧美精品日日鲁夜夜添| 欧美一级特黄视频| 亚洲一区二区av在线| 日本美女黄色一级片| 久久久久久综合| 国产精品无码自拍| 老鸭窝一区二区久久精品| av免费播放网址| 欧美特黄一区| 91精品国产吴梦梦| 成人区精品一区二区婷婷| 狠狠色伊人亚洲综合网站色 | 欧美高清视频一区| 欧美影院视频| 国产在线视频91| 电影一区电影二区| 国产91在线高潮白浆在线观看| 国产丝袜在线播放| 欧美成人四级hd版| 黄黄的网站在线观看| 影音先锋日韩有码| 国产系列在线观看| 亚洲老司机av| 午夜视频免费在线| 亚洲国产精品yw在线观看| 亚洲国产精品久久人人爱潘金莲 | 国产成人av在线| 亚洲同志男男gay1069网站| 国内精品久久久久久影视8| 性欧美1819sex性高清大胸| 日韩视频免费中文字幕| 婷婷视频在线| 色噜噜狠狠狠综合曰曰曰88av| 国内精品一区视频| 亚洲欧洲国产精品| 国内在线精品| 中文字幕国产精品| 午夜在线视频| 日韩视频亚洲视频| 成人在线影视| 欧美成人免费网| 免费男女羞羞的视频网站在线观看 | 中文字幕高清视频| 国产人伦精品一区二区| 国产伦理片在线观看| 日本一区二区高清| 成人欧美一区二区三区黑人一| 国产精品亲子伦对白| 日本黄区免费视频观看| 亚洲天堂免费看| www.色小姐com| 亚洲国产sm捆绑调教视频| 日韩熟女精品一区二区三区| 欧美日韩一区二区在线| 91在线视频免费播放| 欧美三级日韩三级| 国产女人高潮毛片| 精品三级在线看| 性插视频在线观看| 一区二区三区美女xx视频| 日本欧美在线视频免费观看| 另类色图亚洲色图| 俺来俺也去www色在线观看| 1769国产精品| 电影亚洲一区| 99三级在线| 久久97视频| 亚洲一区二区在| 在线播放精品| 波多野结衣作品集| 国内精品久久久久影院一蜜桃| zjzjzjzjzj亚洲女人| 久久精品亚洲国产奇米99| 自拍偷拍第9页| 午夜精品久久久久久久| 波多野结衣一二区| 日韩欧美中文字幕制服| 日韩av免费观影| 久久艹在线视频| 国模冰冰炮一区二区| 亚洲综合在线播放| 精品一区在线| 国产精品日韩三级| 日韩国产精品久久久| 日本天堂在线播放| 中文字幕va一区二区三区| 久久婷婷国产麻豆91| 欧洲视频一区二区| 亚洲美女性生活| 少妇高潮 亚洲精品| 国产99在线观看| 成人av在线天堂| 国产欧美日韩一区二区三区四区 | 国产欧美一区二区三区国产幕精品| 无码日韩人妻精品久久蜜桃| 国产成人午夜片在线观看高清观看| www.色多多| 亚洲国产三级在线| 亚洲无码精品国产| 国产视频精品久久久| 色呦呦在线看| 成人欧美在线视频| 免费一区二区三区视频导航| 日韩国产小视频| 久久9热精品视频| 鲁丝一区二区三区| 欧美午夜无遮挡| 亚洲第一视频在线| 久久精品国产69国产精品亚洲| 网友自拍亚洲| 激情伦成人综合小说| 欧美不卡一区| 国产xxxxhd| 中文字幕日韩一区| 亚洲永久精品一区| 亚洲人高潮女人毛茸茸| aaa在线播放视频| 国产91视觉| 欧美日本国产| 制服下的诱惑暮生| 成人欧美一区二区三区小说| 在线观看日韩一区二区| 一区二区三区四区在线观看视频| 涩涩av在线| 久久手机视频| 亚洲影视综合| 精品1卡二卡三卡四卡老狼| 亚洲精品国产品国语在线app| 亚洲熟妇无码久久精品| 色诱女教师一区二区三区| 巨大黑人极品videos精品| 日韩精品另类天天更新| 视频一区二区不卡| 国产传媒国产传媒| 色av一区二区| 男人天堂资源在线| 欧洲成人在线观看| 国产一区二区在线| 国产视频在线视频| 国产日韩v精品一区二区| 成人a v视频| 色噜噜狠狠狠综合曰曰曰| 欧美jizz18| 伊人久久av导航| 国产一区二区精品久久| 欧美三级免费看| 7777精品伊人久久久大香线蕉完整版| 浪潮av一区| 俄罗斯精品一区二区三区| 韩国亚洲精品| 成熟妇人a片免费看网站| 欧美日韩国产一中文字不卡| 天堂在线观看免费视频| 欧美在线观看一区二区三区| 免费电影一区二区三区| 日本va中文字幕| 亚洲视频一区二区免费在线观看| va婷婷在线免费观看| 亚州av一区二区| 国产一区二区三区日韩精品| 天天干天天色天天干| 亚洲黄色性网站| 午夜福利视频一区二区| 国产精品久久久久国产a级| 亚洲国产精品综合久久久| 免费观看污网站| 色老汉av一区二区三区| av片在线观看| 鲁鲁狠狠狠7777一区二区| 捆绑调教美女网站视频一区| 欧美色图一区二区| 亚洲欧美国产精品专区久久| 欧美美女福利视频| 黄色激情在线视频| 中文字幕av一区二区三区高| 国产高中女学生第一次| 奇米4444一区二区三区| 欧美成人激情| 久久人人妻人人人人妻性色av| 欧美性生活一区| 国产盗摄精品一区二区酒店| 日韩亚洲不卡在线| 丁香桃色午夜亚洲一区二区三区| 免费污污视频在线观看| 欧美精品在线播放| 精品精品99| 扒开伸进免费视频| 欧美色成人综合|