2010年12月29日 星期三

用 Java 做簡單的 Thread pool

以往用 Java 寫 Thread Pool 並不是簡單的事,不過在 JavaSE 5.0 裡,用幾行 code 就可以:

import java.util.concurrent.Executor;
import java.util.concurrent.Executors;

public class TestExecutor {
public static class Command implements Runnable {
private int id;

public Command(int id) {
this.id = id;
}

public void run() {
System.out.println(id + " Begin " + Thread.currentThread().getName());
try {
Thread.sleep(3000);
}
catch (InterruptedException ex) {
ex.printStackTrace();
}
System.out.println(id + " End " + Thread.currentThread().getName());
}
}

public static void main(String[] args) {
Executor tp = Executors.newFixedThreadPool(3);
tp.execute(new Command(1));
tp.execute(new Command(2));
tp.execute(new Command(3));
tp.execute(new Command(4));
tp.execute(new Command(5));
}
}

2010年11月17日 星期三

Mysql中count(*),DISTINCT的使用方法和效率研究

在處理一個大數據量數據庫的時候
突然發現mysql對於count(*)的不同處理會造成不同的結果

比如執行
SELECT count(*) FROM tablename
即使對於千萬級別的數據mysql也能非常迅速的返回結果
而對於
SELECT count(*) FROM tablename WHERE…..
mysql的查詢時間開始攀升

仔細查閱累下手冊,發現當沒有WHERE語句對於整個mysql的表進行count運算的時候
MyISAM類型的表中保存有總的行數,而當添加有WHERE限定語句的時候Mysql需要對整個表進行檢索
從而得出count的數值

突然又想起來看到的不少新興的php程序對於count的處理並沒有很好的意識到這點
記錄下

順便提下mysql的DISTINCT的關鍵字有很多你想不到的用處

2010年9月16日 星期四

Regular Expression (RegExp) in JavaScript


Regular Expression (以下簡稱 REGEX) 是以一組特定字元符號描述字串樣式規則的記述語法。簡單地說, REGEX 用於表達字元符號在字串中出現的規則。舉個例子說明,在 REGEX 中,字元 '^' 放在第一個位置表示字串開頭位置,當我寫下 ^A 的記述時,便表示必須是一個開頭為 A 的字串,如 Adam,才符合此一規則。這個表達規則通常稱為 pattern 。 ECMAScript/JavaScript 以內建的 RegExp Object 提供 REGEX 功能。See also: ECMA-262 15.10 - RegExp Objects





要產生一個 RegExp 個體有兩種方式。第一種是直接以斜線 (/) 包住 pattern ,例如 /^A/ 。注意不要再用單引號或雙引號包在斜線外圍,一但用了引號圍住,就只是一個 String 而非 RegExp 個體。 "/^A/" 就是錯誤寫法,這只是一個普通字串。第二種是向系統要求建立一個 RegExp 個體,即 new RegExp(pattern) ,引數 pattern 可以是一個字串也可以是另一個 RegExp 個體。第一種方法只能使用常值的 pattern ,我們不能用斜線包住一個變數或一個字串運算結果。如果 pattern 保存在變數之中,則必須使用第二種方式。




RegExp 個體提供兩個主要行為,即 exec() 和 test() 。 exec() 會對引數字串進行比對運算,並將匹配的字串內容記錄在陣列中回傳。而 test() 則僅僅測試引數字串是否符合規則,只回傳 truefalse 。此外,RegExp 個體也可以作為 String 個體的 match(), search(), replace(), split() 之引數。 String 的 match() 其實就是調用 RegExp 的 exec() ,兩者的結果相同。



2010年9月9日 星期四

JAVA日期問題總結.轉


【轉錄自某簡體網頁】


● JAVA日期問題總結


1、獲取服務器端當前日期:
<%@ page import="java.util.Date"%>
<%
Date myDate = new Date();
%>
2、獲取當前年、月、日:

<%@ page import="java.util.Date"%>

<%
Date myDate = new Date();
int thisYear = myDate.getYear() + 1900;//thisYear = 2003
int thisMonth = myDate.getMonth() + 1;//thisMonth = 5
int thisDate = myDate.getDate();//thisDate = 30
%>


3、按本地時區輸出當前日期

