ÓÑÇéÌáʾ£ºÈç¹û±¾ÍøÒ³´ò¿ªÌ«Âý»òÏÔʾ²»ÍêÕû£¬Çë³¢ÊÔÊó±êÓÒ¼ü¡°Ë¢Ð¡±±¾ÍøÒ³£¡
µÚÈýµç×ÓÊé ·µ»Ø±¾ÊéĿ¼ ¼ÓÈëÊéÇ© ÎÒµÄÊé¼Ü ÎÒµÄÊéÇ© TXTÈ«±¾ÏÂÔØ ¡ºÊղص½ÎÒµÄä¯ÀÀÆ÷¡»

VB2008´ÓÈëÃŵ½¾«Í¨(PDF¸ñʽӢÎÄ°æ)-µÚ81²¿·Ö

¿ì½Ý²Ù×÷: °´¼üÅÌÉÏ·½Ïò¼ü ¡û »ò ¡ú ¿É¿ìËÙÉÏÏ·­Ò³ °´¼üÅÌÉ쵀 Enter ¼ü¿É»Øµ½±¾ÊéĿ¼ҳ °´¼üÅÌÉÏ·½Ïò¼ü ¡ü ¿É»Øµ½±¾Ò³¶¥²¿! Èç¹û±¾ÊéûÓÐÔĶÁÍ꣬ÏëÏ´μÌÐø½Ó×ÅÔĶÁ£¬¿ÉʹÓÃÉÏ·½ "Êղص½ÎÒµÄä¯ÀÀÆ÷" ¹¦ÄÜ ºÍ "¼ÓÈëÊéÇ©" ¹¦ÄÜ£¡


¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡sheetAverage¡£AssignCellCalculation£¨row£»¡¡1£»¡¡_¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Function£¨worksheet¡¡As¡¡IWorksheet£¨Of¡¡Double£©£»¡¡cellRow¡¡As¡¡Integer£»¡¡_¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡cellCol¡¡As¡¡Integer£©¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡£¨worksheet¡£GetCellState£¨cellRow£»¡¡0£©¡¡_¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡worksheet¡£Calculate£¨items¡£Length£»¡¡0£©£©£©¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Next¡¡row¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡The¡¡number¡¡of¡¡cell¡­state¡¡calculations¡¡depends¡¡on¡¡the¡¡count¡¡of¡¡numbers¡¡in¡¡items¡£¡¡Each¡¡cell¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡calculation¡¡is¡¡assigned¡¡a¡¡locally¡¡declared¡¡lambda¡¡expression£»¡¡meaning¡¡that¡¡the¡¡lambda¡¡expres

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡sions¡¡of¡¡all¡¡cell¡¡states¡¡will¡¡be¡¡identical¡¡and¡¡share¡¡the¡¡same¡¡state¡£¡¡The¡¡only¡¡shared¡¡variable¡¡is¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡items¡£Length¡£¡¡All¡¡the¡¡lambda¡¡expressions¡¡expect¡¡the¡¡same¡¡length£»¡¡and¡¡so¡¡it¡¡is¡¡acceptable¡¡to¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡share¡¡this¡¡variable¡£¡¡The¡¡average¡¡difference¡¡is¡¡calculated¡¡by¡¡calculating¡¡the¡¡average¡¡and¡¡then¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡subtracting¡¡it¡¡from¡¡the¡¡worksheet¡¡cell¡¡item¡¡value¡¡that¡¡is¡¡in¡¡the¡¡zeroth¡¡column¡£¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Finally£»¡¡when¡¡everything¡¡is¡¡assigned£»¡¡you¡¡can¡¡call¡¡the¡¡worksheet¡£Calculate£¨£©¡¡method¡¡to¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡calculate¡¡the¡¡average¡¡and¡¡difference¡¡from¡¡the¡¡average¡£¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡sheetAverage¡£Calculate£¨£©¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Console¡£WriteLine£¨sheetAverage¡£ToString£¨£©£©¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Understanding¡¡Why¡¡the¡¡Calculation¡¡Worked¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡The¡¡cell¡¡calculations¡¡work¡¡because¡¡the¡¡spreadsheet¡¡has¡¡the¡¡ability¡¡to¡¡track¡¡what¡¡has¡¡been¡¡calculated¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡and¡¡what¡¡has¡¡not¡¡been¡¡calculated¡£¡¡In¡¡a¡¡typical¡¡spreadsheet£»¡¡you¡¡can¡¡change¡¡one¡¡cell¡¡in¡¡a¡¡sheet¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡and¡¡have¡¡everything¡¡magically¡¡recalculate¡£¡¡There¡¡is¡¡no¡¡such¡¡feature¡¡for¡¡this¡¡spreadsheet¡£¡¡However£»¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡this¡¡simpler¡¡spreadsheet¡¡version¡¡can¡¡make¡¡sure¡¡that¡¡when¡¡there¡¡are¡¡dependencies£»¡¡they¡¡are¡¡not¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡calculated¡¡multiple¡¡times¡£¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Look¡¡back¡¡at¡¡the¡¡source¡¡code¡¡to¡¡calculate¡¡the¡¡difference¡¡between¡¡the¡¡average¡¡and¡¡a¡¡number¡£¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡The¡¡only¡¡reason¡¡the¡¡calculation¡¡worked¡¡is¡¡that¡¡the¡¡cell¡¡that¡¡contained¡¡the¡¡average¡¡was¡¡called¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡using¡¡the¡¡Calculate£¨£©¡¡method¡£¡¡Had¡¡the¡¡GetCellState£¨£©¡¡method¡¡been¡¡used£»¡¡the¡¡average¡¡might¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡not¡¡have¡¡been¡¡calculated£»¡¡and¡¡thus¡¡the¡¡difference¡¡calculation¡¡would¡¡have¡¡been¡¡corrupted¡£¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡But¡¡having¡¡each¡¡and¡¡every¡¡cell¡¡calculate¡¡the¡¡average¡¡whenever¡¡a¡¡small¡¡change¡¡is¡¡made¡¡is¡¡a¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡waste¡¡of¡¡resources£»¡¡since¡¡the¡¡change¡¡might¡¡not¡¡affect¡¡a¡¡cell¡¡that¡¡is¡¡recalculated¡£¡¡To¡¡avoid¡¡this£»¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡built¡¡into¡¡the¡¡spreadsheet¡¡is¡¡a¡¡version¡­control¡¡mechanism¡¡that¡¡calculates¡¡a¡¡cell¡¡to¡¡the¡¡latest¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡version¡£¡¡Then£»¡¡if¡¡another¡¡calculation¡¡is¡¡called¡¡with¡¡the¡¡same¡¡version¡¡number£»¡¡the¡¡value¡¡is¡¡retrieved¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡from¡¡the¡¡cell¡¡state¡£¡¡The¡¡following¡¡is¡¡the¡¡code¡¡from¡¡Worksheet£¨Of¡¡BaseType£©¡¡that¡¡manages¡¡the¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡version¡¡number¡£¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Public¡¡Function¡¡Calculate£¨ByVal¡¡row¡¡As¡¡Integer£»¡¡ByVal¡¡col¡¡As¡¡Integer£©¡¡As¡¡BaseType¡¡_¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Implements¡¡IWorksheet£¨Of¡¡BaseType£©¡£Calculate¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡If¡¡£¨CurrVersion¡¡¡·¡¡CalculationVersion£¨row£»¡¡col£©£©¡¡Then¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡CellState£¨row£»¡¡col£©¡¡=¡¡Cells£¨row£»¡¡col£©£¨Me£»¡¡row£»¡¡col£©¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡CalculationVersion£¨row£»¡¡col£©¡¡=¡¡CurrVersion¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡End¡¡If¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Return¡¡CellState£¨row£»¡¡col£©¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡End¡¡Function¡¡


¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­Page¡¡333¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡CH¡¡AP¡¡T¡¡E¡¡R¡¡¡¡¡¡1¡¡1¡¡¡¡¡¡¡ö¡¡¡¡¡¡¡¡L¡¡E¡¡A¡¡R¡¡N¡¡IN¡¡G¡¡¡¡¡¡AB¡¡O¡¡U¡¡T¡¡¡¡¡¡¡£¡¡N¡¡E¡¡T¡¡¡¡G¡¡E¡¡N¡¡E¡¡R¡¡I¡¡CS¡¡311¡¡



