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

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

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



¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­Page¡¡243¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡C¡¡H¡¡AP¡¡TE¡¡R¡¡¡¡¡¡8¡¡¡¡¡¡¡ö¡¡¡¡¡¡¡¡L¡¡E¡¡AR¡¡N¡¡IN¡¡G¡¡¡¡¡¡AB¡¡O¡¡U¡¡T¡¡¡¡¡¡CO¡¡M¡¡P¡¡O¡¡N¡¡E¡¡N¡¡T¡¡O¡¡R¡¡IE¡¡N¡¡TE¡¡D¡¡¡¡¡¡A¡¡R¡¡CH¡¡I¡¡TE¡¡C¡¡TU¡¡R¡¡E¡¡221¡¡



¡¡¡¡¡¡¡¡¡¡¡¡Do¡¡not¡¡confuse¡¡multiple¡¡implementations¡¡with¡¡multiple¡¡implementations¡¡that¡¡offer¡¡a¡¡¡¡

pletely¡¡different¡¡feature¡¡set¡£¡¡For¡¡example£»¡¡controller¡¡version¡¡1¡¡and¡¡controller¡¡version¡¡super

duper¡¡1000¡¡might¡¡control¡¡the¡¡same¡¡room¡¡types£»¡¡but¡¡the¡¡inputs£»¡¡outputs£»¡¡logic£»¡¡and¡¡algorithms¡¡¡¡

contained¡¡in¡¡each¡¡might¡¡be¡¡pletely¡¡different¡£¡¡In¡¡that¡¡case£»¡¡using¡¡an¡¡interface¡¡gains¡¡no¡¡advan

tage¡£¡¡You¡¡might¡¡use¡¡a¡¡version¡¡1¡¡interface¡¡on¡¡a¡¡version¡¡super¡­duper¡¡1000¡¡for¡¡legacy¡¡integration£»¡¡¡¡

since¡¡the¡¡old¡¡interface¡¡has¡¡older¡¡ideas¡£¡¡

¡¡¡¡¡¡¡¡¡¡You¡¡would¡¡use¡¡an¡¡interface¡¡for¡¡the¡¡controller¡¡when¡¡multiple¡¡controllers¡¡implement¡¡the¡¡¡¡

same¡¡interface¡£¡¡You¡¡would¡¡use¡¡an¡¡interface¡¡if¡¡you¡¡want¡¡the¡¡flexibility¡¡to¡¡later¡¡implement¡¡multiple¡¡¡¡

implementations¡¡using¡¡the¡¡same¡¡interface¡£¡¡On¡¡the¡¡other¡¡hand£»¡¡if¡¡there¡¡will¡¡only¡¡ever¡¡be¡¡a¡¡single¡¡¡¡

implementation¡¡for¡¡a¡¡single¡¡interface¡¡declaration£»¡¡it¡¯s¡¡much¡¡easier¡¡to¡¡use¡¡a¡¡class¡¡declared¡¡as¡¡¡¡

Public¡£¡¡

¡¡¡¡¡¡¡¡¡¡¡¡If¡¡you¡¡do¡¡decide¡¡to¡¡declare¡¡the¡¡controller¡¡using¡¡an¡¡interface¡¡and¡¡implementation£»¡¡you¡¡need¡¡¡¡

to¡¡structure¡¡the¡¡project¡¡differently¡¡than¡¡the¡¡organization¡¡used¡¡for¡¡this¡¡chapter¡¯s¡¡example¡£¡¡The¡¡¡¡

reason¡¡is¡¡that¡¡you¡¡cannot¡¡declare¡¡the¡¡interfaces¡¡and¡¡implementations¡¡in¡¡the¡¡same¡¡project¡£¡¡¡¡

Imagine¡¡trying¡¡to¡¡offer¡¡multiple¡¡kernel¡¡implementations£»¡¡but¡¡for¡¡the¡¡users¡¡to¡¡be¡¡able¡¡to¡¡use¡¡the¡¡¡¡

interfaces£»¡¡they¡¡must¡¡reference¡¡a¡¡project¡¡that¡¡contains¡¡a¡¡particular¡¡kernel¡¡implementation¡£¡¡¡¡

¡¡¡¡¡¡¡¡¡¡You¡¡will¡¡need¡¡to¡¡modularize¡¡the¡¡structure¡¡and¡¡have¡¡an¡¡organization¡¡similar¡¡to¡¡that¡¡shown¡¡¡¡