<%@ page import="java.util.Date"%>
<%
Date myDate = new Date();
out.println(myDate.toLocaleString());
%>


輸出結果為:
2003-5-30



Convert string to Date in JSP






<%@ page import=

"java.util.Date,java.text.SimpleDateFormat,

java.text.ParseException"

%>

<%

String dateStr = request.getParameter("date");

SimpleDateFormat formater =
new SimpleDateFormat("dd-MM-yyyy hh:mm:ss");

Date result = formater.parse(dateStr);

out.println(result);

%>

2010年7月29日 星期四

java 判斷是否為數字



public boolean CheckNum(str){

for (int j=0;j < str.length();j++){
if (java.lang.Character.isDigit(str.charAt(j))){
} else {
return false;
break;
}
}
return true;
}

2010年7月19日 星期一

mysql語句中用if的例子

select *,if(sva=1,"男","女") as ssva from taname where sva<>""

12.2. 控制流程函數
CASE value WHEN [compare-value] THEN result [WHEN [compare-value] THEN result ...] [ELSE result] END CASE WHEN [condition] THEN result [WHEN [condition] THEN result ...] [ELSE result] END
在第一個方案的返回結果中, value=compare-value。而第二個方案的返回結果是第一種情況的真實結果。如果沒有匹配的結果值,則返回結果為ELSE後的結果,如果沒有ELSE 部分,則返回值為NULL。

MySQL> SELECT CASE 1 WHEN 1 THEN 'one'

-> WHEN 2 THEN 'two' ELSE 'more' END;

-> 'one'

mysql> SELECT CASE WHEN 1>0 THEN 'true' ELSE 'false' END;

-> 'true'

mysql> SELECT CASE BINARY 'B'

-> WHEN 'a' THEN 1 WHEN 'b' THEN 2 END;

-> NULL

一個CASE表達式的默認返回值類型是任何返回值的相容集合類型,但具體情況視其所在語境而定。如果用在字符串語境中,則返回結果味字符串。如果用在數字語境中,則返回結果為十進制值、實值或整數值。

IF(exPR1,expr2,expr3)
如果expr1 是TRUE (expr1 <> 0 and expr1 <> NULL),則IF()的返回值為expr2; 否則返回值則為expr3。 IF() 的返回值為數字值或字符串值,具體情況視其所在語境而定。

mysql> SELECT IF(1>2,2,3);

-> 3

mysql> SELECT IF(1<2,'yes ','no');

-> 'yes'

mysql> SELECT IF(STRCMP('test','test1'),'no','yes');

-> 'no'

如果expr2 或expr3中只有一個明確是NULL,則IF() 函數的結果類型為非NULL表達式的結果類型。

expr1 作為一個整數值進行計算,就是說,假如你正在驗證浮點值或字符串值, 那麼應該使用比較運算進行檢驗。

mysql> SELECT IF(0.1,1,0);

-> 0

mysql> SELECT IF(0.1<>0,1,0);

-> 1

在所示的第一個例子中,IF(0.1)的返回值為0,原因是0.1 被轉化為整數值,從而引起一個對IF(0)的檢驗。這或許不是你想要的情況。在第二個例子中,比較檢驗了原始浮點值,目的是為了了解是否其為非零值。比較結果使用整數。

IF() (這一點在其被儲存到臨時表時很重要) 的默認返回值類型按照以下方式計算:

表達式
返回值

expr2 或expr3 返回值為一個字符串。
字符串

expr2 或expr3 返回值為一個浮點值。
浮點

expr2 或 expr3 返回值為一個整數。
整數


假如expr2 和expr3 都是字符串,且其中任何一個字符串區分大小寫,則返回結果是區分大小寫。
http://blog.knowsky.com/
IFNULL(expr1,expr2)
假如expr1 不為NULL,則IFNULL() 的返回值為expr1; 否則其返回值為expr2。 IFNULL()的返回值是數字或是字符串,具體情況取決於其所使用的語境。

mysql> SELECT IFNULL(1,0);

-> 1

mysql> SELECT IFNULL(NULL,10);

-> 10

mysql> SELECT IFNULL(1/0,10);

-> 10

mysql> SELECT IFNULL(1/0,'yes');

-> 'yes'