Public¡¡Sub¡¡Calculate£¨£©¡¡Implements¡¡IWorksheet£¨Of¡¡BaseType£©¡£Calculate¡¡

¡¡¡¡¡¡¡¡CurrVersion¡¡£«=¡¡1¡¡

¡¡¡¡¡¡¡¡Dim¡¡row¡¡As¡¡Integer¡¡

¡¡¡¡¡¡¡¡For¡¡row¡¡=¡¡0¡¡To¡¡Cells¡£GetLength£¨0£©¡¡1¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Dim¡¡col¡¡As¡¡Integer¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡For¡¡col¡¡=¡¡0¡¡To¡¡Cells¡£GetLength£¨1£©¡¡1¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡If¡¡Cells£¨row£»¡¡col£©¡¡IsNot¡¡Nothing¡¡Then¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Calculate£¨row£»¡¡col£©¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡End¡¡If¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Next¡¡col¡¡

¡¡¡¡¡¡¡¡Next¡¡row¡¡

End¡¡Sub¡¡



¡¡¡¡¡¡¡¡¡¡Calling¡¡the¡¡method¡¡Calculate£¨£©¡¡without¡¡parameters¡¡indicates¡¡a¡¡desire¡¡to¡¡recalculate¡¡the¡¡¡¡

entire¡¡spreadsheet¡£¡¡In¡¡the¡¡implementation¡¡of¡¡Calculate£¨£©£»¡¡the¡¡variable¡¡CurrVersion£»¡¡which¡¡¡¡

represents¡¡the¡¡version¡¡number¡¡of¡¡the¡¡current¡¡calculation£»¡¡is¡¡incremented¡£¡¡Then¡¡each¡¡cell¡¡is¡¡iter

ated£»¡¡and¡¡if¡¡it¡¡exists£»¡¡the¡¡individual¡¡cell¡¡form¡¡of¡¡Calculate£¨£©¡¡£¨Calculate£¨£©¡¡with¡¡the¡¡parameters¡¡row¡¡¡¡

and¡¡col£©¡¡is¡¡called¡£¡¡In¡¡the¡¡individual¡¡cell¡¡form¡¡of¡¡Calculate£¨£©£»¡¡a¡¡check¡¡is¡¡made¡¡to¡¡see¡¡if¡¡the¡¡calcu

lation¡¡version¡¡number¡¡of¡¡the¡¡cell¡¡is¡¡the¡¡latest¡¡of¡¡the¡¡spreadsheet£»¡¡if¡¡not£»¡¡the¡¡cell¡¯s¡¡lambda¡¡expression¡¡¡¡

is¡¡called¡£¡¡After¡¡the¡¡new¡¡CellState¡¡has¡¡been¡¡assigned£»¡¡the¡¡cell¡­state¡¡version¡¡number¡¡is¡¡incre

mented£»¡¡and¡¡the¡¡cell¡¡state¡¡is¡¡returned¡£¡¡



¡öNote¡¡¡¡The¡¡calculation¡¡of¡¡the¡¡spreadsheet¡¡is¡¡nothing¡¡earth¡­shattering£»¡¡and¡¡you¡¡might¡¡be¡¡tempted¡¡to¡¡argue¡¡¡¡

it¡¡is¡¡irrelevant¡¡to¡¡the¡¡scope¡¡of¡¡the¡¡book¡£¡¡In¡¡fact£»¡¡the¡¡calculation¡¡and¡¡its¡¡side¡¡effects¡¡are¡¡of¡¡major¡¡relevance¡£¡¡With¡¡¡¡

lambda¡¡expressions£»¡¡you¡¡have¡¡a¡¡form¡¡of¡¡asynchronous¡¡processing£»¡¡very¡¡much¡¡like¡¡a¡¡spreadsheet¡£¡¡The¡¡cell¡¡¡¡

