javaÖÐyield(),sleep()ÒÔ¼°wait()µÄÇø±ð
ÍùÍù»ìÏýÁËÕâÈý¸öº¯ÊýµÄʹÓá£
´Ó²Ù×÷ϵͳµÄ½Ç¶È½²£¬os»áά»¤Ò»¸öready queue£¨¾ÍÐ÷µÄÏ̶߳ÓÁУ©¡£²¢ÇÒÔÚijһʱ¿ÌcpuֻΪready queueÖÐλÓÚ¶ÓÁÐÍ·²¿µÄÏ̷߳þÎñ¡£
µ«Êǵ±Ç°ÕýÔÚ±»·þÎñµÄÏ߳̿ÉÄܾõµÃcpuµÄ·þÎñÖÊÁ¿²»¹»ºÃ£¬ÓÚÊÇÌáǰÍ˳ö£¬Õâ¾ÍÊÇyield¡£
»òÕßµ±Ç°ÕýÔÚ±»·þÎñµÄÏß³ÌÐèҪ˯һ»á£¬ÐÑÀ´ºó¼ÌÐø±»·þÎñ£¬Õâ¾ÍÊÇsleep¡£
sleep·½·¨²»ÍƼöʹÓ㬿ÉÓÃwait¡£
Ïß³ÌÍ˳ö×îºÃ×Ô¼ºÊµÏÖ£¬ÔÚÔËÐÐ״̬ÖÐÒ»Ö±¼ìÑéÒ»¸ö״̬£¬Èç¹ûÕâ¸ö×´Ì¬ÎªÕæ£¬¾ÍÒ»Ö±ÔËÐУ¬Èç¹ûÍâ½ç¸ü¸ÄÁËÕâ¸ö״̬±äÁ¿£¬ÄÇôÏ߳̾ÍÍ£Ö¹ÔËÐС£
sleep()ʹµ±Ç°Ï߳̽øÈëÍ£ÖÍ״̬£¬ËùÒÔÖ´ÐÐsleep()µÄÏß³ÌÔÚÖ¸¶¨µÄʱ¼äÄڿ϶¨²»»áÖ´ÐУ»yield()Ö»ÊÇʹµ±Ç°Ïß³ÌÖØÐ»ص½¿ÉÖ´ÐÐ״̬£¬ËùÒÔÖ´ÐÐyield()µÄÏß³ÌÓпÉÄÜÔÚ½øÈëµ½¿ÉÖ´ÐÐ״̬ºóÂíÉÏÓÖ±»Ö´ÐС£
sleep()¿ÉʹÓÅÏȼ¶µÍµÄÏ̵߳õ½Ö´ÐеĻú»á£¬µ±È»Ò²¿ÉÒÔÈÃͬÓÅÏȼ¶ºÍ¸ßÓÅÏȼ¶µÄÏß³ÌÓÐÖ´ÐеĻú»á£»yield()Ö»ÄÜʹͬÓÅÏȼ¶µÄÏß³ÌÓÐÖ´ÐеĻú»á¡£
µ±µ÷ÓÃwait()ºó£¬Ï̻߳áÊͷŵôËüËùÕ¼ÓÐµÄ“Ëø±êÖ¾”£¬´Ó¶øÊ¹Ïß³ÌËùÔÚ¶ÔÏóÖÐµÄÆäËüsynchronizedÊý¾Ý¿É±»±ðµÄÏß³ÌʹÓá£
waite()ºÍnotify()ÒòΪ»á¶Ô¶ÔÏóµÄ“Ëø±êÖ¾”½øÐвÙ×÷£¬ËùÒÔËüÃDZØÐëÔÚsynchronizedº¯Êý»òsynchronized¡¡blockÖнøÐе÷Óá£Èç¹ûÔÚnon-synchronizedº¯Êý»ònon-synchronized¡¡blockÖнøÐе÷Óã¬ËäÈ»ÄܱàÒëͨ¹ý£¬µ«ÔÚÔËÐÐʱ»á·¢ÉúIllegalMonitorStateExceptionµÄÒì³£¡£
³¹µ×Ã÷°×¶àÏß³ÌͨÐÅ»úÖÆ£º
Ï̼߳äµÄͨÐÅ
1. Ï̵߳ļ¸ÖÖ״̬
Ïß³ÌÓÐËÄÖÖ״̬£¬ÈκÎÒ»¸öÏ߳̿϶¨´¦ÓÚÕâËÄÖÖ״̬ÖеÄÒ»ÖÖ£º
1) ²úÉú£¨New£©£ºÏ̶߳ÔÏóÒѾ²úÉú£¬µ«ÉÐδ±»Æô¶¯£¬ËùÒÔÎÞ·¨Ö´ÐС£Èçͨ¹ýnew²úÉúÁËÒ»¸öÏ̶߳ÔÏóºóû¶ÔËüµ÷ÓÃstart()º¯Êý֮ǰ¡£
2) ¿ÉÖ´ÐУ¨Runnable£©£ºÃ¿¸öÖ§³Ö¶àÏ̵߳Äϵͳ¶¼ÓÐÒ»¸öÅÅ³ÌÆ÷£¬ÅÅ³ÌÆ÷»á´ÓÏ̳߳ØÖÐÑ¡ÔñÒ»¸öÏ̲߳¢Æô¶¯Ëü¡£µ±Ò»¸öÏ̴߳¦ÓÚ¿ÉÖ´ÐÐ״̬ʱ£¬±íʾËü¿ÉÄÜÕý´¦ÓÚÏ̳߳ØÖеȴýÅÅÅÅ³ÌÆ÷Æô¶¯Ëü£»Ò²¿ÉÄÜËüÒÑÕýÔÚÖ´ÐС£ÈçÖ´ÐÐÁËÒ»¸öÏ̶߳ÔÏóµÄstart()·½·¨ºó£¬Ï߳̾ʹ¦ÓÚ¿ÉÖ´ÐÐ״̬£¬µ«ÏÔ¶øÒ×¼ûµÄÊÇ´ËʱÏ̲߳»Ò»¶¨ÕýÔÚÖ´ÐÐÖС£
3) ËÀÍö£¨Dead£©£ºµ±Ò»¸öÏß³ÌÕý³£½áÊø£¬Ëü±ã´¦ÓÚËÀÍö״̬¡£ÈçÒ»¸öÏ̵߳Ärun()º¯ÊýÖ´ÐÐÍê±ÏºóÏ߳̾ͽøÈëËÀÍö״̬¡£
4) Í£ÖÍ£¨Blocked£©£ºµ±Ò»¸öÏ̴߳¦ÓÚÍ£ÖÍ״̬ʱ£¬ÏµÍ³ÅÅ³ÌÆ÷
Ïà¹ØÎĵµ£º
create PROCEDURE pagelist
@tablename nvarchar(50),
@fieldname nvarchar(50)='*',
@pagesize int output,--ÿҳÏÔʾ¼Ç¼ÌõÊý
@currentpage int output,--µÚ¼¸Ò³
@orderid nvarchar(50),--Ö÷¼üÅÅÐò
@sort int,--ÅÅÐò·½Ê½£¬1±íʾÉýÐò£¬0±íʾ½µÐòÅÅÁÐ
......
package com.xinnuo.jdbc;
import java.io.*;
import java.sql.*;
import java.util.*;
import java.util.Date;
/*
* ¸ÃÀàÖ»ÄÜ´´½¨Ò»¸öʵÀý£¬ÆäËü¶ÔÏóÄܹ»µ÷ÓÃÆä¾²Ì¬·½·¨£¨Ò²³ÆÎªÀà·½·¨£©»ñµÃ¸ÃΨһʵÀýµÄÒýÓá£
* DBConnectionManagerÀàµÄ½¨¹¹º¯ÊýÊÇ˽Óеģ¬ÕâÊÇΪÁ˱ÜÃâÆäËü¶ÔÏó´´½¨¸ÃÀ ......
×î½üÔÚCSDN£¬¿´µ½ÁËÒ»µÀȤζÌ⣺123456789Õâ¾Å¸ö°´Ë³ÐòÅÅÁеÄÊý£¬ÒªÇóÔÚËüÃÇÖ®¼ä²åÈëÈô¸É¸ö+£¬-£¬*£¬/ £¬Ê¹Æä½á¹ûÕýºÃµÈÓÚ
100È磺1*2*3*4+5+6+7*8+9=100¡£
¿´ÁËÌâÄ¿ºó£¬Ë¼¿¼Èç¹ûÓÃjavaÈçºÎʵÏÖ¡£ÒÔÏÂÊÇÎҵĽâÌâ˼·£º
˼Ïë±È½Ï¼òµ¥£¬ÏȽ«²åÈë+£¬-£¬*£¬/ºóµÄËùÓÐ×Ö·û´®¶¼Çî¾Ù³öÀ´£¬È»ºó¼ÆËãÄÄЩ×Ö·û´®µÈÓÚ100¡£
Õ ......
--°ü
create or replace package pkg_query as
type cur_query is ref cursor;
end pkg_query;
--¹ý³Ì
CREATE OR REPLACE PROCEDURE "PRC_QUERY" (p_tableName
in varchar2, --±íÃû
& ......
1. floatÐÍfloat f=3.4ÊÇ·ñÕýÈ·?
¡¡¡¡´ð£º²»ÕýÈ·£¬Ó¦Îªfloat f=3.4f
¡¡¡¡2. µ±Ò»¸ö¶ÔÏó±»µ±×÷²ÎÊý´«µÝµ½Ò»¸ö·½·¨ºó£¬´Ë·½·¨¿É¸Ä±äÕâ¸ö¶ÔÏóµÄÊôÐÔ£¬²¢¿É·µ»Ø±ä»¯ºóµÄ½á¹û£¬ÄÇôÕâÀïµ½µ×ÊÇÖµ´«µÝ»¹ÊÇÒýÓô«µÝ?
¡¡¡¡´ð£ºÊÇÒýÓô«µÝ¡£
¡¡¡¡3. ÔÚjavaÖÐÒ»¸öÀà±»ÉùÃ÷ΪfinalÀàÐÍ£¬±íʾÁËʲôÒâ˼?
¡¡¡¡´ð£º±íʾ¸ÃÀà²»Ä ......