IFNULL(expr1,expr2)的默認結果值為兩個表達式中更加“通用”的一個,順序為STRING、 REAL或INTEGER。假設一個基於表達式的表的情況, 或MySQL必須在內存儲器中儲存一個臨時表中IFNULL()的返回值:

CREATE TABLE tmp SELECT IFNULL(1,'test') AS test;

在這個例子中,測試列的類型為CHAR(4)。

NULLIF(expr1,expr2)
如果expr1 = expr2 成立,那麼返回值為NULL,否則返回值為expr1。這和CASE WHEN expr1 = expr2 THEN NULL ELSE expr1 END相同。

mysql> SELECT NULLIF(1,1);

-> NULL

mysql> SELECT NULLIF(1,2);

-> 1

注意,如果參數不相等,則MySQL 兩次求得的值為 expr1 。

引用:http://zxlm.cityk.cn/fh/viewthread.php?tid=1395


资料引用:http://www.knowsky.com/345280.html

CASE 指令,MySQL 的 switch 與 if else



  1. 必須依附在 SELECT,UPDATE,INSERT,DELETE 下
  2. 不可用在區段中加其他動作
  3. 具有 switch 與 if else 兩種架構


-- switch 的用法
SELECT CASE col
WHEN 100 THEN '1'
WHEN 50 THEN '2'
ELSE '3'
END
FROM table;



-- if else 的用法
SELECT CASE
WHEN col>100 THEN '1'
WHEN col>50 THEN '2'
ELSE '3'
END
FROM table;



-- IFNULL 的用法
SELECT IFNULL(a.col, b.col)
FROM table1 as a,table2 as b;

2010年4月12日 星期一

Linux下mysql中文問題

操作系統環境:

CentOS4.8、MySQL 5.1.45

現象:

在此電腦上安裝了Tomcat作為web服務器,部署了一個項目,通過jdbc連接到mysql數據庫。但是發現中文輸入輸出亂碼現象。

解決步驟:

1. 找到mysql的配置文件

網上說,mysql的配置文件就是/etc/my.cnf。但是這個文件並不一定存在,由於你可能採取的MySQL安裝方式跟網上所說的不一樣,就不一定能夠找得到/etc/my.cnf。因此,你需要使用find命令查找cnf文件。記得不要去找my.cnf因為它不一定存在,而應該找*.cnf。

VSFTP 設定與參數

相關檔案或目錄
/etc/vsftpd/vsftpd.conf //vsftpd的設定檔
/etc/pam.d/vsftpd //PAM模組設定檔,身份認證之用
/etc/vsftpd.ftpusers //pam模組用來指定某user無法登入的設定檔
/etc/vsftpd.user_list //依vsftpd.conf內的userlist_enable, userlist_deny參數設定而有不同功能
/etc/vsftpd.chroot_list //將某帳號chroot 在他們的家目錄下,和vsftpd.conf內的chroot_list_enable, chroot_list_file參數相關
/usr/sbin/vsftpd //主要執行檔
/var/ftp/ //匿名使用者登入的根目錄


常用功能設定做法
不讓某帳號離開家目錄
修改vsftpd.conf

2010年4月9日 星期五

PermGen space及其解決方法

1、PermGen space的全稱是Permanent Generation space,是指內存的永久保存區域OutOfMemoryError: PermGen space從表面上看就是內存益出,解決方法也一定是加大內存。說說為什麼會內存益出:這一部分用於存放Class和的信息,Class在被Load的時候被放入PermGen space區域,它和和存放Instance的Heap區域不同,GC(Garbage Collection)不會在主程序運行期對PermGen space進行清理,所以如果你的APP會LOAD很多CLASS的話,就很可能出現PermGen space錯誤。這種錯誤常見在web服務器對JSP進行pre compile的時候。

2010年4月8日 星期四

Linux下mysql大小寫問題

1、Linux下mysql安裝完後是默認:區分表名的大小寫,不區分列名的大小寫;


2、用root帳號登錄後,在/etc/my.cnf 中的[mysqld]後添加添加lower_case_table_names=1,重啟MYSQL服務,這時已設置成功:不區分表名的大小寫;



MySQL帳號與權限設定

當有多人使用MySQL Server時,若都以MySQL管理者root身份登入,這是很危險的事情。root什麼事情都可以做,所以為了避免root密碼外洩造成資料庫資安風險提高,建議另外新增帳號,並賦予適當的存取權限。