calculations¡¡of¡¡the¡¡spreadsheet¡¡do¡¡not¡¡know¡¡when¡¡they¡¡will¡¡be¡¡called£»¡¡and¡¡they¡¡cannot¡¡make¡¡assumptions¡¡¡¡

about¡¡the¡¡state¡£¡¡Thus£»¡¡when¡¡a¡¡lambda¡¡expression¡¡is¡¡created£»¡¡the¡¡state¡¡at¡¡the¡¡time¡¡of¡¡the¡¡lambda¡¡expression¡¡¡¡

may¡¡not¡¡be¡¡the¡¡same¡¡as¡¡when¡¡the¡¡lambda¡¡expression¡¡is¡¡executed¡£¡¡If¡¡you¡¡are¡¡not¡¡acutely¡¡aware¡¡of¡¡this¡¡potential¡¡¡¡

pitfall£»¡¡you¡¡could¡¡have¡¡some¡¡major¡¡bugs¡¡in¡¡your¡¡code¡£¡¡¡¡



The¡¡Important¡¡Stuff¡¡to¡¡Remember¡¡



In¡¡this¡¡chapter£»¡¡you¡¡learned¡¡how¡¡to¡¡use¡¡¡¡generics¡¡and¡¡also¡¡expanded¡¡your¡¡knowledge¡¡of¡¡¡¡

lambda¡¡expressions¡£¡¡The¡¡main¡¡items¡¡to¡¡remember¡¡are¡¡as¡¡follows£º¡¡



¡¡¡¡¡¡¡¡¡¡o¡¡¡¡¡¡generics¡¡code¡¡can¡¡use¡¡¡¡generics£»¡¡or¡¡it¡¡can¡¡be¡¡code¡¡that¡¡provides¡¡types¡¡based¡¡on¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡generics¡£¡¡



¡¡¡¡¡¡¡¡¡¡o¡¡¡¡Performance¡¡and¡¡type¡­safe¡¡characteristics¡¡are¡¡primary¡¡reasons¡¡for¡¡using¡¡¡¡generics¡£¡¡



¡¡¡¡¡¡¡¡¡¡o¡¡¡¡You¡¡can¡¡use¡¡¡¡generics¡¡at¡¡the¡¡type¡¡level¡¡or¡¡at¡¡the¡¡method¡¡level¡£¡¡Using¡¡¡¡generics¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡at¡¡the¡¡type¡¡level¡¡implies¡¡concretizing¡¡the¡¡type¡¡when¡¡the¡¡type¡¡is¡¡instantiated¡£¡¡Using¡¡¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡generics¡¡at¡¡the¡¡method¡¡level¡¡implies¡¡concretizing¡¡the¡¡type¡¡when¡¡the¡¡method¡¡is¡¡called¡£¡¡



¡¡¡¡¡¡¡¡¡¡o¡¡¡¡Lambda¡¡expressions¡¡may¡¡be¡¡shared¡¡state¡¡or¡¡individual¡¡state£»¡¡depending¡¡on¡¡how¡¡they¡¡are¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡declared¡¡and¡¡manipulated¡£¡¡


¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­Page¡¡334¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­

