JavaÄÚ´æÄ£ÐÍ
ÔÚÁ˽âJavaµÄͬ²½ÃØÃÜ֮ǰ£¬ÏÈÀ´¿´¿´JMM(Java Memory Model)¡£
Java±»Éè¼ÆΪ¿çƽ̨µÄÓïÑÔ£¬ÔÚÄÚ´æ¹ÜÀíÉÏ£¬ÏÔȻҲҪÓÐÒ»¸öͳһµÄÄ£ÐÍ¡£¶øÇÒJavaÓïÑÔ×î´óµÄÌصã¾ÍÊǷϳýÁËÖ¸Õ룬°Ñ³ÌÐòÔ±´ÓÍ´¿àÖнâÍѳöÀ´£¬²»ÓÃÔÙ¿¼ÂÇÄÚ´æʹÓú͹ÜÀí·½ÃæµÄÎÊÌâ¡£
¿ÉϧÊÀÊÂ×ܲ»¾¡ÈçÈËÒ⣬ËäÈ»JMMÉè¼ÆÉÏ·½±ãÁ˳ÌÐòÔ±£¬µ«ÊÇËüÔö¼ÓÁËÐéÄâ»úµÄ¸´Ôӳ̶ȣ¬¶øÇÒ»¹µ¼ÖÂijЩ±à³Ì¼¼ÇÉÔÚJavaÓïÑÔÖÐʧЧ¡£
JMMÖ÷ÒªÊÇΪÁ˹涨ÁËÏ̺߳ÍÄÚ´æÖ®¼äµÄһЩ¹Øϵ¡£¶ÔJava³ÌÐòÔ±À´ËµÖ»Ð踺ÔðÓÃsynchronizedͬ²½¹Ø¼ü×Ö£¬ÆäËüÖîÈçÓëÏß³Ì/ÄÚ´æÖ®¼ä½øÐÐÊý¾Ý½»»»/ͬ²½µÈ·±Ëö¹¤×÷¾ùÓÉÐéÄâ»ú¸ºÔðÍê³É¡£Èçͼ1Ëùʾ£º¸ù¾ÝJMMµÄÉè¼Æ£¬ÏµÍ³´æÔÚÒ»¸öÖ÷ÄÚ´æ(Main Memory)£¬JavaÖÐËùÓбäÁ¿¶¼´¢´æÔÚÖ÷´æÖУ¬¶ÔÓÚËùÓÐÏ̶߳¼Êǹ²ÏíµÄ¡£Ã¿ÌõÏ̶߳¼ÓÐ×Ô¼ºµÄ¹¤×÷ÄÚ´æ(Working Memory)£¬¹¤×÷ÄÚ´æÖб£´æµÄÊÇÖ÷´æÖÐijЩ±äÁ¿µÄ¿½±´£¬Ï̶߳ÔËùÓбäÁ¿µÄ²Ù×÷¶¼ÊÇÔÚ¹¤×÷ÄÚ´æÖнøÐУ¬Ïß³ÌÖ®¼äÎÞ·¨Ï໥ֱ½Ó·ÃÎÊ£¬±äÁ¿´«µÝ¾ùÐèҪͨ¹ýÖ÷´æÍê³É¡£
ͼ1 JavaÄÚ´æÄ£ÐÍʾÀýͼ
Ïß³ÌÈôÒª¶Ôij±äÁ¿½øÐвÙ×÷£¬±ØÐë¾¹ýһϵÁв½Ö裺Ê×ÏÈ´ÓÖ÷´æ¸´ÖÆ/Ë¢ÐÂÊý¾Ýµ½¹¤×÷Äڴ棬ȻºóÖ´ÐдúÂ룬½øÐÐÒýÓÃ/¸³Öµ²Ù×÷£¬×îºó°Ñ±äÁ¿ÄÚÈÝд»ØMain Memory¡£JavaÓïÑԹ淶(JLS)ÖжÔÏ̺߳ÍÖ÷´æ»¥²Ù×÷¶¨ÒåÁË6¸öÐÐΪ£¬·Ö±ðΪload£¬save£¬read£¬write£¬assignºÍuse£¬ÕâЩ²Ù×÷ÐÐΪ¾ßÓÐÔ×ÓÐÔ£¬ÇÒÏ໥ÒÀÀµ£¬ÓÐÃ÷È·µÄµ÷ÓÃÏȺó˳Ðò¡£¾ßÌåµÄÃèÊöÇë²Î¼ûJLSµÚ17Õ¡£
ÎÒÃÇÔÚÇ°ÃæµÄÕ½ڽéÉÜÁËsynchronizedµÄ×÷Óã¬ÏÖÔÚ£¬´ÓJMMµÄ½Ç¶ÈÀ´ÖØÐÂÉóÊÓsynchronized¹Ø¼ü×Ö¡£
¼ÙÉèijÌõÏß³ÌÖ´ÐÐÒ»¸ösynchronized´úÂë¶Î£¬Æä¼ä¶Ôij±äÁ¿½øÐвÙ×÷£¬JVM»áÒÀ´ÎÖ´ÐÐÈç϶¯×÷£º
(1) »ñȡͬ²½¶ÔÏómonitor (lock)
(2) ´ÓÖ÷´æ¸´ÖƱäÁ¿µ½µ±Ç°¹¤×÷ÄÚ´æ (read and load)
(3) Ö´ÐдúÂ룬¸Ä±ä¹²Ïí±äÁ¿Öµ (use and assign)
(4) Óù¤×÷ÄÚ´æÊý¾ÝË¢ÐÂÖ÷´æÏà¹ØÄÚÈÝ (store and write)
(5) ÊÍ·Åͬ²½¶ÔÏóËø (unlock)
¿É¼û£¬synchronizedµÄÁíÍâÒ»¸ö×÷ÓÃÊDZ£Ö¤Ö÷´æÄÚÈݺÍÏ̵߳Ť×÷ÄÚ´æÖеÄÊý¾ÝµÄÒ»ÖÂÐÔ¡£Èç¹ûûÓÐʹÓÃsynchronized¹Ø¼ü×Ö£¬JVM²»±£Ö¤µÚ2²½ºÍµÚ4²½»áÑϸñ°´ÕÕÉÏÊö´ÎÐòÁ¢¼´Ö´ÐС£ÒòΪ¸ù¾ÝJLSÖеĹ涨£¬Ï̵߳Ť×÷ÄÚ´æºÍÖ÷´æÖ®¼äµÄÊý¾Ý½»»»ÊÇËÉñîºÏµÄ£¬Ê²Ã´Ê±ºòÐèҪˢй¤×÷ÄÚ´æ»òÕ߸üÐÂÖ÷ÄÚ´æÄÚÈÝ£¬¿ÉÒÔÓɾßÌåµÄÐéÄâ»úʵÏÖ×ÔÐоö¶¨¡£Èç¹û¶à¸öÏß³ÌͬʱִÐÐÒ»¶Îδ¾synchronized±£»¤µÄ´úÂë¶Î£¬ºÜÓпÉÄÜijÌõÏß³ÌÒѾ¸Ä¶¯Á˱äÁ¿µÄÖµ£¬µ«ÊÇÆäËûÏß³ÌÈ´ÎÞ·¨¿´µ½Õâ¸ö¸Ä¶¯£¬ÒÀÈ»ÔھɵÄ
Ïà¹ØÎĵµ£º
Ò»¡¢ ¶¨Òå
·ÅÔÚÒ»¸öÀàµÄÄÚ²¿µÄÀàÎÒÃǾͽÐÄÚ²¿Àà¡£
¶þ¡¢ ×÷ÓÃ
1.ÄÚ²¿Àà¿ÉÒԺܺõÄʵÏÖÒþ²Ø,Ò²¾ÍÊÇ·â×°ÐÔ¡£Ò»°ãµÄ·ÇÄÚ²¿À࣬ÊDz»ÔÊÐíÓÐ private ÓëprotectedȨÏ޵ģ¬µ«ÄÚ²¿Àà¿ÉÒÔ
2.ÄÚ²¿ÀàÓµÓÐÍâΧÀàµÄËùÓÐÔªËصķÃÎÊȨÏÞ
3.¿ÉÊÇʵÏÖ¶àÖؼ̳Ð
4.¿ÉÒÔ±ÜÃâÐ޸ĽӿڶøʵÏÖͬһ¸öÀàÖÐÁ½ÖÖͬÃû·½·¨µÄµ÷ÓÃ
Èý¡¢  ......
Ò»¡¢ÈÏʶ¶àÈÎÎñ¡¢¶à½ø³Ì¡¢µ¥Ï̡߳¢¶àÏß³Ì
ÒªÈÏʶ¶àÏ߳̾ÍÒª´Ó²Ù×÷ϵͳµÄÔÀí˵Æð¡£
ÒÔÇ°¹ÅÀϵÄDOS²Ù×÷ϵͳ£¨V 6.22£©Êǵ¥ÈÎÎñµÄ£¬»¹Ã»ÓÐÏ̵߳ĸÅÄϵͳÔÚÿ´ÎÖ»ÄÜ×öÒ»¼þÊÂÇé¡£±ÈÈçÄãÔÚcopy¶«Î÷µÄʱºò²»ÄÜrenameÎļþÃû¡£ÎªÁËÌá¸ßϵͳµÄÀûÓÃЧÂÊ£¬²ÉÓÃÅú´¦ÀíÀ´ÅúÁ¿Ö´ÐÐÈÎÎñ¡£
ÏÖÔڵIJÙ×÷ϵͳ¶¼ÊǶàÈÎÎñ² ......
JavaỊ̈߳ºÏ̵߳Äͬ²½ÓëËø
Ò»¡¢Í¬²½ÎÊÌâÌá³ö
Ï̵߳Äͬ²½ÊÇΪÁË·ÀÖ¹¶à¸öÏ̷߳ÃÎÊÒ»¸öÊý¾Ý¶ÔÏóʱ£¬¶ÔÊý¾ÝÔì³ÉµÄÆÆ»µ¡£
ÀýÈ磺Á½¸öÏß³ÌThreadA¡¢ThreadB¶¼²Ù×÷ͬһ¸ö¶ÔÏóFoo¶ÔÏ󣬲¢ÐÞ¸ÄFoo¶ÔÏóÉϵÄÊý¾Ý¡£
public class Foo {
private int x = 100;
......
JavaỊ̈߳ºÏ̵߳ĵ÷¶È-Èò½
Ï̵߳ÄÈò½º¬Òå¾ÍÊÇʹµ±Ç°ÔËÐÐ×ÅÏß³ÌÈóöCPU×ÊÔ´£¬µ«ÊÇÈ»¸ø˲»ÖªµÀ£¬½ö½öÊÇÈóö£¬Ïß³Ì״̬»Øµ½¿ÉÔËÐÐ״̬¡£
Ï̵߳ÄÈò½Ê¹ÓÃThread.yield()·½·¨£¬yield() Ϊ¾²Ì¬·½·¨£¬¹¦ÄÜÊÇÔÝÍ£µ±Ç°ÕýÔÚÖ´ÐеÄÏ̶߳ÔÏ󣬲¢Ö´ÐÐÆäËûÏ̡߳£
/**
* JavaỊ̈߳ºÏ̵߳ĵ÷¶È-Èò½
*
......
JavaỊ̈߳ºÏ̵߳ĵ÷¶È-ÊØ»¤Ïß³Ì
ÊØ»¤Ïß³ÌÓëÆÕͨÏß³Ìд·¨ÉÏ»ù±¾Ã´É¶Çø±ð£¬µ÷ÓÃÏ̶߳ÔÏóµÄ·½·¨setDaemon(true)£¬Ôò¿ÉÒÔ½«ÆäÉèÖÃΪÊØ»¤Ï̡߳£
ÊØ»¤Ïß³ÌʹÓõÄÇé¿ö½ÏÉÙ£¬µ«²¢·ÇÎÞÓ㬾ÙÀýÀ´Ëµ£¬JVMµÄÀ¬»ø»ØÊÕ¡¢ÄÚ´æ¹ÜÀíµÈÏ̶߳¼ÊÇÊØ»¤Ï̡߳£»¹ÓоÍÊÇÔÚ×öÊý¾Ý¿âÓ¦ÓÃʱºò£¬Ê¹ÓõÄÊý¾Ý¿âÁ¬½Ó³Ø£¬Á¬½Ó³Ø±¾ÉíÒ²°üº ......