--------------------------------------------------------------------------------
請以MySQL管理者root身份登入MySQL,你可以使用「grant on」指令新增使用者與權限的調整。當使用者不存在時會建立帳號,若存在則會變更權限,grant on指令基本設定如下:
grant 權限 on 資料庫.資料表 to 帳號@主機 identified by‘密碼’

2010年4月7日 星期三

CentOS jdk1.6 安裝

SUN 官網

http://java.sun.com/javase/downloads/index.jsp

下載 JDK jdk-6u19-linux-i586-rpm.bin

> chmod a+x jdk-6u19-linux-i586-rpm.bin

執行安裝

> ./jdk-6u19-linux-i586-rpm.bin

切換目錄到/usr/bin
> cd /usr/bin

作link
> ln -s -f /usr/java/jdk1.6.0_19/bin/java
> ln -s -f /usr/java/jdk1.6.0_19/bin/javac

> vim hello.java

按 i 進行編輯


Linux RPM 使用講解

前言:
原文出處:

作者: 我從山中來
http://tw.group.knowledge.yahoo.com/hacker-cracker/article/view?aid=1202

http://doc.linuxpk.com/153.html

歡迎參觀 AYO 阿佑 個人的電腦技術園地
http://tw.myblog.yahoo.com/kain-0913/

AYO阿佑 這次來講說,Linux 世界中,有一種工具叫做 RPM,
這個是 Linux 套件安裝、升級、更新 的方法之一,
先行說明一下幾個名詞解釋 :
RPM : 這是 Linux 安裝、升級、更新方法之一,泰半都是 Red Hat 公司出品的 Linux 居多,
會這麼說是因為是因為 RPM 全名叫做,RedHat Package Managmer,
所以 Red Hat 相關的 Linux,都 100% 支援此種方式,
例如 : RedHat、RHEL、Fedora Core、CentOS
DPKG : 這又是另外一種 Linux 安裝、升級、更新方法之一,源出自 Debian Linux,
而 Linux 中,N User 比較常聽過的 Ubuntu,也是支援這個方法喔!!
當然還有 FreeBSD 也是支援此方式做的喔!

CentOS移除以及安裝mysql-server

如果忘記了mysql-server的密碼,只好重裝 :

#yum remove mysql-server --->移除mysql-server
#rm -rf /var/lib/mysql/ --->徹底清除相關目錄
#yum -y install mysql-server --->安裝
#service mysqld restart --->重啟服務
#mysqladmin -u root password 填新密碼 --->變更mysql的root的密碼

2010年4月1日 星期四

SAXBuilder、Document、Element的用法