312¡¡¡¡¡¡¡¡¡¡¡¡¡¡CH¡¡AP¡¡T¡¡E¡¡R¡¡¡¡¡¡1¡¡1¡¡¡¡¡¡¡ö¡¡¡¡¡¡¡¡L¡¡E¡¡A¡¡R¡¡N¡¡I¡¡N¡¡G¡¡¡¡¡¡A¡¡B¡¡OU¡¡T¡¡¡¡¡¡¡£¡¡N¡¡E¡¡T¡¡¡¡G¡¡E¡¡N¡¡E¡¡R¡¡I¡¡CS¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡o¡¡¡¡For¡¡plex¡¡types£»¡¡you¡¡should¡¡always¡¡implement¡¡ToString£¨£©¡¡as¡¡a¡¡way¡¡of¡¡figuring¡¡out¡¡the¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡state¡¡of¡¡an¡¡instance¡£¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡o¡¡¡¡Lambda¡¡expressions¡¡act¡¡asynchronously¡£¡¡When¡¡you¡¡use¡¡them£»¡¡remember¡¡to¡¡not¡¡make¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡assumptions¡¡of¡¡a¡¡particular¡¡state¡£¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Some¡¡Things¡¡for¡¡You¡¡to¡¡Do¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡The¡¡following¡¡are¡¡some¡¡exercises¡¡that¡¡allow¡¡you¡¡to¡¡apply¡¡what¡¡you¡¯ve¡¡learned¡¡so¡¡far¡£¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡1¡£¡¡The¡¡Worksheet£¨Of¡¡BaseType£©¡¡class¡¡always¡¡requires¡¡you¡¡to¡¡dimension¡¡the¡¡fixed¡­cell¡¡array¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡ahead¡¡of¡¡time¡£¡¡Change¡¡this¡¡code¡¡so¡¡that¡¡the¡¡number¡¡of¡¡rows¡¡and¡¡columns¡¡can¡¡change¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡dynamically¡£¡¡Remember¡¡that¡¡the¡¡focus¡¡is¡¡on¡¡performance£»¡¡and¡¡the¡¡fastest¡¡approach¡¡is¡¡a¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡fixed¡­dimension¡¡array¡£¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡2¡£¡¡The¡¡average¡¡calculation¡¡knows¡¡how¡¡many¡¡items¡¡there¡¡are¡¡by¡¡the¡¡row¡¡number¡£¡¡Rewrite¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡the¡¡average¡¡calculation¡¡code¡¡so¡¡that¡¡the¡¡user¡¡of¡¡the¡¡average¡¡code¡¡does¡¡not¡¡need¡¡to¡¡deal¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡with¡¡the¡¡plexities¡¡of¡¡adding¡¡more¡¡elements£»¡¡moving¡¡the¡¡cell¡¡calculation£»¡¡and¡¡so¡¡on¡£¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡3¡£¡¡The¡¡methods¡¡Calculate£¨£©¡¡and¡¡GetCellState£¨£©¡¡seem¡¡to¡¡do¡¡the¡¡same¡¡thing¡£¡¡So£»¡¡is¡¡there¡¡a¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡need¡¡to¡¡have¡¡separate¡¡methods£¿¡¡Answer¡¡the¡¡question£»¡¡and¡¡then¡¡make¡¡any¡¡necessary¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡changes¡¡to¡¡the¡¡source¡¡code¡¡based¡¡on¡¡your¡¡answer¡£¡¡


¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­Page¡¡335¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­

C¡¡¡¡H¡¡¡¡A¡¡¡¡P¡¡¡¡T¡¡¡¡E¡¡¡¡R¡¡¡¡¡¡¡¡¡¡1¡¡¡¡2¡¡



¡ö¡¡¡ö¡¡¡ö¡¡



Learning¡¡About¡¡¡¡

Application¡¡Configuration¡¡¡¡

and¡¡Dynamic¡¡Loading¡¡



All¡¡of¡¡the¡¡examples¡¡in¡¡the¡¡preceding¡¡chapters¡¡have¡¡demonstrated¡¡how¡¡to¡¡use¡¡an¡¡application¡¡¡¡

with¡¡a¡¡specific¡¡ponent¡£¡¡You¡¡knew¡¡which¡¡type¡¡to¡¡instantiate£»¡¡which¡¡interface¡¡to¡¡use£»¡¡and¡¡¡¡

which¡¡project¡¡to¡¡reference¡£¡¡In¡¡these¡¡cases£»¡¡you£»¡¡as¡¡the¡¡developer£»¡¡are¡¡in¡¡plete¡¡control£»¡¡and¡¡¡¡

when¡¡your¡¡application¡¡is¡¡built£»¡¡all¡¡of¡¡the¡¡assemblies¡¡pop¡¡out¡¡as¡¡a¡¡nice£»¡¡neat¡¡package¡£¡¡

¡¡¡¡¡¡¡¡¡¡But¡¡what¡¡works¡¡for¡¡the¡¡developer¡¡might¡¡not¡¡necessarily¡¡work¡¡for¡¡others¡£¡¡Let¡¯s¡¡go¡¡back¡¡to¡¡¡¡

