偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

使用Scala Actor時(shí)最差(或最好的)編程習(xí)慣?

原創(chuàng)
開發(fā) 后端
Scala Actor是Scala語言的一大亮點(diǎn)。本文是一則有關(guān)Scala Actors的問答,問題是:在使用Scala Actors的時(shí)候有哪些最差的使用習(xí)慣?

【51CTO快譯】前日,在stackoverflow上有一則關(guān)于Scala Actor的問題,很有代表性。該問題的答案對于學(xué)習(xí)Scala Actor的開發(fā)者會有一些幫助。這個問題是:

在使用Scala Actors的時(shí)候有哪些最差的使用習(xí)慣?

(如果還沒有執(zhí)行最好編程習(xí)慣的自信,那么先注重回避最差的習(xí)慣倒不失為一個很好的想法。不過事實(shí)上下面這些答案中已經(jīng)在建議一些優(yōu)良的使用習(xí)慣了。)

51CTO編輯推薦:Scala編程語言專題

下面是一份不錯的答案(譯文):

◆任何地方都不要使用!?,否則會造成系統(tǒng)鎖定。

◆總是從actor類子系統(tǒng)線程發(fā)送消息。如果這意味著要通過actor.actor方法創(chuàng)造一個暫時(shí)的actor類,那么代碼如下:

  1. case ButtonClicked(src) => Actor.actor { controller ! SaveTrade(trdFld.text) }   

◆給你的actor的反應(yīng)(reactions)加一個“其它消息”處理程序。否則就不可能判斷你是否在給一個錯誤的actor類發(fā)送消息:

  1. case other => log.warning(this + " has received unexpected message " + other  

◆對于你的原始actor類,不要使用actor.actor方法,而是用actor類的子類(subclass)。這么做的原因是只有通過子類你才能提供一個敏感toString方法。還有,如果你的日志中到處都有像下面的聲明的話,調(diào)試actor類將非常的困難:

  1. 12:03 [INFO] Sending RequestTrades(2009-10-12) to scala.actors.Actor$anonfun$1  

◆把你系統(tǒng)中的actor類整理成文檔,并明確注明它們接受什么消息,以及它們怎么精確的計(jì)算響應(yīng)。使用actor類會導(dǎo)致標(biāo)準(zhǔn)程序(一般是用一個方法壓縮)通過多個actor類之間的響應(yīng)變成一個復(fù)雜的邏輯網(wǎng)絡(luò)。沒有好的文檔管理很容易搞混。

◆保證你可以跟你的actor類在響應(yīng)循環(huán)之外進(jìn)行通信,從而確定它的狀態(tài)。舉個例子,我總是聲明一個方法,使用一個和下面的編碼類似的MBean調(diào)用。否則,很難看出你的actor類是在運(yùn)行,還是已經(jīng)關(guān)掉,是否有一大長串消息等等。

  1. def reportState = {   
  2.   val _this = this   
  3.   synchronized {   
  4.     val msg = "%s Received request to report state with %d items in mailbox".format(   
  5.                    _this, mailboxSize)    
  6.     log.info(msg)   
  7.   }   
  8.   Actor.actor { _this ! ReportState }   
  9. }   

◆把你的actors連在一起并把trapExit設(shè)置成true,否則它們會悄無聲息的失敗,這意味著你的程序不會按你所設(shè)計(jì)的執(zhí)行,并且當(dāng)消息留在actor的郵箱里時(shí)程序會溢出存儲器。

對于以上這些Scala Actors的使用建議,你有什么看法么?

【編輯推薦】

  1. 從Java走進(jìn)Scala:一步步教你使用Scala Actor
  2. Scala Actor:多線程的基礎(chǔ)學(xué)習(xí)
  3. 十二步學(xué)會Scala(1):從下載安裝到定義方法
  4. Scala講座:面向?qū)ο蠛秃瘮?shù)式的特點(diǎn)總結(jié)
  5. 萬物皆對象:介紹Scala對象
責(zé)任編輯:yangsai 來源: 51CTO.com
相關(guān)推薦

2010-01-15 09:15:09

Scala Actor并發(fā)

2009-08-03 11:07:18

Scala Actor

2009-08-14 11:35:01

Scala Actor

2011-04-13 10:16:41

編程習(xí)慣

2010-09-14 15:34:41

Scala

2018-11-07 10:20:20

職業(yè)科技淘汰

2009-07-09 00:25:00

ScalaSet類Map類

2009-07-09 00:25:00

ScalaListTuple

2017-09-01 11:01:22

開發(fā)編程習(xí)慣

2015-08-17 10:13:35

ios習(xí)慣高效

2011-03-29 12:41:49

編程

2010-11-17 11:31:22

Scala基礎(chǔ)面向?qū)ο?/a>Scala

2009-09-24 09:41:00

Scala講座Scala

2009-06-05 12:54:03

ScalaActor內(nèi)存泄露

2009-07-24 18:02:46

ASP.NET編程

2010-09-14 13:22:17

Scala編程指南Scala

2015-11-16 10:59:02

流量提速降費(fèi)應(yīng)用軟件

2015-08-20 10:50:33

iOS高效編程習(xí)慣

2014-03-06 09:43:54

代碼編程習(xí)慣

2009-01-03 10:40:41

PHP編程代碼
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號