in¡¡Figure¡¡8¡­5¡£¡¡¡¡



Figure¡¡8¡­5¡£¡¡Organization¡¡of¡¡a¡¡modular¡¡interface¡¡and¡¡implementation¡¡architecture¡¡


¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­Page¡¡244¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­

222¡¡¡¡¡¡¡¡¡¡¡¡¡¡CH¡¡AP¡¡T¡¡E¡¡R¡¡¡¡¡¡8¡¡¡¡¡¡¡ö¡¡¡¡¡¡¡¡L¡¡E¡¡A¡¡R¡¡N¡¡IN¡¡G¡¡¡¡¡¡AB¡¡OU¡¡T¡¡¡¡¡¡CO¡¡M¡¡P¡¡O¡¡N¡¡E¡¡N¡¡TO¡¡R¡¡IE¡¡N¡¡T¡¡E¡¡D¡¡¡¡AR¡¡C¡¡HI¡¡TE¡¡CT¡¡U¡¡R¡¡E¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡In¡¡Figure¡¡8¡­5£»¡¡the¡¡individual¡¡boxes¡¡represent¡¡a¡¡single¡¡¡¡assembly¡£¡¡Each¡¡assembly¡¡serves¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡a¡¡unique¡¡purpose£º¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡o¡¡¡¡Definitions£º¡¡An¡¡assembly¡¡that¡¡contains¡¡all¡¡interfaces¡¡used¡¡by¡¡all¡¡of¡¡the¡¡other¡¡assemblies¡£¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡This¡¡represents¡¡a¡¡single¡¡assembly¡¡that¡¡changes¡¡very¡¡rarely¡¡and¡¡is¡¡a¡¡cornerstone¡¡of¡¡the¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡application¡£¡¡Along¡¡with¡¡interfaces£»¡¡you¡¡would¡¡add¡¡general¡¡utility¡¡classes¡¡that¡¡all¡¡assem

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡blies¡¡would¡¡reference¡£¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡o¡¡¡¡User£º¡¡The¡¡main¡¡application¡¡that¡¡interacts¡¡with¡¡the¡¡interfaces¡¡of¡¡objects¡¡that¡¡are¡¡imple

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡mented¡¡in¡¡either¡¡the¡¡Kernel¡¡or¡¡¡¡Implementations¡¡assemblies¡£¡¡The¡¡User¡¡assembly¡¡is¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡responsible¡¡for¡¡wiring¡¡together¡¡all¡¡of¡¡the¡¡types¡£¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡o¡¡¡¡Kernel£º¡¡An¡¡assembly¡¡that¡¡defines¡¡the¡¡main¡¡functionality¡¡of¡¡the¡¡application¡¡and¡¡manipu

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡lates¡¡instances¡¡that¡¡implement¡¡interfaces¡¡from¡¡the¡¡Definitions¡¡assembly¡£¡¡The¡¡kernel¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡does¡¡not¡¡know¡¡where¡¡the¡¡interfaces¡¡are¡¡implemented£»¡¡and¡¡it¡¡expects¡¡some¡¡other¡¡piece¡¡of¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡code¡¡to¡¡know¡¡where¡¡the¡¡implementations¡¡are¡£¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡o¡¡¡¡Implementations£º¡¡An¡¡assembly¡¡that¡¡contains¡¡the¡¡implementations¡¡of¡¡the¡¡interfaces¡¡that¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡the¡¡kernel¡¡manipulates¡£¡¡The¡¡programmer¡¡may¡¡create¡¡a¡¡single¡¡implementation¡¡assembly¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡or¡¡multiple¡¡assemblies¡£¡¡The¡¡implementations¡¡are¡¡only¡¡aware¡¡of¡¡the¡¡Definitions¡¡assembly£»¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡they¡¡are¡¡unaware¡¡of¡¡the¡¡Kernel¡¡assembly¡£¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Building¡¡a¡¡plete¡¡Application¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡All¡¡of¡¡the¡¡code¡¡illustrated¡¡thus¡¡far¡¡is¡¡related¡¡to¡¡the¡¡kernel£»¡¡and¡¡it¡¡would¡¡seem¡¡that¡¡our¡¡applica

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡tion¡¡is¡¡plete¡£¡¡In¡¡reality£»¡¡the¡¡kernel¡¡has¡¡done¡¡nothing¡¡other¡¡than¡¡organize¡¡and¡¡manipulate¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡the¡¡rooms¡£¡¡The¡¡kernel¡¡has¡¡not¡¡defined¡¡any¡¡implementations¡¡for¡¡a¡¡particular¡¡room¡£¡¡Now¡¡let¡¯s¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡see¡¡how¡¡to¡¡define¡¡some¡¡rooms¡¡and¡¡use¡¡the¡¡rooms¡¡in¡¡the¡¡context¡¡of¡¡the¡¡kernel¡£¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡The¡¡idea¡¡is¡¡to¡¡enable¡¡a¡¡developer¡¡to¡¡add¡¡functionality¡¡to¡¡the¡¡kernel¡¡without¡¡affecting¡¡the¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡code¡¡of¡¡the¡¡kernel¡£¡¡The¡¡example¡¡that¡¡we¡¡will¡¡go¡¡through¡¡defines¡¡a¡¡couple¡¡of¡¡rooms¡¡in¡¡a¡¡museum¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡£¨the¡¡Museum¡¡project£©¡£¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡öNote¡¡¡¡The¡¡implementation¡¡of¡¡the¡¡Home¡¡project¡¡is¡¡not¡¡discussed¡¡here£»¡¡but¡¡it¡¡is¡¡available¡¡in¡¡this¡¡book¡¯s¡¡down

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡loadable¡¡source¡¡code¡£¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Defining¡¡Some¡¡Rooms¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡The¡¡rooms¡¡are¡¡defined¡¡in¡¡a¡¡separate¡¡assembly¡¡called¡¡Museum¡¡and¡¡are¡¡not¡¡part¡¡of¡¡the¡¡kernel¡£¡¡The¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡following¡¡is¡¡an¡¡example¡¡of¡¡a¡¡room¡¡implementation¡£¡¡Again£»¡¡remember¡¡to¡¡include¡¡a¡¡reference¡¡to¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡LibLightingSystem¡¡£¨right¡­click¡¡References¡¡in¡¡Museum¡¡and¡¡select¡¡Add¡¡Reference¡¡then¡¡Projects¡¡¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡LibLightingSystem£©¡£¡¡


¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­Page¡¡245¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡C¡¡H¡¡AP¡¡TE¡¡R¡¡¡¡¡¡8¡¡¡¡¡¡¡ö¡¡¡¡¡¡¡¡L¡¡E¡¡AR¡¡N¡¡IN¡¡G¡¡¡¡¡¡AB¡¡O¡¡U¡¡T¡¡¡¡¡¡CO¡¡M¡¡P¡¡O¡¡N¡¡E¡¡N¡¡T¡¡O¡¡R¡¡IE¡¡N¡¡TE¡¡D¡¡¡¡¡¡A¡¡R¡¡CH¡¡I¡¡TE¡¡C¡¡TU¡¡R¡¡E¡¡223¡¡



¡£¡¡¡£¡¡¡£¡¡

Imports¡¡LibLightingSystem¡¡



¡¡¡¡¡¡¡¡Friend¡¡Class¡¡PrivateRoom¡¡£º¡¡Implements¡¡INoRemoteControlRoom¡¡¡¡

¡¡¡¡¡¡¡¡End¡¡Class¡¡



¡¡¡¡¡¡¡¡Friend¡¡Class¡¡PublicRoom¡¡£º¡¡Implements¡¡ISensorRoom¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Public¡¡ReadOnly¡¡Property¡¡IsPersonInRoom£¨£©¡¡As¡¡Boolean¡¡_¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Implements¡¡ISensorRoom¡£IsPersonInRoom¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Get¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Return¡¡False¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡End¡¡Get¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡End¡¡Property¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Private¡¡_lightLevel¡¡As¡¡Double¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Public¡¡ReadOnly¡¡Property¡¡LightLevel£¨£©¡¡As¡¡Double¡¡_¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Implements¡¡ISensorRoom¡£LightLevel¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Get¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Return¡¡_lightLevel¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡End¡¡Get¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡End¡¡Property¡¡¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Public¡¡Sub¡¡LightSwitch£¨ByVal¡¡lightState¡¡As¡¡Boolean£©¡¡_¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Implements¡¡IRemoteControlRoom¡£LightSwitch¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡If¡¡lightState¡¡Then¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡_lightLevel¡¡=¡¡1¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Else¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡_lightLevel¡¡=¡¡0¡¡

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

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡End¡¡Sub¡¡¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Public¡¡Sub¡¡DimLight£¨ByVal¡¡level¡¡As¡¡Double£©¡¡_¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Implements¡¡IRemoteControlRoom¡£DimLight¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡_lightLevel¡¡=¡¡level¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡End¡¡Sub¡¡