the¡¡lighting¡¡system¡¡presented¡¡in¡¡Chapter¡¡8¡£¡¡We¡¡created¡¡a¡¡kernel¡¡that¡¡was¡¡responsible¡¡for¡¡turning¡¡¡¡

on¡¡and¡¡off¡¡the¡¡lights¡£¡¡The¡¡implementations¡¡of¡¡the¡¡individual¡¡rooms¡¡were¡¡in¡¡a¡¡predetermined¡¡¡¡

project¡¡with¡¡a¡¡specific¡¡name¡£¡¡This¡¡architecture¡¡would¡¡not¡¡work¡¡with¡¡a¡¡third¡­party¡¡library£»¡¡because¡¡¡¡

the¡¡kernel¡¡expected¡¡a¡¡project¡¡of¡¡a¡¡certain¡¡name¡£¡¡You¡¡might¡¡be¡¡thinking£»¡¡¡°Heck£»¡¡that¡¯s¡¡easy¡¡to¡¡¡¡

solve¡ªI¡¡just¡¡delete¡¡the¡¡old¡¡project¡¡and¡¡rename¡¡my¡¡project¡¡to¡¡match¡¡the¡¡old¡¡name¡£¡±¡¡That¡¡tech

nique¡¡would¡¡work£»¡¡but¡¡it¡¡would¡¡also¡¡be¡¡an¡¡administrator¡¯s¡¡nightmare¡£¡¡The¡¡solution¡¡is¡¡to¡¡tell¡¡the¡¡¡¡

program£»¡¡¡°For¡¡lighting¡¡room¡¡implementations£»¡¡look¡¡at¡¡this¡¡project¡¡and¡¡these¡¡types¡£¡±¡¡And¡¡to¡¡¡¡

give¡¡the¡¡program¡¡this¡¡information£»¡¡you¡¡define¡¡some¡¡text¡¡in¡¡a¡¡file¡£¡¡A¡¡file¡¡that¡¡tells¡¡a¡¡program¡¡to¡¡do¡¡¡¡

some¡¡task¡¡is¡¡called¡¡a¡¡runtime¡¡configuration¡¡file¡£¡¡

¡¡¡¡¡¡¡¡¡¡This¡¡chapter¡¡focuses¡¡on¡¡two¡¡areas£º¡¡using¡¡application¡¡configuration¡¡files¡¡and¡¡dynamically¡¡¡¡

loading¡¡code¡£¡¡A¡¡related¡¡topic¡¡is¡¡how¡¡much¡¡dynamically¡¡executed¡¡code¡¡should¡¡be¡¡configuration¡¡¡¡

and¡¡how¡¡much¡¡should¡¡be¡¡convention¡£¡¡¡¡



Convention¡¡over¡¡Configuration¡¡



The¡¡question¡¡of¡¡how¡¡to¡¡reference¡¡and¡¡instantiate¡¡classes¡¡is¡¡both¡¡philosophical¡¡and¡¡pragmatic¡£¡¡¡¡

Consider¡¡the¡¡architecture¡¡shown¡¡in¡¡Figure¡¡12¡­1£»¡¡which¡¡is¡¡a¡¡modular¡¡interface¡¡and¡¡implementation¡¡¡¡

that¡¡was¡¡presented¡¡as¡¡an¡¡alternative¡¡architecture¡¡for¡¡the¡¡lighting¡¡system¡¡example¡¡in¡¡Chapter¡¡8¡£¡¡¡¡

In¡¡this¡¡figure£»¡¡each¡¡of¡¡the¡¡boxes¡¡represents¡¡a¡¡single¡¡project£º¡¡a¡¡project¡¡that¡¡contains¡¡the¡¡interface¡¡¡¡

definitions£»¡¡a¡¡project¡¡that¡¡contains¡¡the¡¡implementations£»¡¡and¡¡a¡¡project¡¡that¡¡contains¡¡the¡¡kernel¡£¡¡¡¡

