Changing proxy settings of IE is a frequent requirement of mine. Then I got the idea of writing a tool by myself, at last. I have not found clear instructions on this. Many articles recommend to modify registry directly, but unfortunately their instruction is not enough. Most of them direct me to modify the following values in registry :-
[HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Internet Settings]
"ProxyEnable"=dword:00000001
"ProxyServer"=":"
"ProxyOverride"=""
"DisablePasswordCaching"=dword:00000001
I tested it and find that it does not work at least on my computer.( I access internet by ADSL connection.) So I backed up registry and modified proxy settings via Internet Explorer, finding that [HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Internet Settings\Connections] is also changed. So I wrote the following code snippet to change proxy settings:
void ShowError(long lerr) { LPVOID lpMsgBuf; if (!FormatMessage( FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS, NULL, lerr, MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // Default language (LPTSTR) &lpMsgBuf, 0, NULL )) { return; } MessageBox( NULL, (LPCTSTR)lpMsgBuf, "Error", MB_OK | MB_ICONINFORMATION ); LocalFree( lpMsgBuf ); } void CieproxyDlg::OnBnClickedOk() {//set proxy server UpdateData(); GetDlgItemText(IDC_EDIT1,m_sIEProxy); HKEY hk; LONG lret=RegOpenKeyEx(HKEY_CURRENT_USER, "Software\\Microsoft\\Windows\\CurrentVersion\\Internet Settings", NULL,KEY_WRITE|KEY_SET_VALUE,&hk); if(lret==ERROR_SUCCESS&&NULL!=hk) { TCHAR* pbuf=m_sIEProxy.GetBuffer(1); lret=RegSetValueEx( hk,"ProxyServer",NULL,REG_SZ,pbuf,m_sIEProxy.GetLength()); DWORD dwenable=1; lret=RegSetValueEx(hk,"ProxyEnable",NULL,REG_DWORD, (LPBYTE)&dwenable,sizeof(dwenable)); RegCloseKey(hk); } const TCHAR* keyname3=_T( "software\\Microsoft\\windows\\currentversion\\Internet Settings\\Connections"); lret=RegOpenKeyEx(HKEY_CURRENT_USER,keyname3,NULL, KEY_READ|KEY_WRITE|KEY_SET_VALUE,&hk); if(lret==ERROR_SUCCESS&&NULL!=hk) { DWORD dwtype; char pbuf[256]; DWORD dwlen=sizeof(pbuf); constchar* valname="Connection to adsl3"; lret=RegQueryValueEx(hk,valname,NULL,&dwtype,pbuf,&dwlen); if(lret!=ERROR_SUCCESS) { ShowError(lret); } pbuf[8] = 3;//enable proxy pbuf[4]=pbuf[4]+1; constchar* p=m_sIEProxy.GetBuffer(1); memcpy(pbuf+16,p,m_sIEProxy.GetLength()); char c=0; for(int i=m_sIEProxy.GetLength();i<20;i++) pbuf[16+i]=c; m_sIEProxy.ReleaseBuffer(); lret=RegSetValueEx(hk,valname,NULL,REG_BINARY,pbuf,dwlen); RegCloseKey(hk); } DWORD dwret; SendMessageTimeout(HWND_BROADCAST,WM_SETTINGCHANGE,NULL,NULL, SMTO_NORMAL,1000,&dwret); } void CieproxyDlg::OnBnClickedDisableProxy() { UpdateData(); GetDlgItemText(IDC_EDIT1,m_sIEProxy); HKEY hk; LONG lret=RegOpenKeyEx(HKEY_CURRENT_USER, "Software\\Microsoft\\Windows\\CurrentVersion\\Internet Settings", NULL,KEY_WRITE|KEY_SET_VALUE,&hk); if(lret==ERROR_SUCCESS&&NULL!=hk) { DWORD dwenable=0; lret=RegSetValueEx(hk,"ProxyEnable",NULL,REG_DWORD, (LPBYTE)&dwenable,sizeof(dwenable)); RegCloseKey(hk); } const TCHAR* keyname3=_T( "software\\Microsoft\\windows\\currentversion\\Internet Settings\\Connections"); lret=RegOpenKeyEx(HKEY_CURRENT_USER,keyname3, NULL,KEY_READ|KEY_WRITE|KEY_SET_VALUE,&hk); if(lret==ERROR_SUCCESS&&NULL!=hk) { DWORD dwtype; char pbuf[256]; DWORD dwlen=sizeof(pbuf); constchar* valname="Connection to adsl3"; lret=RegQueryValueEx(hk,valname,NULL,&dwtype,pbuf,&dwlen); if(lret!=ERROR_SUCCESS) { ShowError(lret); } pbuf[8] = 1;//enable proxy pbuf[4]=pbuf[4]+1; lret=RegSetValueEx(hk,valname,NULL,REG_BINARY,pbuf,dwlen); RegCloseKey(hk); } DWORD dwret; SendMessageTimeout(HWND_BROADCAST,WM_SETTINGCHANGE,NULL,NULL,SMTO_NORMAL, 1000,&dwret); }
Problem with above code is that existing Internet Explorer instances don't know the change of settings. What is more, changing registry directly is not an elegant method. Then the following must be more attractive :
BOOL SetConnectionOptions(LPCTSTR conn_name,LPCTSTR proxy_full_addr) { //conn_name: active connection name. //proxy_full_addr : eg "210.78.22.87:8000" INTERNET_PER_CONN_OPTION_LIST list; BOOL bReturn; DWORD dwBufSize = sizeof(list); // Fill out list struct. list.dwSize = sizeof(list); // NULL == LAN, otherwise connectoid name. list.pszConnection = conn_name; // Set three options. list.dwOptionCount = 3; list.pOptions = new INTERNET_PER_CONN_OPTION[3]; // Make sure the memory was allocated.if(NULL == list.pOptions) { // Return FALSE if the memory wasn't allocated. OutputDebugString("failed to allocat memory in SetConnectionOptions()"); return FALSE; } // Set flags. list.pOptions[0].dwOption = INTERNET_PER_CONN_FLAGS; list.pOptions[0].Value.dwValue = PROXY_TYPE_DIRECT | PROXY_TYPE_PROXY; // Set proxy name. list.pOptions[1].dwOption = INTERNET_PER_CONN_PROXY_SERVER; list.pOptions[1].Value.pszValue = proxy_full_addr;//"http://proxy:80";// Set proxy override. list.pOptions[2].dwOption = INTERNET_PER_CONN_PROXY_BYPASS; list.pOptions[2].Value.pszValue = "local"; // Set the options on the connection. bReturn = InternetSetOption(NULL, INTERNET_OPTION_PER_CONNECTION_OPTION, &list, dwBufSize); // Free the allocated memory.delete [] list.pOptions; InternetSetOption(NULL, INTERNET_OPTION_SETTINGS_CHANGED, NULL, 0); InternetSetOption(NULL, INTERNET_OPTION_REFRESH , NULL, 0); return bReturn; } BOOL DisableConnectionProxy(LPCTSTR conn_name) { //conn_name: active connection name. INTERNET_PER_CONN_OPTION_LIST list; BOOL bReturn; DWORD dwBufSize = sizeof(list); // Fill out list struct. list.dwSize = sizeof(list); // NULL == LAN, otherwise connectoid name. list.pszConnection = conn_name; // Set three options. list.dwOptionCount = 1; list.pOptions = new INTERNET_PER_CONN_OPTION[list.dwOptionCount]; // Make sure the memory was allocated.if(NULL == list.pOptions) { // Return FALSE if the memory wasn't allocated. OutputDebugString("failed to allocat memory in DisableConnectionProxy()"); return FALSE; } // Set flags. list.pOptions[0].dwOption = INTERNET_PER_CONN_FLAGS; list.pOptions[0].Value.dwValue = PROXY_TYPE_DIRECT ; // Set the options on the connection. bReturn = InternetSetOption(NULL, INTERNET_OPTION_PER_CONNECTION_OPTION, &list, dwBufSize); // Free the allocated memory.delete [] list.pOptions; InternetSetOption(NULL, INTERNET_OPTION_SETTINGS_CHANGED, NULL, 0); InternetSetOption(NULL, INTERNET_OPTION_REFRESH , NULL, 0); return bReturn; }
The usage is very straightforward:
//set proxy const char* connection_name="Connection to adsl3"; SetConnectionOptions(connection_name,"62.81.236.23:80"); //disable proxy DisableConnectionProxy(connection_name);
Existing Internet Explorer instances are notified by INTERNET_OPTION_SETTINGS_CHANGED
and INTERNET_OPTION_REFRESH
Written by Halatu Hubisi
約定:
1.讀者應(yīng)具備一定JAVA的知識(shí).
2.本文中的JVM選項(xiàng)均以SUN公司發(fā)布的HotSpot JVM 5為準(zhǔn)(不過(guò)大多數(shù)的選項(xiàng)在JVM1.3,JVM1.4中也是可用的).
3.以JAVA_HOME下demo/jfc/SwingSet2/SwingSet2.jar為例進(jìn)行說(shuō)明.
4.閱讀本文需要一些關(guān)于GC的知識(shí),可以到附錄A中了解這些知識(shí)。
關(guān)鍵字:
JVM(java虛擬機(jī)),調(diào)優(yōu),GC(垃圾回收)
JVM GC調(diào)優(yōu)
為了能夠?qū)VM GC的調(diào)優(yōu)能夠使用在具體的實(shí)踐當(dāng)中,下面將利用若干個(gè)例子來(lái)說(shuō)明GC的調(diào)優(yōu).
例1:Heap size 設(shè)置
JVM堆的設(shè)置是指java程序運(yùn)行過(guò)程中JVM可以調(diào)配使用的內(nèi)存空間的設(shè)置.JVM在啟動(dòng)的時(shí)候會(huì)自動(dòng)設(shè)置Heap size的值,其初始空間(即-Xms)是物理內(nèi)存的1/64,最大空間(-Xmx)是物理內(nèi)存的1/4。可以利用JVM提供的-Xmn -Xms -Xmx等選項(xiàng)可進(jìn)行設(shè)置。Heap size 的大小是Young Generation 和Tenured Generaion 之和。
當(dāng)在JAVA_HOME下demo/jfc/SwingSet2/目錄下執(zhí)行下面的命令。
java -jar -Xmn4m -Xms16m -Xmx16m SwingSet2.jar
系統(tǒng)輸出為:
Exception in thread "Image Fetcher 0" java.lang.OutOfMemoryError: Java heap space
Exception in thread "Image Fetcher 3" java.lang.OutOfMemoryError: Java heap space
Exception in thread "Image Fetcher 1" java.lang.OutOfMemoryError: Java heap space
Exception in thread "Image Fetcher 2" java.lang.OutOfMemoryError: Java heap space
除了這些異常信息外,還會(huì)發(fā)現(xiàn)程序的響應(yīng)速度變慢了。這說(shuō)明Heap size 設(shè)置偏小,GC占用了更多的時(shí)間,而應(yīng)用分配到的執(zhí)行時(shí)間較少。
提示:在JVM中如果98%的時(shí)間是用于GC且可用的Heap size 不足2%的時(shí)候?qū)伋龃水惓P畔ⅰ?/span>
將上面的命令換成以下命令執(zhí)行則應(yīng)用能夠正常使用,且未拋出任何異常。
java -jar -Xmn4m -Xms16m -Xmx32m SwingSet2.jar
提示:Heap Size 最大不要超過(guò)可用物理內(nèi)存的80%,一般的要將-Xms和-Xmx選項(xiàng)設(shè)置為相同,而-Xmn為1/4的-Xmx值。
例2:Young Generation(-Xmn)的設(shè)置
在本例中看一下Young Generation的設(shè)置不同將有什么現(xiàn)象發(fā)生。
假設(shè)將Young generation 的大小設(shè)置為4M ,即執(zhí)行java -jar -verbose:gc -Xmn4m -Xms32m -Xmx32m -XX:+PrintGCDetails SwingSet2.jar,屏幕輸出如下(節(jié)選)
[GC [DefNew: 3968K->64K(4032K), 0.0923407 secs] 3968K->2025K(32704K), 0.0931870 secs]
[GC [DefNew: 4021K->64K(4032K), 0.0356847 secs] 5983K->2347K(32704K), 0.0365441 secs]
[GC [DefNew: 3995K->39K(4032K), 0.0090603 secs] 6279K->2372K(32704K), 0.0093377 secs]
[GC [DefNew: 3992K->23K(4032K), 0.0057540 secs] 6325K->2356K(32704K), 0.0060290 secs]
[GC [DefNew: 3984K->27K(4032K), 0.0013058 secs] 6317K->2360K(32704K), 0.0015888 secs]
[GC [DefNew: 3981K->59K(4032K), 0.0023307 secs] 6315K->2422K(32704K), 0.0026091 secs]
將程序體制并將Young Generation的大小設(shè)置為8M,即執(zhí)行java -jar -verbose:gc -Xmn8m -Xms32m -Xmx32m -XX:+PrintGCDetails SwingSet2.jar,屏幕輸出如下(節(jié)選)
[GC [DefNew: 7808K->192K(8000K), 0.1016784 secs] 7808K->2357K(32576K), 0.1022834 secs]
[GC [DefNew: 8000K->70K(8000K), 0.0149659 secs] 10165K->2413K(32576K), 0.0152557 secs]
[GC [DefNew: 7853K->59K(8000K), 0.0069122 secs] 10196K->2403K(32576K), 0.0071843 secs]
[GC [DefNew: 7867K->171K(8000K), 0.0075745 secs] 10211K->2681K(32576K), 0.0078376 secs]
[GC [DefNew: 7970K->192K(8000K), 0.0201353 secs] 10480K->2923K(32576K), 0.0206867 secs]
[GC [DefNew: 7979K->30K(8000K), 0.1787079 secs] 10735K->4824K(32576K), 0.1790065 secs]
那么根據(jù)GC輸出的信息(這里取第一行)做一下Minor收集的比較。可以看出兩次的Minor收集分別在Young generation中找回3904K(3968K->64K)和7616K(7808K->192K)而對(duì)于整個(gè)jvm則找回1943K(3968K->2025)和5451K(7808K->2357K)。第一種情況下Minor收集了大約50%(1943/3904)的對(duì)象,而另外的50%的對(duì)象則被移到了tenured generation。在第二中情況下Minor收集了大約72%的對(duì)象,只有不到30%的對(duì)象被移到了Tenured Generation.這個(gè)例子說(shuō)明此應(yīng)用在的Young generation 設(shè)置為4m時(shí)顯的偏小。
提示:一般的Young Generation的大小是整個(gè)Heap size的1/4。Young generation的minor收集率應(yīng)一般在70%以上。當(dāng)然在實(shí)際的應(yīng)用中需要根據(jù)具體情況進(jìn)行調(diào)整。
例3:Young Generation對(duì)應(yīng)用響應(yīng)的影響
還是使用-Xmn4m 和-Xmn8m進(jìn)行比較,先執(zhí)行下面的命令
java -jar -verbose:gc -Xmn4m -Xms32m -Xmx32m -XX:+PrintGCDetails -XX:+PrintGCApplicationConcurrentTime -XX:+PrintGCApplicationStoppedTime SwingSet2.jar
屏幕輸出如下(節(jié)選)
Application time: 0.5114944 seconds
[GC [DefNew: 3968K->64K(4032K), 0.0823952 secs] 3968K->2023K(32704K), 0.0827626 secs]
Total time for which application threads were stopped: 0.0839428 seconds
Application time: 0.9871271 seconds
[GC [DefNew: 4020K->64K(4032K), 0.0412448 secs] 5979K->2374K(32704K), 0.0415248 secs]
Total time for which application threads were stopped: 0.0464380 seconds
Young Generation 的Minor收集占用的時(shí)間可以計(jì)算如下:應(yīng)用線程被中斷的總時(shí)常/(應(yīng)用執(zhí)行總時(shí)?L+應(yīng)用線程被中斷的總時(shí)常),那么在本例中垃圾收集占用的時(shí)?L約為系統(tǒng)的5%~14%。那么當(dāng)垃圾收集占用的時(shí)間的比例越大的時(shí)候,系統(tǒng)的響應(yīng)將越慢。
提示:對(duì)于互聯(lián)網(wǎng)應(yīng)用系統(tǒng)的響應(yīng)稍微慢一些,用戶是可以接受的,但是對(duì)于GUI類型的應(yīng)用響應(yīng)速度慢將會(huì)給用戶帶來(lái)非常不好的體驗(yàn)。
例4:如何決定Tenured Generation 的大小
分別以-Xmn8m -Xmx32m和-Xmn8m -Xmx64m進(jìn)行對(duì)比,先執(zhí)行
java -verbose:gc -Xmn8m -Xmx32m-XX:+PririntGCDetails -XX:+PrintGCTimeStamps java類,命令行將提示(只提取了Major收集)
111.042: [GC 111.042: [DefNew: 8128K->8128K(8128K), 0.0000505 secs]111.042: [Tenured: 18154K->2311K(24576K), 0.1290354 secs] 26282K->2311K(32704K), 0.1293306 secs]
122.463: [GC 122.463: [DefNew: 8128K->8128K(8128K), 0.0000560 secs]122.463: [Tenured: 18630K->2366K(24576K), 0.1322560 secs] 26758K->2366K(32704K), 0.1325284 secs]
133.896: [GC 133.897: [DefNew: 8128K->8128K(8128K), 0.0000443 secs]133.897: [Tenured: 18240K->2573K(24576K), 0.1340199 secs] 26368K->2573K(32704K), 0.1343218 secs]
144.112: [GC 144.112: [DefNew: 8128K->8128K(8128K), 0.0000544 secs]144.112: [Tenured: 16564K->2304K(24576K), 0.1246831 secs] 24692K->2304K(32704K), 0.1249602 secs]
再執(zhí)行java -verbose:gc -Xmn8m -Xmx64m-XX:+PririntGCDetails -XX:+PrintGCTimeStamps java類,命令行將提示(只提取了Major收集)
90.597: [GC 90.597: [DefNew: 8128K->8128K(8128K), 0.0000542 secs]90.597: [Tenured: 49841K->5141K(57344K), 0.2129882 secs] 57969K->5141K(65472K), 0.2133274 secs]
120.899: [GC 120.899: [DefNew: 8128K->8128K(8128K), 0.0000550 secs]120.899: [Tenured: 50384K->2430K(57344K), 0.2216590 secs] 58512K->2430K(65472K), 0.2219384 secs]
153.968: [GC 153.968: [DefNew: 8128K->8128K(8128K), 0.0000511 secs]153.968: [Tenured: 51164K->2309K(57344K), 0.2193906 secs] 59292K->2309K(65472K), 0.2196372 secs]
可以看出在Heap size 為32m的時(shí)候系統(tǒng)等候時(shí)間約為0.13秒左右,而設(shè)置為64m的時(shí)候等候時(shí)間則增大到0.22秒左右了。但是在32m的時(shí)候系統(tǒng)的Major收集間隔為10秒左右,而Heap size 增加到64m的時(shí)候?yàn)?0秒。那么應(yīng)用在運(yùn)行的時(shí)候是選擇32m還是64m呢?如果應(yīng)用是web類型(即要求有大的吞吐量)的應(yīng)用則使用64m(即heapsize大一些)的比較好。對(duì)于要求實(shí)時(shí)響應(yīng)要求較高的場(chǎng)合(例如GUI型的應(yīng)用)則使用32m比較好一些。
注意:
1。因?yàn)樵贘VM5運(yùn)行時(shí)已經(jīng)對(duì)Heap-size進(jìn)行了優(yōu)化,所以在能確定java應(yīng)用運(yùn)行時(shí)不會(huì)超過(guò)默認(rèn)的Heap size的情況下建議不要對(duì)這些值進(jìn)行修改。
2。Heap size的 -Xms -Xmn 設(shè)置不要超出物理內(nèi)存的大小。否則會(huì)提示“Error occurred during initialization of VM Could not reserve enough space for object heap”。
例5:如何縮短minor收集的時(shí)間
下面比較一下采用-XX:+UseParNewGC選項(xiàng)和不采用它的時(shí)候的minor收集將有什么不同。先執(zhí)行
java -jar -server -verbose:gc -Xmn8m -Xms32m -Xmx32m SwingSet2.jar
系統(tǒng)將輸出如下信息(片段〕
[GC 7807K->2641K(32576K), 0.0676654 secs]
[GC 10436K->3108K(32576K), 0.0245328 secs]
[GC 10913K->3176K(32576K), 0.0072865 secs]
[GC 10905K->4097K(32576K), 0.0223928 secs]
之后再執(zhí)行 java -jar -server -verbose:gc -XX:+UseParNewGC -Xmn8m -Xms32m -Xmx32m SwingSet2.jar
系統(tǒng)將輸出如下信息(片段〕
[ParNew 7808K->2656K(32576K), 0.0447687 secs]
[ParNew 10441K->3143K(32576K), 0.0179422 secs]
[ParNew 10951K->3177K(32576K), 0.0031914 secs]
[ParNew 10985K->3867K(32576K), 0.0154991 secs]
很顯然使用了-XX:+UseParNewGC選項(xiàng)的minor收集的時(shí)間要比不使用的時(shí)候優(yōu)。
例6:如何縮短major收集的時(shí)間
下面比較一下采用-XX:+UseConcMarkSweepGC選項(xiàng)和不采用它的時(shí)候的major收集將有什么不同。先執(zhí)行
java -jar -verbose:gc -XX:+UseConcMarkSweepGC -XX:+UseParNewGC -Xmn64m -Xms256m -Xmx256m SwingSet2.jar
系統(tǒng)將輸出如下信息(片段〕
[Full GC 22972K->18690K(262080K), 0.2326676 secs]
[Full GC 18690K->18690K(262080K), 0.1701866 secs
之后再執(zhí)行 java -jar -verbose:gc -XX:+UseParNewGC -Xmn64m -Xms256m -Xmx256m SwingSet2.jar
系統(tǒng)將輸出如下信息(片段〕
[Full GC 56048K->18869K(260224K), 0.3104852 secs]
提示:此選項(xiàng)在Heap Size 比較大而且Major收集時(shí)間較長(zhǎng)的情況下使用更合適。
例7:關(guān)于-server選項(xiàng) 在JVM中將運(yùn)行中的類認(rèn)定為server-class的時(shí)候使用此選項(xiàng)。SUN 的Hot Spot JVM5 如果判斷到系統(tǒng)的配置滿足如下條件則自動(dòng)將運(yùn)行的類認(rèn)定為server-class,并且會(huì)自動(dòng)設(shè)置jvm的選項(xiàng)(當(dāng)沒(méi)有手工設(shè)置這選項(xiàng)的時(shí)候〕而且HOTSPOT JVM5提供了自動(dòng)調(diào)優(yōu)的功能,他會(huì)根據(jù)JVM的運(yùn)行情況進(jìn)行調(diào)整。如果沒(méi)有特別的需要是不需要太多的人工干預(yù)的。SUN形象的稱這個(gè)機(jī)制為“人體工學(xué)”(Ergonomics〕。具體可以參考http://java.sun.com/docs/hotspot/gc5.0/ergo5.html
*.具有2個(gè)或更多個(gè)物理的處理器
*.具有2G或者更多的物理內(nèi)存
提示:此選項(xiàng)要放在所有選項(xiàng)的前面。例如:java -server 其他選項(xiàng) java類
附錄A:預(yù)備知識(shí)
.JVM中對(duì)象的劃分及管理
JVM根據(jù)運(yùn)行于其中的對(duì)象的生存時(shí)間大致的分為3種。并且將這3種不同的對(duì)象分別存放在JVM從系統(tǒng)分配到的不同的內(nèi)存空間。這種對(duì)象存放空間的管理方式叫做Generation管理方式。
1。Young Generation:用于存放“早逝”對(duì)象(即瞬時(shí)對(duì)象)。例如:在創(chuàng)建對(duì)象時(shí)或者調(diào)用方法時(shí)使用的臨時(shí)對(duì)象或局部變量。
2。Tenured Generation:用于存放“駐留”對(duì)象(即較長(zhǎng)時(shí)間被引用的對(duì)象)。往往體現(xiàn)為一個(gè)大型程序中的全局對(duì)象或長(zhǎng)時(shí)間被使用的對(duì)象。
3。Perm Generation:用于存放“永久”對(duì)象。這些對(duì)象管理著運(yùn)行于JVM中的類和方法。
.JVM選項(xiàng)的分類
JVM有這么幾種選項(xiàng)供使用.
1.供-X選項(xiàng)使用的項(xiàng)目,又稱為非標(biāo)準(zhǔn)選項(xiàng),不同廠商的此類型選項(xiàng)是有所不同的。例如:IBM的JVM用的一些選項(xiàng)在Sun的JVM中就不一定能生效。這種選項(xiàng)的使用方式如下:
java -Xmn16m -Xms64m -Xmx64m java類名
2.供-XX選項(xiàng)使用的項(xiàng)目,這種類型的選項(xiàng)可能要求有對(duì)系統(tǒng)信息訪問(wèn)的權(quán)限。所以要慎用。這種選項(xiàng)的使用方式如下:
java -XX:MaxHeapFreeRatio=70 -XX:+PrintGCDetails java類名
3.java選項(xiàng)(即在命令行執(zhí)行java后提示的選項(xiàng)).
java -server -verbose:gc -d64 java類名
.垃圾收集分類
在JVM中有兩種垃圾方式,一種叫做Minor(次收集),另一種叫做Major(主收集)。其中Minor在Young Generation的空間被對(duì)象全部占用后執(zhí)行,主要是對(duì)Young Generation中的對(duì)象進(jìn)行垃圾收集。而Major是針對(duì)于整個(gè)Heap size的垃圾收集。其中Minor方式的收集經(jīng)常發(fā)生,并且Minor收集所占用的系統(tǒng)時(shí)間小。Major方式的垃圾收集則是一種“昂貴”的垃圾收集方式,因?yàn)樵贛ajor要對(duì)整個(gè)Heap size進(jìn)行垃圾收集,這會(huì)使得應(yīng)用停頓的時(shí)間變得較長(zhǎng)。
.GC信息的格式
[GC [<collector>: <starting occupancy1> -> <ending occupancy1>, <pause time1> secs] <starting occupancy3> -> <ending occupancy3>, <pause time3> secs]
<collector> GC為minor收集過(guò)程中使用的垃圾收集器起的內(nèi)部名稱.
<starting occupancy1> young generation 在進(jìn)行垃圾收集前被對(duì)象使用的存儲(chǔ)空間.
<ending occupancy1> young generation 在進(jìn)行垃圾收集后被對(duì)象使用的存儲(chǔ)空間
<pause time1> minor收集使應(yīng)用暫停的時(shí)間長(zhǎng)短(秒)
<starting occupancy3> 整個(gè)堆(Heap Size)在進(jìn)行垃圾收集前被對(duì)象使用的存儲(chǔ)空間
<ending occupancy3> 整個(gè)堆(Heap Size)在進(jìn)行垃圾收集后被對(duì)象使用的存儲(chǔ)空間
<pause time3> 整個(gè)垃圾收集使應(yīng)用暫停的時(shí)間長(zhǎng)短(秒),包括major收集使應(yīng)用暫停的時(shí)間(如果發(fā)生了major收集).
.GC信息的選項(xiàng)
-XX:+PrintGCDetails 顯示GC的詳細(xì)信息
-XX:+PrintGCApplicationConcurrentTime 打印應(yīng)用執(zhí)行的時(shí)間
-XX:+PrintGCApplicationStoppedTime 打印應(yīng)用被暫停的時(shí)間
提示:1.":"后的"+"號(hào)表示開啟此選項(xiàng),如果是"-"號(hào)那么表示關(guān)閉此選項(xiàng)。
?????2.在不同的選項(xiàng)和不同的收集方式和類型下輸出的格式會(huì)有所不同。
附錄B:HotSpot JVM 選項(xiàng)
請(qǐng)參考JavaTM HotSpot VM Options
附錄C:其他資源
http://java.sun.com/docs/hotspot/gc5.0/gc_tuning_5.html
http://java.sun.com/docs/hotspot/gc5.0/ergo5.html
String strs = request.getParameter("yourstrs");關(guān)于tomcat4.0配置digest認(rèn)證注意事項(xiàng):
byte b[] = strs.getBytes("ISO-8859-1");
strs = new String(b);
簡(jiǎn)潔寫法:
String convert = new String(request.getParmater("inputname").trim().getBytes("ISO8859_1"), "GBK");
????似乎是數(shù)位少年作家的嶄露頭角,讓人們開始注目“80后”。而當(dāng)在人們眼中的“80后”還是代表著浮躁和反叛時(shí),這個(gè)詞卻在悄悄地與財(cái)富畫上連接符號(hào),一批極為年輕的財(cái)富新貴的出現(xiàn)似乎是一夜之間,同時(shí)顛覆了人們心目中
企業(yè)家
的傳統(tǒng)印象。
???
???也正由于他們的年紀(jì)之輕和擁有的財(cái)富之重,這段時(shí)間來(lái),他們不斷受到媒體和公眾的追捧。
????看看上述這些代表人物從事的行業(yè)就知道,這批“80后”財(cái)富新貴的共同特點(diǎn)是夾了一本叫“互聯(lián)網(wǎng)”的大課本匆匆上路了。互聯(lián)網(wǎng)這座虛擬時(shí)空里的“大學(xué)”,在很多層面上反叛著以一間講堂、一套書本、一種方言、一個(gè)系統(tǒng)為依托的傳統(tǒng) 教育 。
????在李想看來(lái),這正是“80后”的一代人所具有的互聯(lián)網(wǎng)精神:完全不顧忌那些別人認(rèn)為是必須去做的傳統(tǒng),破除墨守成規(guī),只做最正確的事。
????和李想說(shuō)話,你會(huì)發(fā)現(xiàn)他始終思路清晰、方向明確,回答每個(gè)問(wèn)題不超過(guò)3句話,也挑不出一點(diǎn)廢話。“我的方向和目標(biāo)很明確,一開始我就知道我的事業(yè)方向就是互聯(lián)網(wǎng),然后我會(huì)確定每一個(gè)階段的目標(biāo),一個(gè)一個(gè)去實(shí)現(xiàn),所以我不會(huì)受到誘惑去燒錢,也不會(huì)因?yàn)榕龅嚼щy就放棄。”
????“像李想、戴志康這批‘80后’創(chuàng)業(yè)家的優(yōu)勢(shì)就在于他們創(chuàng)新能力很強(qiáng),敢于嘗試,想了就做。不像70年代的人干什么都思前想后,以致錯(cuò)過(guò)很多機(jī)會(huì)。”中華英才網(wǎng)總裁、著名人力資源專家張建國(guó)說(shuō):“但他們的問(wèn)題是自我意識(shí)太強(qiáng),而管理企業(yè)是要靠組織體系和團(tuán)隊(duì)協(xié)作的,因此,靠一個(gè)好的創(chuàng)意可以成就一個(gè)企業(yè),但企業(yè)做大以后怎么管理好,這可能是‘80后’企業(yè)家應(yīng)該注意的問(wèn)題。”
????和張建國(guó)基本同齡的戴光對(duì)于兒子戴志康也有類似的擔(dān)心,“你可以憑一項(xiàng)技術(shù)創(chuàng)業(yè),但公司做大以后,如何從一個(gè)技術(shù)天才的角色中脫離出來(lái),完成一個(gè)管理者的轉(zhuǎn)型,是一個(gè)大問(wèn)題”。
這些擔(dān)心已經(jīng)是李想們正在思考并一直著力解決的問(wèn)題。
????“2003年時(shí)我的性格還是典型的‘80后’,太自我,不太考慮他人的感受。這給了我很多教訓(xùn),讓我慢慢改變,慢慢學(xué)會(huì)跳出來(lái)觀察自己,學(xué)會(huì)了解每一個(gè)員工的性格和想法。”李想說(shuō),“而且我開始嘗試用心跟別人溝通,而不是用腦子。用腦子太累,大家互相猜來(lái)猜去,我喜歡直截了當(dāng),怎么想的就怎么說(shuō)。后來(lái)我發(fā)現(xiàn)其實(shí)大部分人都喜歡這種溝通方式,包括那些很有名的CEO們。所以規(guī)則不是不可以改寫的,關(guān)鍵是你去不去做。”
????這正是“80后”財(cái)富新貴的共同特點(diǎn),他們擁有與年齡不相符的成熟和老練。
????本期,我們走近“80后”財(cái)富新貴中的兩位:李想和戴志康,也走訪了其中一位的父親,希望能從父輩的教育方式上對(duì)這批財(cái)富新貴的成功緣由有所挖掘。
????一個(gè)沒(méi)有上過(guò)大學(xué),一個(gè)做了大學(xué)的“半路逃兵”,李想和戴志康都沒(méi)有受過(guò)完整的高等教育,但他們卻創(chuàng)造了奇跡。
????這批沒(méi)有接受正規(guī)高等教育卻創(chuàng)業(yè)成功的年輕企業(yè)家的崛起,再次引發(fā)對(duì)現(xiàn)行高等教育的爭(zhēng)議,中國(guó)高校究竟該培養(yǎng)什么樣人才的問(wèn)題又一次被提起。
????在關(guān)注他們成長(zhǎng)的同時(shí),我們也期待他們?cè)诮窈蟮穆飞献叩酶臃€(wěn)健和長(zhǎng)久。
????見到25歲的PCPOP網(wǎng)首席執(zhí)行官李想時(shí),他的公司一片忙亂,所有的會(huì)議室都被騰出來(lái)接待面試者,李想準(zhǔn)備繼續(xù)擴(kuò)大已有的100多人的團(tuán)隊(duì),而他們2004年還顯得空蕩的公司變得擁擠不堪。李想說(shuō)他已經(jīng)在中關(guān)村一個(gè)新建的寫字樓里租下了比現(xiàn)在大一倍的“新家”,馬上就要搬家了。
????作為中國(guó)第三大中文 IT 專業(yè)網(wǎng)站——PCPOP網(wǎng)的創(chuàng)始人,李想持有公司50%以上的股份,身家在1億元以上,網(wǎng)站去年的營(yíng)業(yè)額收入近兩千萬(wàn)元,利潤(rùn)一千萬(wàn)元,取20倍的市盈率,市場(chǎng)價(jià)值兩億元。但李想的野心決不僅限于此,“今年的營(yíng)業(yè)額要達(dá)到去年的2.5倍,明年要超過(guò)1億元,然后2008年達(dá)到一個(gè)上市的標(biāo)準(zhǔn),這是我們未來(lái)幾年發(fā)展的一個(gè)方向。”
????這個(gè)野心勃勃的年輕人8年前還是一個(gè)上不起網(wǎng)的高中生,當(dāng)時(shí)一小時(shí)8元的上網(wǎng)費(fèi)外加一小時(shí)4元的電話費(fèi)對(duì)于一個(gè)孩子來(lái)說(shuō)實(shí)在昂貴,后來(lái)上網(wǎng)費(fèi)用降到只需一小時(shí)1元,他就是那時(shí)候開始接觸互聯(lián)網(wǎng)的,“我一碰互聯(lián)網(wǎng)馬上就迷上了,當(dāng)時(shí)很單純,就是因?yàn)榭梢栽诰W(wǎng)上跟志同道合的人交流、學(xué)習(xí)知識(shí)”。
李想很快就開始做自己的IT資訊網(wǎng)站,網(wǎng)站的訪問(wèn)量很快就達(dá)到五六千人。當(dāng)達(dá)到一萬(wàn)人時(shí),就有
廣告
商開始找他,要做廣告,訪問(wèn)量一千次10元,‘我當(dāng)時(shí)想,閑著也是閑著,就給他掛上了”。
????沒(méi)有在意的李想兩個(gè)月后收到了廣告商6000元的付款,“我當(dāng)時(shí)也很吃驚,這比我父母一個(gè)月加起來(lái)掙的還多。”不經(jīng)意間挖到自己的第一桶金,本來(lái)心思就不在讀書上的李想終于在高三畢業(yè)時(shí)作出了一個(gè)大膽決定:放棄考大學(xué),自己創(chuàng)業(yè)。
????與李想同歲、同樣靠互聯(lián)網(wǎng)起家的康盛世紀(jì)科技有限公司CEO戴志康卻是個(gè)從小和電腦泡到大的人。戴志康出生在大慶一個(gè)高級(jí)知識(shí)分子家庭,父親戴光是大慶石油學(xué)院的博士后。還在上小學(xué)的戴志康沒(méi)事就去鼓搗家里的電腦,從286到586,家里的電腦一次次為他升級(jí),戴志康編程的本事也越來(lái)越高。
????2000年,戴志康竟然經(jīng)過(guò)高考前一個(gè)月的突擊準(zhǔn)備考進(jìn)一所知名大學(xué)的 通信 工程專業(yè),這讓老師同學(xué)大跌眼鏡。然而進(jìn)入大學(xué)一年級(jí)后,戴志康便很少在學(xué)校,而是自己在外創(chuàng)業(yè)。“我當(dāng)時(shí)在外面租了個(gè)月租300塊錢的房子,一天差不多15個(gè)小時(shí)都泡在電腦前面,悶頭開發(fā)Discuz!”。
????Discuz!是一套能自動(dòng)生成社區(qū)的軟件,能讓不懂技術(shù)的人也能管理自己設(shè)計(jì)的網(wǎng)絡(luò)社區(qū)。剛開始研發(fā)時(shí),戴志康并沒(méi)打算以此創(chuàng)業(yè),“我想畢業(yè)后找個(gè)好工作,所以開始研發(fā)Discuz!時(shí)只是興趣,就想證明自己的能力。但在研發(fā)過(guò)程中,當(dāng)我產(chǎn)生以此掙錢的念頭時(shí),就不再想找工作了。”
????現(xiàn)在,Discuz!已經(jīng)是社區(qū)軟件領(lǐng)域的老大,戴志康也開始進(jìn)行公司的轉(zhuǎn)型,把產(chǎn)品免費(fèi)供應(yīng)給客戶,轉(zhuǎn)而從為客戶提供服務(wù)中獲取收入。這個(gè)仍習(xí)慣于吃學(xué)校食堂、穿地?cái)傄路s開著銀灰色 寶馬 的年輕人,談起自己公司的發(fā)展方向頭頭是道,老練得讓人有些超出想像。
????寬松的家庭教育造就了創(chuàng)業(yè)素質(zhì)
????戴志康的辦公室立著一個(gè)空空的書架,“我不喜歡看書,我認(rèn)為書是用來(lái)查的,不是用來(lái)翻的,我討厭被動(dòng)地接收信息,我喜歡從生活中掘取信息”。戴志康的學(xué)習(xí)與常人理解的不同,他既不靠學(xué)校也不靠書本,而是從生活的細(xì)節(jié)中學(xué)習(xí)。
????經(jīng)常和朋友聊天到凌晨的戴志康,從中“偷學(xué)”到不少東西。
“另外,我喜歡獨(dú)立思考。只有獨(dú)立的人才會(huì)堅(jiān)強(qiáng)。當(dāng)遇到看似解決不了的困難時(shí),不獨(dú)立的人馬上想到的是尋求幫助。但在一個(gè)商業(yè)社會(huì)里如果沒(méi)有利益的關(guān)聯(lián),沒(méi)有人會(huì)幫你,你獲得了別人的幫助也就意味著自己商業(yè)利益的損失。”戴志康說(shuō),“再有,勇氣和執(zhí)著是創(chuàng)業(yè)必須的基本素質(zhì),而這兩點(diǎn)獨(dú)立的人很容易獲得。”
????戴志康把這種獨(dú)立思考能力的養(yǎng)成歸功于家庭教育,“我父母的教育方式比較西化,給我很大的空間。當(dāng)然,父母同時(shí)也要我自己負(fù)責(zé)任,什么都靠自己,不到萬(wàn)不得已他們不會(huì)伸手幫忙。而且我父母都是老師,每天和年輕人接觸,心態(tài)也比較年輕。”
????戴志康的父親戴光在向筆者總結(jié)他的教育方式時(shí)說(shuō),對(duì)孩子的培養(yǎng)不能限制得太死,要給孩子建議而不是命令,孩子覺(jué)得對(duì)的要采納,要讓他自己思考,不能給現(xiàn)成的答案,這樣孩子才能有自信、有想法,不是一塊只會(huì)跟著別人的木頭。
????“我覺(jué)得戴志康之所以能取得一些成就,是他發(fā)揮了自己的特長(zhǎng),大學(xué)里就有了自己的產(chǎn)品,他的創(chuàng)造能力和創(chuàng)新思維特別強(qiáng),又有敢想敢干的冒險(xiǎn)精神,還有就是這孩子是個(gè)踏踏實(shí)實(shí)干事的人,能容得下事、容得下人。”戴光這樣評(píng)價(jià)自己的兒子。
????無(wú)獨(dú)有偶,李想同樣來(lái)自一個(gè)環(huán)境寬松的家庭,他也把自己最重要的創(chuàng)業(yè)素質(zhì)歸結(jié)為“獨(dú)立思考和總結(jié)能力強(qiáng)”以及不斷學(xué)習(xí)的能力。“我小學(xué)時(shí)父母給的是命令,初中時(shí)給的是建議,高中時(shí)是從朋友的角度提出參考,到了高中以后就是信任了。父母給了我很多獨(dú)立思考的機(jī)會(huì),我基本沒(méi)有受過(guò)什么束縛。”李想說(shuō)。
????財(cái)富新貴引發(fā)教育新思考
????“因?yàn)槌隽宋覀冞@樣一批人而在社會(huì)上引起什么‘高等教育無(wú)用論’,純屬瞎扯。現(xiàn)實(shí)是大學(xué)里沒(méi)有目標(biāo)、隨波逐流的人太多了,所以我們這樣目標(biāo)明確并堅(jiān)持下來(lái)的人才顯現(xiàn)出來(lái)。
????”沒(méi)有上過(guò)大學(xué)的李想說(shuō)。
????李想坦言,沒(méi)有上大學(xué)的確是自己的一個(gè)遺憾,因?yàn)槿松腥鄙倭艘环蒹w驗(yàn)。“如果你有明確的目標(biāo),大學(xué)絕對(duì)是一個(gè)非常好的學(xué)習(xí)場(chǎng)所。但相對(duì)于上學(xué)來(lái)說(shuō),更重要的是一個(gè)人要有目標(biāo)和方向。”
????李想把現(xiàn)在的大學(xué)生分為兩類:畢業(yè)后可以挑單位的和畢業(yè)后“海投”簡(jiǎn)歷也找不到工作的,“凡是可以挑單位的學(xué)生,絕對(duì)是從大一起就有明確的目標(biāo)并一直為之努力。現(xiàn)在很多大學(xué)生或者是迷茫,或者雖有目標(biāo),但一遇到困難,就‘喜新厭舊’,常立志而不立長(zhǎng)志。”
????上了重點(diǎn)大學(xué)卻半路“逃跑”的戴志康這樣看待自己4年的大學(xué)生活:“我考通信專業(yè)時(shí)本來(lái)以為會(huì)學(xué)到數(shù)字通信,接觸到一些大型的 交換機(jī) ,結(jié)果到大三才學(xué)到收音機(jī)原理,大四才學(xué)了黑白 電視 機(jī)原理。大學(xué)的課程設(shè)置太落后于時(shí)代,與用人單位的實(shí)際需求太脫節(jié)。”
????本身就是大學(xué)教授的戴光坦言,現(xiàn)在大學(xué)的課程設(shè)置的確存在滯后問(wèn)題。“雖然現(xiàn)在高等教育已進(jìn)入 大眾 化時(shí)代,但很多老師和高校管理者的思維還停留在精英教育上。精英教育是細(xì)線條的,什么都要講到,是培養(yǎng)理論家的,而大眾教育是粗線條的,應(yīng)該給學(xué)生一定的空間,應(yīng)該多一些應(yīng)用性的東西。”
????清華大學(xué)科技園副主任、被譽(yù)為清華“創(chuàng)業(yè)之父”的羅建北認(rèn)為,像戴志康、李想這樣的人,在現(xiàn)有的大學(xué)體系中很難培養(yǎng)出來(lái),因?yàn)樵趹?yīng)試教育模式下,很難把創(chuàng)業(yè)所需的一些素質(zhì)加入到教學(xué)中,“創(chuàng)業(yè)素質(zhì)的培養(yǎng)和應(yīng)試教育就是一對(duì)矛盾,因?yàn)槟阋獙W(xué)生多了解社會(huì),從而發(fā)現(xiàn)市場(chǎng)的需求和商機(jī),這都需要時(shí)間來(lái)實(shí)踐,那考試怎么辦?”
合肥留學(xué)生創(chuàng)業(yè)園 劉濤 ?