¡¡¡¡¡¡¡¡End¡¡Class¡¡



¡¡¡¡¡¡¡¡¡¡The¡¡two¡¡room¡¡declarations£»¡¡PrivateRoom¡¡and¡¡¡¡PublicRoom£»¡¡are¡¡both¡¡internal¡¡to¡¡the¡¡assembly¡£¡¡¡¡

Each¡¡room¡¡implements¡¡the¡¡interface¡¡that¡¡it¡¡deems¡¡appropriate¡£¡¡PrivateRoom¡¡implements¡¡the¡¡¡¡

interface¡¡INoRemoteControlRoom£»¡¡indicating¡¡that¡¡LightingController¡¡should¡¡leave¡¡the¡¡room¡¡alone¡£¡¡¡¡

¡¡¡¡¡¡¡¡¡¡PublicRoom¡¡implements¡¡ISensorRoom£»¡¡indicating¡¡that¡¡it¡¡will¡¡tell¡¡the¡¡controller¡¡when¡¡a¡¡person¡¡is¡¡¡¡

in¡¡the¡¡room¡¡and¡¡allow¡¡itself¡¡to¡¡be¡¡controlled¡£¡¡The¡¡implementation¡¡of¡¡¡¡PublicRoom¡¡is¡¡trivial¡¡and¡¡¡¡

frankly¡¡not¡¡that¡¡useful£»¡¡but¡¡it¡¡illustrates¡¡the¡¡bare¡¡minimum¡¡of¡¡what¡¡needs¡¡to¡¡be¡¡implemented¡£¡¡¡¡

In¡¡a¡¡production¡¡environment£»¡¡PublicRoom¡¡would¡¡have¡¡access¡¡to¡¡external¡¡devices¡¡such¡¡as¡¡a¡¡¡¡

heat¡¡sensor¡¡and¡¡lights¡£¡¡The¡¡objective¡¡of¡¡PublicRoom¡¡would¡¡be¡¡to¡¡give¡¡and¡¡take¡¡signals¡¡from¡¡the¡¡¡¡

LightingController¡¡and¡¡take¡¡action¡£¡¡It¡¡is¡¡not¡¡up¡¡to¡¡PublicRoom¡¡to¡¡ask¡¡whether¡¡or¡¡not¡¡a¡¡decision¡¡¡¡


¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­Page¡¡246¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­