The¡¡idea¡¡of¡¡all¡¡of¡¡these¡¡projects¡¡is¡¡to¡¡make¡¡it¡¡possible¡¡to¡¡update¡¡a¡¡single¡¡project¡¡without¡¡needing¡¡¡¡

to¡¡update¡¡all¡¡of¡¡them¡£¡¡However£»¡¡what¡¡is¡¡not¡¡indicated¡¡in¡¡the¡¡picture¡¡is¡¡the¡¡fact¡¡that¡¡your¡¡appli

cation¡¡must¡¡be¡¡able¡¡to¡¡reference¡¡all¡¡three¡¡projects¡£¡¡If¡¡one¡¡of¡¡those¡¡projects¡¡is¡¡missing£»¡¡you¡¡have¡¡¡¡

a¡¡problem£»¡¡because¡¡your¡¡program¡¡cannot¡¡function¡£¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡313¡¡


¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­Page¡¡336¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­

314¡¡¡¡¡¡¡¡¡¡¡¡¡¡CH¡¡AP¡¡T¡¡E¡¡R¡¡¡¡¡¡1¡¡2¡¡¡¡¡¡¡ö¡¡¡¡¡¡¡¡L¡¡E¡¡A¡¡R¡¡N¡¡I¡¡N¡¡G¡¡¡¡¡¡A¡¡B¡¡OU¡¡T¡¡¡¡¡¡A¡¡PP¡¡L¡¡I¡¡CA¡¡TI¡¡O¡¡N¡¡¡¡¡¡CO¡¡N¡¡F¡¡I¡¡G¡¡U¡¡R¡¡AT¡¡IO¡¡N¡¡¡¡¡¡AN¡¡D¡¡¡¡¡¡D¡¡Y¡¡N¡¡A¡¡M¡¡I¡¡C¡¡¡¡L¡¡O¡¡AD¡¡I¡¡N¡¡G¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Figure¡¡12¡­1¡£¡¡How¡¡ponents¡¡can¡¡be¡¡defined¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡The¡¡referencing¡¡of¡¡individual¡¡projects¡¡is¡¡not¡¡an¡¡issue¡£¡¡The¡¡issue¡¡is¡¡how¡¡each¡¡project¡¡learns¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡about¡¡the¡¡others¡£¡¡In¡¡previous¡¡chapters£»¡¡I¡¡said¡¡that¡¡you¡¡should¡¡use¡¡a¡¡factory£»¡¡because¡¡a¡¡factory¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡takes¡¡away¡¡the¡¡decision¡¡of¡¡what¡¡implementation¡¡to¡¡use¡£¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Let¡¯s¡¡look¡¡at¡¡this¡¡from¡¡the¡¡perspective¡¡of¡¡code¡£¡¡Suppose¡¡the¡¡following¡¡interface¡¡def
·µ»ØĿ¼ ÉÏÒ»Ò³ ÏÂÒ»Ò³ »Øµ½¶¥²¿ ÔÞ£¨0£© ²È£¨0£©
¿ì½Ý²Ù×÷: °´¼üÅÌÉÏ·½Ïò¼ü ¡û »ò ¡ú ¿É¿ìËÙÉÏÏ·­Ò³ °´¼üÅÌÉ쵀 Enter ¼ü¿É»Øµ½±¾ÊéĿ¼ҳ °´¼üÅÌÉÏ·½Ïò¼ü ¡ü ¿É»Øµ½±¾Ò³¶¥²¿!
ÎÂÜ°Ìáʾ£º ο´Ð¡ËµµÄͬʱ·¢±íÆÀÂÛ£¬Ëµ³ö×Ô¼ºµÄ¿´·¨ºÍÆäËüС»ï°éÃÇ·ÖÏíÒ²²»´íŶ£¡·¢±íÊéÆÀ»¹¿ÉÒÔ»ñµÃ»ý·ÖºÍ¾­Ñé½±Àø£¬ÈÏÕæдԭ´´ÊéÆÀ ±»²ÉÄÉΪ¾«ÆÀ¿ÉÒÔ»ñµÃ´óÁ¿½ð±Ò¡¢»ý·ÖºÍ¾­Ñé½±ÀøŶ£¡