import org.jdom.Document;
import org.jdom.Element;
import org.jdom.JDOMException;
import org.jdom.input.SAXBuilder;
import org.jdom.output.XMLOutputter;
(1)使用JDOM首先要指定使用什麼解析器。如:
SAXBuilder builder=new SAXBuilder(false); 這表示使用的是默認的解析器
(2)得到Document,我們以後要進行的所有操作都是對這個Document操作的:
Document doc=builder.build(xmlpath);
(3)得到根元素:
Element books=doc.getRootElement();
在JDOM中所有的節點(DOM中的概念)都是一個org.jdom.Element類,當然他的子節點也是一個org.jdom.Element類。
(4)得到元素(節點)的集合:
List booklist=books.getChildren("book");
這表示得到“books”元素的所在名稱為“book”的元素,並把這些元素都放到一個List集合中
(5)輪循List集合
for (Iterator iter = booklist.iterator(); iter.hasNext();) {
Element book = (Element) iter.next();

還有一種輪循方法是:

用JDom輕鬆整合Java和XML

Jdom是用Java語言讀、寫、操作XML的新API函數。 Jason Hunter 和Brett McLaughlin公開發布了它的測試版本。在直覺、簡單和高效的前提下,這些API函數被最大限度的優化。在接下來的篇幅裡,Hunter 和McLaughlin介紹怎麼用Jdom去讀寫一個已經存在的XML文檔。

Jdom是一個開源的api,它以直接易懂的方式向java程序員描述XML文檔和文檔的內容。就像名字揭示的那樣,Jdom是為java優化的。為使用XML文檔提供一個低消耗的方法。 Jdom的使用者可以不必掌握太多的XML的知識就可以完成想要的操作。

2010年3月31日 星期三

何時用JSP何時用Servlet?

JSP (JavaServer Page)與Servlet主要是基於分工而產生的。。。

JSP是讓熟悉網頁設計語法的網頁人員可以快速入門,當中不建議有Scriplet,也就是不建議出現<% Java語法 %>,而儘量使用EL、標籤、JavaBean、JSTL等。。。主要用於呈現畫面與資料,不是用於處理業務邏輯。。。

Servlet主要是給熟悉Java語言的開發人員而設計的,在Servlet中不建議出現有HTML內嵌的程式碼,會很難寫,Servlet通常是用於後端的處理,將處理完的資料封裝好之後,丟給JSP來呈現資料。。。

當然,您硬要只用JSP來撰寫,技術上是可行的,或您想用Servlet解決所有的事也是可以的。。。

然而最好的方法是JSP與Servlet相互合作,分好彼此的職責。。。

2010年3月30日 星期二

public class HelloWorld {
private int field;
public static void main(String[] args) {
System.out.println("Hello! World!");
}}


public 修飾子
class 類別
HelloWorld 類別名稱
void 回傳值
main 方法 (Method)
field 欄位 -> 屬性


命名慣例讓程式更容易被理解和閱讀。他們也可以給予關於識別子功能的
資訊 -- 例如,是否為常數,套件,或是類別 -- 這可以在瞭解程式碼時很有
幫助。

●package:英文全部使用小寫,例如:com.xx、java.lang....
●類別:每一個英文單字的第一個字母大寫,例如:Phoenix、PhoenixUtility
●介面:每一個英文單字的第一個字母大寫,例如:Phoenix、PhoenixUtility
●方法:第一個英文單字的英文字母小寫,其他單字的第一個英文字母大寫,例如:phoenix、phoenixUtility
●常數:英文字母全部大寫,且兩兩之間用底線隔開,例如:PHOENIX、PHOENIX_UTILITY
<SCRIPT LANGUAGE="JavaScript">
var myDate = new Date();
myDate.getYear(); //獲取當前年份(2位)
myDate.getFullYear(); //獲取完整的年份(4位,1970-????)
myDate.getMonth(); //獲取當前月份(0-11,0代表1月)
myDate.getDate(); //獲取當前日(1-31)
myDate.getDay(); //獲取當前星期X(0-6,0代表星期天)
myDate.getTime(); //獲取當前時間(從1970.1.1開始的毫秒數)
myDate.getHours(); //獲取當前小時數(0-23)
myDate.getMinutes(); //獲取當前分鐘數(0-59)
myDate.getSeconds(); //獲取當前秒數(0-59)
myDate.getMilliseconds(); //獲取當前毫秒數(0-999)
myDate.toLocaleDateString(); //獲取當前日期
var mytime=myDate.toLocaleTimeString(); //獲取當前時間
myDate.toLocaleString( ); //獲取日期與時間

if (mytime<"23:30:00")
{
alert(mytime);
}
</SCRIPT>

2.

<%
java.text.SimpleDateFormat formatter = new java.text.SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

java.util.Date currentTime = new java.util.Date();//得到當前系統時間

String str_date1 = formatter.format(currentTime); //將日期時間格式化
String str_date2 = currentTime.toString(); //將Date型日期時間轉換成字符串形式
%>

2010年3月22日 星期一

語言技術: JSP/Servlet

在 Java EE 的藍圖中,JSP/Servlet 是屬於 Web 層技術,JSP 與 Servlet 是一體的兩面,您可以使用單獨一項技術來解決動態網頁呈現的需求,但最好的方式是取兩者的長處,JSP 是網頁設計人員導向的,而Servlet 是程式設計人員導向的,釐清它們之間的職責可以讓兩個不同專長的團隊彼此合作,並降低相互間的牽制作用。


轉載自 Gossip@caterpillar

2010年3月18日 星期四

Java語言的寫作風格

Java語言的寫作風格


寫作Java程式時,請注意下列幾種風格

  • Class Name請首字大寫
  • Variable Name和Method Name請首字小寫
  • 如果名稱由數個英文字組成,第二個英文字以後首字大寫
  • 內縮四個空格
  • 註解部分如要變成說明文件,請遵照javadoc這個工具的寫作規則