224¡¡¡¡¡¡¡¡¡¡¡¡¡¡CH¡¡AP¡¡T¡¡E¡¡R¡¡¡¡¡¡8¡¡¡¡¡¡¡ö¡¡¡¡¡¡¡¡L¡¡E¡¡A¡¡R¡¡N¡¡IN¡¡G¡¡¡¡¡¡AB¡¡OU¡¡T¡¡¡¡¡¡CO¡¡M¡¡P¡¡O¡¡N¡¡E¡¡N¡¡TO¡¡R¡¡IE¡¡N¡¡T¡¡E¡¡D¡¡¡¡AR¡¡C¡¡HI¡¡TE¡¡CT¡¡U¡¡R¡¡E¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡is¡¡correct¡£¡¡For¡¡example£»¡¡if¡¡¡¡LightingController¡¡indicated¡¡to¡¡turn¡¡the¡¡light¡¡off¡¡even¡¡though¡¡a¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡person¡¡is¡¡in¡¡the¡¡room£»¡¡then¡¡PublicRoom¡¡would¡¡not¡¡ask¡¡why¡¡the¡¡light¡¡is¡¡being¡¡turned¡¡off¡£¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡öNote¡¡¡¡When¡¡you¡¡are¡¡designing¡¡a¡¡kernel¡­like¡¡architecture£»¡¡the¡¡implementations¡¡are¡¡realizations¡¡of¡¡ideas¡¡and¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡should¡¡never¡¡question¡¡the¡¡controller¡£¡¡The¡¡implementations¡¡might¡¡not¡¡be¡¡aware¡¡of¡¡a¡¡bigger¡¡picture¡¡and¡¡thus¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡might¡¡prevent¡¡an¡¡algorithm¡¡from¡¡functioning¡¡properly¡£¡¡Of¡¡course£»¡¡the¡¡exception¡¡to¡¡this¡¡rule¡¡is¡¡if¡¡the¡¡decision¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡would¡¡cause¡¡physical¡¡damage¡¡or¡¡cause¡¡the¡¡program¡¡to¡¡crash¡£¡¡In¡¡that¡¡case£»¡¡the¡¡implementation¡¡should¡¡throw¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡an¡¡exception£»¡¡indicating¡¡that¡¡the¡¡decision¡¡is¡¡faulty¡£¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Instantiating¡¡PublicRoom¡¡and¡¡PrivateRoom¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡As¡¡described¡¡in¡¡the¡¡previous¡¡chapter£»¡¡when¡¡you¡¡are¡¡developing¡¡ponents£»¡¡you¡¡want¡¡to¡¡separate¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡the¡¡interfaces¡¡from¡¡the¡¡implementations¡£¡¡This¡¡gives¡¡you¡¡the¡¡flexibility¡¡to¡¡change¡¡the¡¡imple

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡mentation¡¡in¡¡an¡¡assembly¡¡without¡¡requiring¡¡the¡¡users¡¡of¡¡the¡¡assembly¡¡to¡¡repile¡¡their¡¡code¡£¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡To¡¡instantiate¡¡the¡¡implementations£»¡¡you¡¡need¡¡a¡¡factory£»¡¡and¡¡the¡¡museum¡¡with¡¡its¡¡PrivateRoom¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡and¡¡PublicRoom¡¡implementations¡¡is¡¡no¡¡different¡£¡¡However£»¡¡a¡¡builder¡¡method¡¡that¡¡assembles¡¡a¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡building¡¡of¡¡potential¡¡PrivateRoom¡¡and¡¡¡¡PublicRoom¡¡binations¡¡will¡¡be¡¡offered¡¡with¡¡the¡¡museum¡£¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡The¡¡builder¡¡method¡¡is¡¡useful¡¡because¡¡it¡¡predefines¡¡a¡¡canned¡¡building¡¡that¡¡has¡¡all¡¡the¡¡room¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡groupings¡¡and¡¡rooms¡¡properly¡¡added¡£¡¡¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡öNote¡¡¡¡Think¡¡of¡¡a¡¡builder¡¡method¡¡as¡¡a¡¡way¡¡of¡¡creating¡¡a¡¡predefined¡¡structure£»¡¡thus¡¡saving¡¡users¡¡from¡¡having¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡to¡¡do¡¡that¡¡themselves¡£¡¡A¡¡builder¡¡method¡¡is¡¡only¡¡a¡¡starting¡¡point£»¡¡and¡¡you¡¡should¡¡be¡¡able¡¡to¡¡manipulate¡¡the¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡structure¡¡afterward¡¡for¡¡fine¡­tuning¡¡purposes¡£¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡The¡¡following¡¡is¡¡the¡¡implementation¡¡of¡¡the¡¡museum¡¡factory£»¡¡which¡¡is¡¡added¡¡to¡¡the¡¡project¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Museum¡£¡¡



¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Public¡¡Module¡¡FactoryRooms¡¡¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Public¡¡Function¡¡CreateBuilding£¨£©¡¡As¡¡LightingController¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Dim¡¡controller¡¡As¡¡New¡¡LightingController£¨£©¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Dim¡¡publicAreas¡¡As¡¡Object¡¡=¡¡_¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡controller¡£AddRoomGrouping£¨¡¨public¡¡viewing¡¡areas¡¨£©¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Dim¡¡privateAreas¡¡As¡¡Object¡¡=¡¡_¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡controller¡£AddRoomGrouping£¨¡¨private¡¡viewing¡¡areas¡¨£©¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡controller¡£AddRoomToGrouping£¨publicAreas£»¡¡New¡¡PublicRoom£¨£©£©¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡controller¡£AddRoomToGrouping£¨privateAreas£»¡¡New¡¡PrivateRoom£¨£©£©¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Return¡¡controller¡¡

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


¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­Page¡¡247¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­¡­

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡C¡¡H¡¡AP¡¡TE¡¡R¡¡¡¡¡¡8¡¡¡¡¡¡¡ö¡¡¡¡¡¡¡¡L¡¡E¡¡AR¡¡N¡¡IN¡¡G¡¡¡¡¡¡AB¡¡O¡¡U¡¡T¡¡¡¡¡¡CO¡¡M¡¡P¡¡O¡¡N¡¡E¡¡N¡¡T¡¡O¡¡R¡¡IE¡¡N¡¡TE¡¡D¡¡¡¡¡¡A¡¡R¡¡CH¡¡I¡¡TE¡¡C¡¡TU¡¡R¡¡E¡¡225¡¡



¡¡¡¡¡¡¡¡Public¡¡Function¡¡CreatePrivateRoom£¨£©¡¡As¡¡IRoom¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Return¡¡New¡¡PrivateRoom£¨£©¡¡

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



¡¡¡¡¡¡¡¡Public¡¡Function¡¡CreatePublicRoom£¨£©¡¡As¡¡IRoom¡¡

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Return¡¡New¡¡PublicRoom£¨£©¡¡

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

End¡¡Module¡¡



¡¡¡¡¡¡¡¡¡¡The¡¡implementation¡¡has¡¡three¡¡methods£º¡¡CreateBuilding£¨£©£»¡¡CreatePrivateRoom£¨£©£»¡¡and¡¡¡¡

CreatePublicRoom£¨£©£»¡£¡¡The¡¡fact¡¡that¡¡CreatePrivateRoom£¨£©¡¡and¡¡PrivateRoom£¨£©¡¡have¡¡similar¡¡naming¡¡is¡¡¡¡

purely¡¡coincidental¡£¡¡The¡¡method¡¡could¡¡just¡¡as¡¡well¡¡have¡¡been¡¡called¡¡CreateNonControlledRoom£¨£©¡£¡¡¡¡

The¡¡CreatePrivateRoom£¨£©¡¡and¡¡CreatePublicRoom£¨£©¡¡methods¡¡are¡¡intended¡¡to¡¡define¡¡method¡¡¡¡

identifiers¡¡that¡¡users¡¡can¡¡understand¡£¡¡What¡¡is¡¡instantiated¡¡in¡¡the¡¡method¡¡must¡¡return¡¡an¡¡IRoom¡¡¡¡

instance¡£¡¡

¡¡¡¡¡¡¡¡¡¡The¡¡CreateBuilding£¨£©¡¡method¡¡is¡¡a¡¡builder¡¡method£»¡¡and¡¡it¡¡returns¡¡a¡¡¡¡LightingController¡¡¡¡

instance¡£¡¡It¡¡is¡¡fine¡¡to¡¡return¡¡a¡¡LightingController¡¡instance£»¡¡because¡¡it¡¡is¡¡a¡¡globally¡¡defined¡¡type¡¡¡¡

and¡¡can¡¡serve¡¡as¡¡a¡¡basis¡¡fo
·µ»ØĿ¼ ÉÏÒ»Ò³ ÏÂÒ»Ò³ »Øµ½¶¥²¿ ÔÞ£¨0£© ²È£¨0£©
¿ì½Ý²Ù×÷: °´¼üÅÌÉÏ·½Ïò¼ü ¡û »ò ¡ú ¿É¿ìËÙÉÏÏ·­Ò³ °´¼üÅÌÉ쵀 Enter ¼ü¿É»Øµ½±¾ÊéĿ¼ҳ °´¼üÅÌÉÏ·½Ïò¼ü ¡ü ¿É»Øµ½±¾Ò³¶¥²¿!
ÎÂÜ°Ìáʾ£º ο´Ð¡ËµµÄͬʱ·¢±íÆÀÂÛ£¬Ëµ³ö×Ô¼ºµÄ¿´·¨ºÍÆäËüС»ï°éÃÇ·ÖÏíÒ²²»´íŶ£¡·¢±íÊéÆÀ»¹¿ÉÒÔ»ñµÃ»ý·ÖºÍ¾­Ñé½±Àø£¬ÈÏÕæдԭ´´ÊéÆÀ ±»²ÉÄÉΪ¾«ÆÀ¿ÉÒÔ»ñµÃ´óÁ¿½ð±Ò¡¢»ý·ÖºÍ¾­Ñé½±ÀøŶ£¡