Thứ Hai, 30 tháng 3, 2015

THUẬT TOÁN [ P_4 ]

http://tedvn.com/wp-content/uploads/2014/07/Whats-an-algorithm-David-J-Malan.jpg1.4. SỐ NGUYÊN VÀ THUẬT TOÁN.
1.4.1. Thuật toán Euclide:
Phương pháp tính ước chung lớn nhất của hai số bằng cách dùng phân tích các số nguyên đó ra thừa số nguyên tố là không hiệu quả. Lý do l à ở chỗ thời gian phải tiêu tốn cho sự phân tích đó. Dưới đây là phương pháp hiệu quả hơn để tìm ước số chung lớn nhất, gọi là thuật toán Euclide. Thuật toán này đã biết từ thời cổ đại. Nó mang tên nhà toán học cổ Hy lạp Euclide, ng ười đã mô tả thuật toán này trong cuốn sách “Những yếu tố” nổi tiếng của ông. Thuật toán Euclide dựa vào 2 mệnh đề sau đây.

Mệnh đề 1 (Thuật toán chia): Cho a và b là hai số nguy ên và b 0. Khi đó tồn tại duy nhất hai số nguyên q và r sao cho a = bq+r, 0  r < |b|.
Trong đẳng thức trên, b được gọi là số chia, a được gọi là số bị chia, q được gọi là thương s ố và r được gọi là số dư.
Khi b là nguyên dương, ta ký hiệu số dư r trong phép chia a cho b là a mod b. Mệnh đề 2: Cho a = bq+r, trong đó a, b, q, r là các số nguyên. Khi đó
UCLN(a,b) = UCLN(b,r).(Ở đây UCLN(a,b) để chỉ ước chung lớn nhất của a và b.)
Giả sử a và b là hai s ố nguy ên d ương với a  b. Đặt r0= a và r1 = b. Bằng cách áp dụng liên tiếp thuật toán chia, ta tìm được:
r0= r1q1+ r2      
0  r2< r1              r1= r2q2+ r3              0  r3< r2
..................
rn-2= rn-1qn-1+ rn
0 <= rn< rn-1rn-1= rn qn.
Cuối cùng, số dư 0 sẽ xuất hiện trong dãy các phép chia liên tiếp, vì dãy các số d ư
a = r0> r1> r2>... >= 0
không thể chứa quá a số hạng được. Hơn nữa, từ Mệnh đề 2 ở trên ta suy ra:
UCLN(a,b) = UCLN(r0,r1) = UCLN(r1,r2) = ... = UCLN(rn-2, rn-1) = UCLN(rn-1,rn) = rn.
Do đó, ước chung lớn nhất là số dư khác không cuối cùng trong dãy các phép chia.
Thí dụ 6: Dùng thuật toán Euclide tìm UCLN(414, 662).
662 = 441.1 + 248
414 = 248.1 + 166
248 = 166.1+ 82
166 = 82.2 + 2
82 = 2.41.
Do đó, UCLN(414, 662) = 2.
Thuật toán Euclide được viết dưới dạng giả mã như sau:
procedure ƯCLN (a,b: positive integers)
x := a
y := b
while y <= 0
begin
r := x mod y
x := y
y := r
end
{UCLN (a,b) là x}
Trong thuật toán tr ên, các giá trị ban đầu của x và y tương ứng là a và b. Ở mỗi giai đoạn của thủ tục, x được thay bằng y và y được thay bằng x mod y. Quá trình này được lặp lại chừng nào y <= 0. Thuật toán sẽ ngừng khi y = 0 v à giá trị của x ở điểm n ày, đó là số dư khác không cuối cùng trong thủ tục, cũng chính là ước chung lớn nhất của a và b.
1.4.2. Biểu diễn các số nguyên:
Mệnh đề 3: Cho b là một số nguyên dương lớn hơn 1. Khi đó nếu n là một số nguyên dương, nó có thể được biểu diễn một cách duy nhất dưới dạng:
n = ak bk+ ak-1bk-1+ ... + a1b + a0.
Ở đây k là một số tự nhiên, a0, a1,..., ak là các số tự nhiên nhỏ hơn b và ak<= 0.
Biểu diễn của n được cho trong Mệnh đề 3 được gọi là khai triển của n theo cơ số b, ký hiệu là (akak-1... a1a0)b.
Bây giờ ta sẽ mô tả thuật toán xây dựng khai triển cơ số b của số nguyên n bất kỳ. Tr ước hết ta chia n cho b để được thương và số dư, tức là
n = bq0+ a0, 0 <= a0< b.
Số dư a0 chính là chữ số đứng bên phải cùng trong khai triển c ơ số b c ủa n. Tiếp theo chia q0 cho b, ta được:
q0= bq1+ a1, 0 <= a1< b.
Số dư a1 chính là chữ số thứ hai tính từ bên ph ải trong khai triển c ơ số b của n. Tiếp tục quá trình này, bằng cách liên tiếp chia các thương cho b ta sẽ được các chữ số tiếp theo trong khai triển cơ số b của n là các số d ư tương ứng. Quá trình này sẽ kết thúc khi ta nhận được một thương bằng 0.
Thí dụ 7: Tìm khai triển cơ số 8 của (12345)10.
12345 = 8.1543 + 1
1543 = 8.192 + 7
192 = 8.24 + 0
24 = 8.3 + 0
3 = 8.0 + 3.
Do đó, (12345)10= (30071)8.
Đoạn giả mã sau biểu diễn thuật toán tìm khai triển cơ số b của số nguyên n.
procedure khai triển theo c ơ số b (n: positive integer)
q := n
k := 0
while q <= 0
begin
ak:= q mod b
q := [qb]
k := k + 1
end
1.4.3. Thuật toán cho các phép tính số nguyên:
Các thuật toán thực hiện các phép tính với những số nguyên khi dùng các khai triển nhị phân của chúng là cực kỳ quan trọng trong số học của máy tính. Ta sẽ mô tả ở
đây  các thuật toán cộng và nhân hai  số nguyên trong biểu diễn nhị phân. Ta cũng sẽ phân tích đ ộ phức tạp tính toán của các thuật toán này thông qua số các phép toán bit thực sự được dùng. Giả sử khai triển nhị phân của hai số nguyên dương a và b là:
a = (an-1an-2... a1a0)2
và b = (bn-1bn-2... b1b0)2
sao cho a và b đều có n bit (đặt các bit 0 ở đầu mỗi khai triển đó, nếu cần).
1) Phép cộng: Xét bài toán cộng hai số nguy ên viết ở dạng nhị phân. Thủ tục thực hiện phép cộng có thể dựa trên phương pháp thông thường là cộng cặp chữ số nhị phân với nhau (có nhớ) để tính tổng của hai số nguyên.
Để cộng a và b, trư ớc hết cộng hai bit ở phải cùng của chúng, tức là:
a0+ b0= c0.2 + s0.
Ở đây s0 là bit phải c ùng trong khai triển nhị phân của a+b, c0 là số nhớ, nó có thể bằng 0 hoặc 1. Sau đó ta cộng hai bit tiếp theo và số nhớ
a1+ b1+ c0= c1.2 + s1.
Ở đây s1 là bit tiếp theo (tính từ bên phải) trong khai triển nhị phân của a+b và c1 là số nhớ. Tiếp tục quá trình này b ằng cách cộng các bit tương ứng trong hai khai triển nhị phân và số nhớ để xác định bit tiếp sau tính từ bên phải trong khai triển nhị phân của tổng a+b. Ở giai đoạn cuối cùng, c ộng an-1, bn-1
và cn-2 để nhận được cn-1.2+sn-1. Bit đứngđầu của tổng là sn=cn-1. 
Kết quả, thủ tục này tạo ra được khai triển nhị phân của tổng, cụ thể là a+b = (sn.sn-1sn-2... s1s0)2.
Thí dụ 8: Tìm tổng của a = (11011)2và b = (10110)2.
a0+ b0= 1 + 0 = 0.2 + 1 (c0= 0, s0= 1), 
a1+ b1+ c0= 1 + 1 + 0 = 1.2 + 0 (c1= 1,s1= 0),
 a2+ b2+c1= 0 + 1 + 1 = 1.2 + 0 (c2= 1, s2= 0), 
a3+ b3+ c2= 1 + 0 + 1 = 1.2 +0 (c3= 1, s3= 0), 
a4+ b4+c3= 1 + 1 + 1 = 1.2 + 1 (s5= c4=1, s4= 1).
Do đó, a + b = (110001)2.
Thuật toán cộng có thể được mô tả bằng cách dùng đoạn giả mã như sau.
procedure cộng (a,b: positive integers)
c := 0
for j := 0 to n-1
begin
d:= (aj+bj+c)/2
sj:= aj+ bj+ c - 2d
c := d
end
sn:= c
{khai triển nhị phân của tổng là (snsn-1...s1s0)2}
Tổng hai số  nguyên  đư ợc tính bằng cách cộng liên tiếp các cặp bit và khi cần
phải cộng cả số nhớ nữa. Cộng một cặp bit và số nhớ đòi ba hoặc ít hơn phép c ộng các
bit. Như vậy, tổng số các phép cộng bit được sử dụng nhỏ hơn ba lần số bit trong khai
triển nhị phân. Do đó, độ phức tạp của thuật toán này là O(n).
2) Phép nhân: Xét bài toán nhân hai số nguyên vi ết ở dạng nhị phân. Thuật toán thông
thường tiến hành như sau. Dùng luật phân phối, ta có:

Ta có thể tính ab bằng cách dùng phương trình trên. Trước hết, ta thấy rằng abj=a nếubj=1 và abj=0 nếu bj=0. Mỗi lần ta nhân một số hạng với 2 là ta d ịch khai triển nhị phân của nó một chỗ về phía trái bằng cách thêm m ột số không vào cuối khai triển nhị phân của nó. Do đó, ta có thể nhận được (abj)2j
bằng cách dịch khai triển nhị phân của abj đi j chỗ về phía trái, tức là thêm j số không vào cuối khai triển nhị phân của nó. Cuối cùng, ta sẽ nhận được tích ab bằng cách cộng n số nguyên abj.2jvới j=0, 1, ..., n-1.
Thí dụ 9: Tìm tích của a = (110)2và b = (101)2.
Ta có  ab0.2^0=  (110)2.1.2^0=  (110)2,  ab1.2^1=  (110)2.0.2^1=  (0000)2,  ab2.2^2=(110)2.1.2^2= (11000)2. Để tìm tích, hãy cộng (110)2, (0000)2và (11000)2. Từ đó ta có ab= (11110)2.
Thủ tục trên được mô tả bằng đoạn giả mã sau:
procedure nhân (a,b: positive integers)
for j := 0 to n-1
begin
if bj= 1 then cj:= a được dịch đi j chỗ
else cj:= 0
end
{c0, c1,..., cn-1là các tích riêng phần}
p := 0
for j := 0 to n-1
p := p + cj
{p là giá trị của tích ab}
Thuật toán trên tính tích của hai số nguyên a và b bằng cách cộng các tích riêng phần c0, c1, c2, ..., cn-1. Khi b
j=1, ta tính tích riêng phần cj
bằng cách dịch khai triển nhị phân của a đi j bit. Khi b
j=0 thì không cần có dịch chuyển nào vì c
j=0. Do đó, để tìm tất cả n số nguyên abj.2j
với j=0, 1, ..., n-1, đòi hỏi tối đa là 0 + 1 + 2 + ... + n-1 = n (n-1) /2 phép dịch chỗ. 
Vì vậy, số các dịch chuyển chỗ đòi h ỏi l à O(n2).
Để cộng các số nguy n a b j từ j=0 đến n1, đòi hỏi phải cộng một số nguy ên n bit, một số nguyên n+1 bit, ... và một số nguyên 2n bit. Ta đã biết rằng mỗi phép cộng đó đòi hỏi O(n) phép cộng bit. Do đó, độ phức tạp của thuật toán này là O(n2).

THUẬT TOÁN [ P_3 ]

 1.3. ĐỘ PHỨC TẠP CỦA THUẬT TOÁN.
1.3.1. Khái niệm về độ phức tạp của một thuật toán:
Thước đo hiệu quả của một thuật toán là thời gian mà máy tính sử dụng để giải bài toán theo thuật toán đang xét, khi các giá trị đầu vào có một kích thước xác định.
http://tedvn.com/wp-content/uploads/2014/07/Whats-an-algorithm-David-J-Malan.jpgMột thước đo thứ hai là dung lượng bộ nhớ đòi hỏi để thực hiện thuật toán khi các giá trị đầu vào có kích thước xác định. Các vấn đề như thế liên quan đến độ phức tạp tính toán của một thuật toán. Sự phân tích thời gian cần thiết để giải một bài toán có kích thước đặc biệt nào đó liên quan đến độ phức tạp thời gian của thuật toán. Sự phân tích bộ nhớ cần thiết của máy tính liên quan đến độ phức tạp không gian của thuật toán. Việc xem xét độ phức tạp thời gian và không gian của một thuật toán là một vấn đề rất thiết yếu khi các thuật toán được thực hiện. Biết một thuật toán sẽ đưa ra đáp số trong một micro giây,  trong  một  phút  hoặc  trong  một  tỉ  năm,  hiển  nhiên  là  hết  sức  quan  trọng.

Tương tự như vậy, dung lượng bộ nhớ đòi hỏi phải l à khả dụng để giải một bài toán,vì vậy độ phức tạp không gian cũng cần phải tính đến.Vì việc xem xét độ phức tạp không gian gắn liền với các cấu trúc dữ liệu đặc biệt được dùng để thực hiện thuật toán nên ở đây ta sẽ tập trung xem xét độ phức tạp thời gian.
Độ phức tạp thời gian của một thuật toán có thể được biểu diễn qua số các phép toán được dùng bởi thuật toán đó khi các giá trị đầu vào có một kích thước xác định. Sở dĩ độ phức tạp thời gian được mô tả thông qua số các phép toán đòi hỏi thay vì thời gian thực của máy tính là b ởi vì các máy tính khác nhau thực hiện các phép tính sơ cấp trong những khoảng thời gian khác nhau. Hơn nữa, phân tích tất cả các phép toán thành các phép tính bit sơ cấp m à máy tính sử dụng là điều rất phức tạp.

Thí dụ 3: Xét thuật toán tìm số lớn nhất trong dãy n s ố a1, a2, ..., an. Có thể coi kích thước của dữ liệu nhập là số lượng phần tử của dãy số, t ức là n. N ếu coi mỗi lần so sánh hai số của thuật toán đòi hỏi một đơn vị thời gian (giây chẳng hạn) thì thời gian thực hiện thuật toán trong trường hợp xấu nhất là n -1 giây. Với dãy 64 số, thời gian thực hiện thuật toán nhiều lắm là 63 giây.

Thí dụ 4: Thuật toán v ề trò ch ơi “Tháp Hà Nội”
Trò chơi “Tháp Hà Nội” như sau: Có ba cọc A, B, C và 64 cái đĩa (có lỗ để đặt vào cọc), các đĩa có đường kính đôi một khác nhau. Nguyên tắc đặt đĩa vào cọc là: mỗi đĩa chỉ được chồng lên đĩa lớn hơn nó. Ban đầu, cả 64 đĩa được đặt chồng lên nhau ở cột A; hai cột B, C trống. Vấn đề là phải chuyển cả 64 đĩa đó sang cột B hay C, mỗi lần chỉ được di chuyển một đĩa.
Xét  trò  chơi  với  n đĩa  ban đầu  ở  cọc  A  (cọc  B  và  C  trống).  Gọi  Sn là số lần chuyển đĩa để chơi xong trò chơi v ới n đĩa. 
Nếu n=1 thì rõ ràng là S1=1.
Nếu n>1 thì trước hết ta chuyển n-1 đĩa bên trên sang cọc B (giữ yên đĩa thứ n ở dưới cùng của cọc A). Số lần chuyển n -1 đĩa là Sn-1. Sau đó ta chuyển đĩa thứ n từ cọc A sang cọc C. Cuối cùng, ta chuyển n -1 đĩa từ cọc B sang cọc C (số lần chuyển là Sn-1).
Như vậy, số lần chuyển n đĩa từ A sang C là:

 

Thuật toán về trò ch ơi “Tháp Hà Nội” đòi hỏi 2^64-1 lần chuyển đĩa (xấp xỉ 18,4 tỉ tỉ lần). Nếu mỗi lần chuyển đĩa mất 1 giây thì thời gian thực hiện thuật toán xấp xỉ 585 tỉ năm!
Hai thí dụ trên cho th ấy rằng: một thuật toán phải kết thúc sau một số hữu hạn bước, nhưng nếu số hữu hạn này quá lớn thì thuật toán không thể thực hiện được trong thực tế.
Ta nói: thuật toán trong Thí dụ 3 có độ phức tạp là n-1 và là một thuật toán hữu hiệu (hay thuật toán nhanh); thuật toán trong Thí dụ 4 có độ phức tạp là 2^n-1 và đó là một thuật toán không hữu hiệu (hay thuật toán chậm).
1.3.2. So sánh độ phức tạp của các thuật toán:
Một  bài  toán  th ường  có  nhiều  cách  giải,  có  nhiều  thuật  toán để giải, các thuật toán đó có độ phức tạp khác nhau.
Xét bài toán: Tính giá trị của đa thức P(x)=a

Ta hãy xét độ phức tạp của hai thuật toán trên.
Đối với thuật toán 1: ở bước 2, phải thực hiện 1 phép nhân và 1 phép cộng với i=1; 2 phép nhân và 1 phép cộng với i=2, ..., n phép nhân và 1 phép cộng với i=n. Vậy số phép tính (nhân và cộng) mà thuật toán 1 đòi hỏi là:

Đối với thuật toán 2, bước 2 phải thực hiện n lần, mỗi lần đòi hỏi 2 phép tính (nhân rồi cộng), do đó số phép tính (nhân và cộng) mà thuật toán 2 đòi hỏi l à 2n.
Nếu coi thời gian thực hiện mỗi phép tính nhân và c ộng là nh ư nhau và là một đơn vị thời gian thì với mỗi n cho trước, thời gian thực hiện thuật toán 1 là n(n+3)/2, còn thời gian thực hiện thuật toán 2 là 2n.
Rõ ràng là thời gian thực hiện thuật toán 2 ít h ơn so v ới thời gian thực hiện thuật toán  1. Hàm f1(n)=2n là hàm bậc nhất, tăng chậm hơn nhiều so với  hàm bậc hai f2(n)=n(n+3)/2.
Ta nói rằng thuật toán 2 (có độ phức tạp là 2n) là thuật toán hữu hiệu h ơn (hay nhanh hơn) so với thuật toán 1 (có độ phức tạp là n(n+3)/2).
Để so sánh độ phức tạp của các thuật toán, đi ều tiện lợi là coi độ phức tạp của mỗi thuật toán như là cấp của hàm biểu hiện thời gian thực hiện thuật toán ấy. Các hàm xét sau đây đều là hàm của biến số tự nhiên n>0.
Định nghĩa 1:Ta nói hàm f(n) có cấp thấp hơn hay bằng hàm g(n) nếu tồn tại hằng số C>0 và một số tự nhiên n0sao cho |f(n)| <= C|g(n)| với mọi n <= n0.
Ta viết f(n)=O(g(n)) và còn nói f(n) thoả mãn quan hệ big -O đối với g(n).
Theo định nghĩa này, hàm g(n) là một hàm đơn giản nhất có thể được, đại diện cho “sự biến thiên” của f(n).
Khái niệm big-O đã được dùng trong toán học đã gần một thế kỷ nay. Trong tinhọc, nó được sử dụng rộng rãi để phân tích các thuật toán. Nhà toán học người Đức Paul Bachmann là người đầu tiên đưa ra khái niệm big-O vào năm 1892.
Định nghĩa 2: Nếu một thuật toán có độ phức tạp là f(n) v ới f(n)=O(g(n)) thì ta c ũng
nói thuật toán có độ phức tạp O(g(n)).
Nếu  có  hai  thuật  toán  giải  cùng  m ột  bài  toán,  thuật  toán  1  có  độ  phức  tạp
O(g1(n)), thuật toán 2 có độ phức tạp O(g2(n)), mà g1(n) có cấp thấp hơn g2(n), thì ta nói rằng thuật toán 1 hữu hiệu hơn (hay nhanh hơn) thuật toán 2.
1.3.3. Đánh giá độ phức tạp của một thuật toán:
1) Thuật toán tìm ki ếm tuyến tính:
Số các phép so sánh được dùng trong thuật toán n ày cũng sẽ được xem như thước đo độ phức tạp thời gian của nó. Ở mỗi một bước của vòng l ặp trong thuật toán, có hai phép so sánh được thực hiện: một để xem đã tới cuối bảng chưa và một để so sánh phần tử x với một số hạng của bảng. Cuối cùng còn một phép so sánh nữa làm ở ngoài vòng lặp. Do đó, nếu x=ai, thì đã có 2i+1 phép so sánh được sử dụng. Số phép so sánh nhiều nhất, 2n+2, đòi h ỏi phải được sử dụng khi phần tử x không có mặt trong bảng. Từ đó, thuật toán t ìm ki ếm tuyến tính có độ phức tạp là O(n).
2) Thuật toán tìm ki ếm nhị phân:
Để đ ơn gi ản, ta giả sử rằng có n=2kphần tử trong bảng liệt kê a1,a2,...,an, với k là số nguy ên không âm (nếu n không phải là l ũy thừa của 2, ta có thể xem bảng là một phần của bảng gồm 2k+1 phần tử, trong đó k là số nguy ên nhỏ nhấ t sao cho n < 2k+1).
Ở mỗi giai đoạn của thuật toán vị trí của số hạng đầu tiên i và số hạng cuối cùng j của bảng con hạn chế tìm kiếm ở giai đoạn đó được so sánh để xem bảng con này còn nhiều hơn một phần tử hay không. Nếu i < j, một phép so sánh sẽ được làm để xác định x có lớn hơn s ố hạng ở giữa của bảng con hạn chế hay không. Như vậy ở mỗi giai đoạn, có sử dụng hai phép so sánh. Khi trong bảng chỉ còn một phần tử, một phép so sánh sẽ cho chúng ta biết rằng không còn một phần tử nào thêm n ữa và một phép so sánh nữa cho  biết  số  hạng  đó  có  phải  là  x  hay  không.  Tóm  lại  cần  phải  có  nhiều  nhất 2k+2=2log 2n+2 phép so sánh để thực hiện phép t ìm kiếm nhị phân (nếu n không phải là
lũy thừa của 2, bảng gốc sẽ được mở rộng tới bảng có 2k+1 phần tử, với k=[log2n] và sự tìm kiếm đòi hỏi phải thực hiện nhiều nhất 2[log2n]+2 phép so sánh). Do đó thuật toán tìm kiếm nhị phân có độ phức tạp là O(log2n). Từ sự phân tích ở trên suy ra rằng thuậttoán tìm kiếm nhị phân, ngay cả trong trường hợp xấu nhất, cũng hiệu quả hơn thuậttoán tìm kiếm tuyến tính.
3) Chú ý: Một điều quan trọng cần phải biết là máy tính phải cần bao lâu để giải xong một bài toán. Thí dụ, nếu một thuật toán đòi hỏi 10 giờ, thì có thể còn đáng chi phí thời gian máy tính đòi h ỏi để giải bài toán đó. Nh ưng nếu một thuật toán đòi hỏi 10 tỉ năm để giải một bài toán, thì thực hiện thuật toán đó sẽ là một điều phi lý. Một trong những hiện tượng lý thú nhất của công nghệ hiện đại là sự tăng ghê gớm của tốc độ và lượng bộ nhớ trong máy tính. Một nhân tố quan t rọng khác làm giảm thời gian cần thiết để giải một bài toán là sự xử lý song song - đây là kỹ thuật thực hiện đồng thời các dãy phép tính. Do sự tăng tốc độ tính toán và  dung lượng  bộ nhớ của  máy  tính,  cũng như nh ờ việc
dùng các thuật toán lợi dụng được ưu thế của kỹ thuật xử lý song song, các bài toán vài năm trước đây được xem là không thể giải được, thì bây gi ờ có thể giải bình thường.
1. Các thuật ngữ thường dùng cho độ phức tạp của một thuật toán:
Độ phức tạp
O(1) Độ phức tạp hằng số
O(logn) Độ phức tạp lôgarit
O(n) Độ phức tạp tuyến tính
O(nlogn) Độ phức tạp nlogn
O(nb) Độ phức tạp đa thức
O(bn) (b>1) Độ phức tạp hàm mũ
O(n!) Độ phức tạp giai thừa
2. Thời gian máy tính được dùng bởi một thuật toán:

Thứ Năm, 26 tháng 3, 2015

Java và lập trình

Java và lập trình trong Internet.

1.Mạng Internet dưới góc độ công nghệ.
    Một mạng có thể chia ra làm hai phần cơ bản: hệ thống phân phối thông tin và các ứng dụng mạng, và mạng Internet cũng không phải là ngoại lệ. Hệ thống phân phối thông tin của nó dựa trên họ giao thức TCP/IP, và tư tưởng liên kết thông qua các socket (đầu cuối-end point). Các ứng dụng Internet dựa trên mô hình Client/Server, client hỏi và server đáp. Công nghệ lập trình trong Internet có thể chia ra 3 thời kỳ, theo sự phát triển của bản thân Internet, với các mốc là sự xuất hiện của WWW và Java.
2.Giai đoạn trước khi xuất hiện WWW.

    Lập trình trong giai đoạn này chủ yếu dựa trên socket. Hoặc bạn tạo ra một dịch vụ mới, bằng cách viết các server và client, dựa trên giao thức riêng, như đã làm với các dịch vụ FTP, SMTP.. hay viết client cho các dịch có sẵn này. Lập trình theo hướng này đòi hỏi bạn phải biết nhiều về TCP/IP và cơ chế hoạt động của socket. Nếu bạn viết client, bạn sẽ phải làm quen thêm với giao thức của dịch vụ đó, còn nếu bạn tạo ra một dịch vụ mới, bạn cần phải tạo ra giao thức riêng cho dịch vụ của mình. Ngôn ngữ lập trình tùy thuộc vào HÐH, dựa trên mô hình Socket (trong Windows bằng cách gọi hàm của Winsock.dll), và thường là C, C++, Pascal.. Hướng này đòi hỏi nhiều ở bạn, cả hiểu biết lẫn công sức. Nhưng khả năng của nó rất lớn, và bạn nên làm quen, ít ra cũng để viết client cho các dịch vụ khác, hay tạo khả năng liên lạc với các dịch vụ khác từ ứng dụng của bạn.
3.Giai đoạn trước khi xuất hiện Java.
    Sự xuất hiện của dịch vụ WWW, giao thức HTTP, chuẩn URL đã tạo ra một hướng mới trong lập trình Internet. Hướng này dựa trên dịch vụ Web và giao thức HTTP, do đó bạn không cần biết về TCP/IP và tạo ra giao thức riêng của mình nữa. Hoặc bạn tạo ra các Web server application(WSA), cung cấp thông tin qua WebServer, hay là viết Client cho WebServer, truy nhập thông tin qua Web. Các yêu cầu của client, thông qua WebServer, được gửi đến WSA, chúng xử lý thông tin, tạo ra kết quả dưới dạng văn bản HTML, và qua WebServer, gửi lại cho client. Viết các WSA tuy không phức tạp như các Internet Server, nhưng cũng rất phức tạp, và đòi hỏi bạn phải biết về HÐH, chuẩn CGI, cũng như các giao diện của chúng. Ưu điểm của WSA là thị trường của chúng, lớn đúng bằng thị trường của WWW. Nhưng dịch vụ WWW được tạo ra để phân phối văn bản, nên việc truyền dữ liệu qua nó là không thích hợp và rất chậm. Ðể thay đổi một hai dữ liệu trong văn bản, bạn đành phải gửi đi nguyên cả trang, đó là hậu quả của việc dùng dịch vụ WWW sai chức năng của nó. Ngôn ngữ phổ biến là Perl, nhưng bạn có thể dùng C, C++ hay Delphi.. miễn là ứng dụng liên lạc được với WebServer.
4.Giai đoạn sau khi xuất hiện Java.
    Sự xuất hiện của Java và các trình duyệt Web hiểu Java (chạy được Java applets) đã giải quyết được nhược điểm của WSA, hỗ trợ cho lập trình với Socket, và mở ra một hướng mới. Ưu điểm của Java applet là chúng được truyền trong mạng, và chạy trong trình duyệt Web. Vì vậy, dữ liệu có thể được truyền thông qua chúng, chứ không phải dưới dạng văn bản. Chỉ bằng cách tạo thêm Java client cho các WSA đang hoạt động, trao đổi thông tin giữa trình duyệt Web và WSA, tốc độ thực hiện của các ứng dụng này đã nhanh lên rất nhiều, và cho phép sử dụng chúng thêm một thời gian nữa.
    Các ứng dụng viết trên Java có thể chạy trên hầu hết các HÐH, giúp đỡ rất nhiều cho việc lập trình với Socket, bạn không phải viết nhiều phiên bản cho các HÐH khác nhau. Ngoài các lĩnh vực truyền thống, các ứng dụng Java còn mở ra một hướng hoàn toàn mới, đó là các ứng dụng được lưu và truyền trong mạng, đòi hỏi tài nguyên hoạt động ít. Ðiều này cho phép, thông qua mạng Internet, các hãng phần mềm bán sản phẩm, các hãng sử dụng phần mềm tiết kiệm tài chính bằng cách lưu các ứng dụng trên Server, bớt công sức và phương tiện trong việc nâng cấp phần mềm, cũng như phần cứng của Clients, các hãng sản xuất đồ dân dụng đưa ra các sản phẩm "thông minh"(có khả năng sử lý dữ liệu thông qua processor riêng và quản lý từ mạng..)
    Về mặt lập trình, Java ngoài ưu điểm có cú pháp giống C++, chỉ có thêm một ưu điểm nữa, đó là vấn đề quản lý bộ nhớ, còn lại không có gì thay đổi. Thậm chí, do các hệ thống lập trình trên Java còn yếu, bạn sẽ thấy khó khăn hơn(JBuilder, Visual Cafe chưa thể so với Delphi, VB..). Với các ứng dụng cổ điển, yêu cầu đối với bạn không có gì thay đổi, vẫn từng đó kiến thức và công sức. Còn về các ứng dụng đặc thù của Java, tuy đã xuất hiện nhiều tư tưởng mới mẻ, như ứng dụng Java cho Network Computer, các sản phẩm "thông minh".., nhưng hãy còn quá sớm để xác định, chúng sẽ đi về đâu.
5.Kết luận.
    Với sự xuất hiện của Java, trong lĩnh vực lập trình đã có nhiều thay đổi, một số được hoàn thiện hơn, một số mới ra đời. Trước mắt, xuất hiện một số xu hướng sau: Các ứng dụng WSA trên CGI sẽ phải có thêm Java Client, không được phát triển lên nữa, và chết hẳn. Các ứng dụng với Socket sẽ phổ biến hơn nhiều, Server vẫn viết trên C++, Delphi.. do tốc độ Java còn thấp và giải quyết phần lớn các chức năng , nhưng Client được viết trên Java, và nếu có thể(kích thước nhỏ, không quá phức tạp..) thì dưới dạng applet, sau khi tốc độ của Java nhanh hơn(hy vọng HotSpot của Sun nhanh được như đã hứa, ngang với C++), Server trên Java sẽ phổ biến hơn. Còn Java với tư cách là một cuộc cách mạng, thì chúng ta phải đợi xem sao đã, chưa có gì chắc chắn, mặc dù hứa hẹn thì có nhiều.
    Trên đây là những suy nghĩ của riêng tôi về thực tiễn lập trình trong giai đoạn hiện nay. Do tôi mới làm quen với Java và vào Internet được 3 tháng, nên rất có thể những ý kiến đưa ra là sai, hoặc không chính xác. Vì vậy mong mọi người chú ý, kiểm tra lại, và nếu có thể, trao đổi ý kiến với tôi!
Thiết kế trang Web có tăng cường tính năng Java
            Nếu đã có thời gian làm việc trên Web với một Browser hiểu Java, chắc bạn sẽ muốn đưa thêm công nghệ tăng cường này vào các trang Web của mình. Nhưng tiêu khiển với các trang có sẵn có tăng cường Java mới chỉ được một nửa sự thú vị. Tìm ra các applet rồi đưa vào trang Web của chính mình mới thực sự đúng điệu. Vì vậy, thì hãy thoả mình vào chiếc ghế thoải mái hơn, và chuẩn bị để nối mạng - đã đến thời điểm của Java.
            Bước đầu tiên là phải quyết định định các trang được tăng cường Java của bạn như thế nào, rồi sau đó mới sờ đến applet, công cụ sẽ làm cho các trang đó thành hiện thực. Điều chủ yếu, nếu không có các applet, cơn khát Java của bạn sẽ không thể nào thoả mãn được. Rất may là việc tìm các applet còn dễ hơn cả việc tìm cửa hàng bán café ở Seattle; applet có ở khắp mọi nơi. Thực ra applet không phải là phương tiện duy nhất để tạo sinh động cho các trang Web của bạn bằng Java. Java Script, sẽ được trình bày chi tiết hơn trong phần III, cũng là một phương tiện bổ xung sống động Java . Tuy nhiên, Java Scrip chỉ như phần khuất chìm dưới nước của con thuyền applet, cũng là cà phê nhưng không phải là loại hảo hạng như applet.
     Chọn đúng applet hoàn hảo.
      Bạn hoàn toàn sẵn sàng bước vào giai đoạn làm sống động cho Web site của mình bằng một số applet Java vui mắt, khi đã dừng việc tìm kiếm, có thể nảy sinh câu hỏi : "Các applet đến từ đâu?".
      Đây là thời điểm ngồi lại và cùng trao đổi vài câu chuyện nhỏ....
      Đừng toát mồ hôi vì nó
      Phương pháp tìm kiếm applet để sử dụng trong trang Web của bạn là một phần việc quan trọng trong toàn bộ quá trình lập kế hoạch. Khi phải quyết định các applet Java nào sẽ được đưa vào Web site của mình, bạn có thể một trong hai kỹ thuật sau đây:
      Lướt trên Web theo cảm hứng: cách dễ dàng nhất để tạo ra các ý tưởng cho Web site của bạn là nhìn xem những người khác đã làm như thế nào. Bằng cách lướt trên Web, bạn có thể tìm được các trang và các applet gây cảm hứng cho bạn. Quá trình này gọi là lướt theo cảm hứng (inspiration surfing), và có lẽ là phương pháp trực tiếp và thú vị nhất để tạo ý tưởng cho các trang Web của bạn.
      Làm việc căng thẳng: nếu bạn là người ham việc và thích tự hành hạ, bạn có thể tự hình thành các ý tưởng đó một cách tương đối độc lập, trực tiếp đáp ứng cho những yêu cầu riêng đối với site của bạn. Kỹ thuật này không mấy thú vị, đòi hỏi độ động não nhiều và bắt buộc tác giả trang Web phải tự đề ra các chi tiết của site mà không lợi dụng được hàng trăm hàng ngàn gì của những người khác đã đầu tư để xây dựng nên các Java site hiện đại.
      Điều tệ nhất của phương pháp này là sau khi đã xác định được những gì các applet đó phải thực hiện, bạn còn phải dựng nên chúng. Đúng vậy, nếu bạn đã có trình độ tiến sĩ máy tính, bạn có thể tự viết cho mình một applet từ hai bàn tay trắng. Nhưng nếu bạn là người mới vào nghề, thì tốt nhất là hãy tìm đến con đường dễ dàng và tuỳ biến những applet đã có sẵn từ trước.
      Chắc phần lớn mọi người thích làm việc theo cảm hứng hơn là căng thẳng. Còn bạn thì sao?
      Để thực sự cảm thấy được những gì các trang Web của mình có thể và sẽ phải thực hiện, bạn nên dành thời gian đáng kể truy cập trực tuyến để xem xét những gì có ở đó. Chỉ sau khi đã đầu tư nhiều thời gian cho công việc định hướng các tài liệu siêu phương tiện này, bạn mới có thể hiểu rõ và đánh giá đúng cách thiết kế trang Web phù hợp.
      Đáng tiếc là có nhiều người lao vào Web mà không thực sự hiểu rõ về nó. Phương pháp mù quáng này nhất định sẽ dẫn đến tình trạng làm việc căng thẳng, cố nặn ra các chi tiết của việc xây dựng trang Web mà không gắn với một lý do xác đáng nào, trong khi chỉ cần bỏ ra một ít thời gian để lướt Web cũng sẽ làm cho toàn bộ quá trình dễ dàng hơn nhiều. Mắc sai lầm này là một tai hoạ cho Web site của bạn; phát hành các trang có tăng cường Java trên World Wide Web mà không đầu tư thời gian và kinh nghiệm để biết rõ cách thiết kế nào là tốt hoặc xấu, hệ thốngì chẳng khác gì xuyên một chiếc cọc nhọn vào thẳng tim site của bạn.
      Để hiểu lý do tại sao như vậy, bạn phải xem xét kỹ bản chất của Web. Có hàng chục triệu người hàng ngày lướt trên Web, họ chịu mất thời gian và tiền bạc để được sưởi ấm trước màn hình máy tính. Hiện nay, đường phân phối dữ liệu qua Web rất hẹp và lưu thông thường tắc nghẽn. cáng nhiều người trên Web thì việc định hướng này càng trở nên chậm chạp hơn-giống như các cửa hàng trong ngày lễ tết.
      Một trong các lý do chính để mọi người nối vào Web là để phát hiện được những cái mới. Bạn có thể đi mọi nơi, xem mọi cái, và du lịch đến vô tận, hình như không bao giờ quay lại những bước chân cũ của mình. Tuy nhiên, mỗi khi tìm đến một trang, bạn cũng phải đợi nó tải xuống qua Net. Web không phải là một hệ thống thông tin được phân phối ngay tức khắc như vô tuyến truyền hình; nó phải tốn thời gian để cho mã nguồn, hình ảnh ,âm thanh và các applet của trang tải xuống máy tính của bạn. mà trên Web, thời gian là tiền bạc.
      Thiết kế trang Web càng quan trọng hơn khi bạn dùng Java, và các applet tốn nhiều thời gian để nạp, đặc biệt là khi chúng sư dụng hình ảnh và âm thanh (mà nhiều applet như vậy). Vì Java rất được ngưỡng mộ, nên nhiều người dùng Web sẵn sàng treo máy chờ để tìm cho được trang có tăng cường Java. Nhưng sẽ như thế nào, nếu Web site mà họ phải chờ cho đến lượt lại là đồ dỏm, và toàn bộ thời gian cũng như tiền bạc bỏ ra là vô ích? Bạn có thể tin chắc họ sẽ chuyển ngay đến trang Web khác. Và càng phải đợi lâu thì họ càng có ấn tượng thù ghét hơn đối với site xúc phạm đó.
      Mặt khác, site nào thực sự có ích hoặc hấp dẫn thì càng nhiều khách thăm - kể cả được đánh dấu lại để truy cập nhanh sau này,nghĩa là site đó được khách tái thăm nhiều lần. Chỉ có một cách duy nhất để bạn biết rõ kiểu thiết kế nào tốt hay xấu là phải dùng qua nhiều lần đối với cả hai loại. Phương pháp duy nhất để thực hiện điều đó là phải lướt trên Web.
      Nếu bạn không lướt trên Web hoặc không phân biệt được site nào xấu tốt, thì hiện tại sẽ không có một cơ hội nào để lao vào cuộc. Sự chuẩn bị đó không chỉ nên làm, mà tuyệt đối phải làm. Hãy nghĩ điều này như là một nhiệm vụ được giao, thực chất không khác gì một chuyến du lịch vòng quanh thế giới với yêu cầu phải chụp ảnh và ghi chép ở mọi điểm dừng chân. Đó thực sự là tất cả những gì bạn phải làm. Hãy lướt ngay trên Web và đánh dấu lại các site mà bạn thích. Hãy đọc phần "Tìm kiếm các applet tốt nhất trong thế giới điều khiển" (trong chương này để biết cách lướt qua các Web site, cách đánh dấu để truy cập nhanh sau này, cách tìm các applet trong đó, và cách lưu lại mã nguồn của những trang mà chũng biểu hiện để tham khảo về sau.
      Qua những trình bày trên, không có nghĩa là bạn phải trì hoãn việc đưa các applet vào trang Web của mình cho đến khi đã tìm tòi rộng khắp trên Web và chắt lọc ra được những tinh tuý của nó. Tốt nhất hãy tập luyện kỹ năng nhúng applet song song với việc hình thành các sở thích riêng trong thiết kế trang. Vì bạn tạo ra các trang Web trên chính chiếc náy của bạn, cho nên chỉ có bạn là người duyệt xem chúng trước khi tải lên máy Web Sever. Như vậy, Web site của bạn là một "bán thành phẩm" được hoàn chỉnh ngay trên ổ cứng của mình. Bạn,và chỉ một mình bạn mà thôi, sẽ quyết định khi nào thì một trang là hoàn hảo để đưa ra, cho nên bạn có thể gọt dũa bao lâu tuỳ ý.
     Được phép chọn dùng hay không
      Khi đi ngang qua một applet trên Web mà bạn muốn nhặt lấy để đưa vào trang của mình thì bước kế tiếp là phải thực hiện một động tác thẩm tra nhỏ để biết bạn có được phép sử dụng applet đó hay không. Có một số applet tuyệt hảo, nhưng không phải là loại được quyền chọn dùng.
      Bạn có thể biết chắc một applet hoàn toàn nằm ngoài phạm vi công cộng nếu nó không cung cấp một thông tin nào giải thích cách sử dụng applet đó trong các trang riêng của bạn. Dĩ nhiên đây là một ý tưởng tốt để xem xét toàn bộ site trước khi phải từ bỏ. Nhưng nếu các chi tiết này không được cung cấp, bạn không có cách chọn lựa nào khác là vẫn phải tiếp tục.
      Applet là những chương trình nhỏ, nếu dùng chúng mà không được phép thì cũng phạm luật giống như đi vào cửa hàng và chôm một hộp phần mềm bày trên giá.
      Rất may là các phương tiện chuyển tải applet trên Web đều cho phép tự do lấy, và hàng ngày được bổ sung thêm một lượng lớn. Hầu hết các applet này đều mô tả một cách chi tiết và chính xác cách thức để bạn có thể đưa chúng vào trong các trang riêng của mình. Cho nên, trừ trường hợp bạn muốn tìm mua một số applet lạ, còn thì bạn có nhiều cơ hội để tìm được đúng những gì mà bạn cần, đơn giản chỉ bằng cách lướt trên Web.
     Đặt hàng một applet soạn theo yêu cầu
      Nếu đã tìm khắp trên Web mà vẫn không thấy một applet có sẵn theo ý muốn, bạn luôn luôn có thể đặt hàng một applet được xây dựng theo các yêu cầu của bạn. Nhưng nên nhớ, các applet biên soạn theo yêu cầu giá không rẻ, tuỳ theo công việc có liên quan, bạn có thể trả giá từ 50 USD đến 100 USD cho những loại công việc cơ bản nhất.
      Một số lượng đông đảo các chuyên gia Java tự phong gần đây đã có mặt trên Web, và hứa hẹn sẽ tạo ra những applet xuất sắc với giá phải chăng. Nếu bạn quyết định phải có một applet Java đặt hàng cho mình, bạn hãy tiến hành một cách an toàn theo những lời khuyên sau đây:
      -Chỉ chọn hãng nào có kinh nghiệm: Tìm những công ty được khách hàng giới thiệu và có các ví dụ mẫu về công trình của họ được trình bày nổi bật trên site (hoặc những hãng sẵn lòng cung cấp ngay những mẫu đó khi có yêu cầu).
      -Đừng chấp nhận những lời giới thiệu suông. Phải tiếp xúc với từng khách hàng và đặt các câu hỏi có định hướng, như "Công việc gì đã được thực hiện?", "Làm việc đó mất bao lâu?" "Giá bao nhiêu?" và "Có thể giới thiệu công ty này cho công việc của tôi không?"
      _Đi nhiều cửa hàng. Những gì mà công ty này làm với giá 500 USD, thì công ty khác có thể chỉ làm với 100 USD hay ít hơn. Nhưng nên nhớ, giá cả không phải là tất cả, mà uy tín của nhà phát triển mới là phần quan trọng nhất.
      Web có một diễn dàn, trong đó tất cả những người dùng có một máy tính với một modem đều có thể tự xưng là chuyên gia biên soạn Java. Đừng tin vào những điều đó.
     Tìm kiếm các applet tốt nhất trong thế giới điều khiển
      Một trong những điều thách thức nhát khi đưa Java vào các trang Web của bạn là phạm vi các khả năng chọn lựa rộng đến chóng mặt mà bạn có trong tay khi đã kết thúc việc tìm kiếm applet (hoặc các applet) sẽ được đưa vào các trang của bạn. Nếu bạn đã từng bị xoay chong chóng trên Web với một brower hiểu Java, thì bạn sẽ biết chính xác điều này. Mỗi lần tìm lại thấy xuất hiện các applet mới mẻ đầy cám dỗ, sẵn sàng để được sử dụng trog những trang riêng của bạn.
      Bạn có thể cài một số lượng applet bất kỳ vào trong một trang Web. Nhưng đừng quá tham. Mỗi applet sẽ phải mất một thời gian để tải từ Internet xuống. Kất quả là bất kỳ ai đến thăm trang Web có nhiều applet đều phải đợi rất lâu để các applet đó đủ thời giờ di chuyển trên mạng - điều này có thể làm cho mọi người lảng tránh site của bạn. Với các applet, cũng như với các trang Web nói chung, bạn nên cân nhắc kỹ về thiết kế tổng thể của trang trước khi thực sự xây dựng nó.
      Căng buồm lên đi vào cuộc tìm kiếm các applet hảo hạng
      Nếu bạn không biết chắc sẽ bắt đầu cuộc tìm kiếm applet của mình từ đâu, thì cũng đừng lo. Bạn có thể bắt đầu duyệt từ bất kỳ trang nào, cứ để cho chuột của bạn dẫn đi theo nhiều hướng. Bạn có thể tiến từ trang này đến trang khác, từ site này đến site khác hoặc cách quãng. Tuy nhiên, nên từ từ trong giai đoạn bắt đầu này, vì bạn sẽ phải hình thành dần một "khẩu vị" riêng trong việc thiết kế trang Web.
      Hãy tìm hiểu về những phong cách lướt Web khác nhau, và cố gắng thử tất cả. Nên nhớ, bạn cần phải luyện tập các kỹ năng thiết kế trang Web của mình, và điều này đòi hỏi bạn phải xem kỹ các trang nhưng khác với cách xem của những khách du lịch. Đồng thời, vì có nhiều cách lướt Web khác nhau, nên yêu cầu bạn phải kiểm tra trang bằng tất cả các cách đó.
      Khi lướt Web, bạn sẽ hình thành dần sở thích riêng đối với việc thiết kế trang Web. Bạn sẽ biết rõ cái gì mình thích và không thích, đồng thời những thông tin này sẽ được phản ánh vào các quyết định thiết kế của bạn sau này. Những gì làm cho một site có tăng cường Java mạnh lên hoặc yếu đi đều do sở thích rieng của từng người quyết định, song một Web site hoản hảo phải có các chất lượng sau đây:
     Mới mẻ. Các applet trên site này không giống như các applet cũ mà mọi người đều dùng. Nếu một applet đã xuất hiện treen một nửa số site hiện hành, thì khi dùng nó liêu site của bạn có gây được sự chú ý không? Có lẽ là không. Song nếu bạn không thể tìm được cho mình những applet thuộc loai duy nhất, thì hãy cân nhắc để sắp xếp những applet cũ đó nằm rải rác không dồn vào một chỗ.
     Hấp dẫn. Bản thân site đó không bị nhồi nhét quá nhiều applet, hình ảnh, v.v... Gặp một màn hình xấu xí, những người sử dụng sẽ quay mặt đi ngay trước khi bạn có thể biểu diễn những trò ảo thuật.
     Trang trọng. Không có gì có thể đánh bại một trang Web làm cho những người xem phải thốt lên "Chà!" một cách ngưỡng mộ.
     Hữu ích. Cùng với sự hấp dẫn và trang trọng, trang của bạn còn phải là cái mà nhiều người có thể sử dụng được. Mọi người lướt trên Web đều thích tìm ra những cái hữu ích cho mình, Nếu site của bạn có ích, mọi người sẽ đến.
     Tương tác. cuối cùng, site của bạn phải có khả năng tương tác với người dùng. Nếu họ có thể làm một số cài gì đó với các applet trong site của bạn khi chơi, học, hay làm việc, nó sẽ trở thành vừa có ích vừa thích thú. Trên hết, người dùng sẽ thích những trang vừa có ích vừa vui, hơn là chỉ có ích mà thôi.
      Có một số Web site được dành riêng để trưng bày các site và các trang tôi nhất đã đưa ra, và có nhiều Web site chuyên dùng cho việc biểu dương các site và các trang tốt nhất. Để tìm các site tốt nhất và tồi nhất trên Web, chỉ cần sử dụng cơ cấu tìm kiếm và nhập các từ khoá WORST WEB và BEST WEB vào trong câu hỏi của bạn.
     Thả neo bằng các thẻ đánh dấu
      Khi phải đánh dầu một chỗ nào đó trong cuốn sách in, bạn phải xé một mảnh giấy và đặt vào giữa hai trang. Bạn cũng có thể ghi một số điều gì đó lên mảnh giấy này để nhớ lý do tại sao lại đặt nó vào đây. Khi sử dụng Web bạn cũng làm những việc tương tự. Nhưng đừng có bận tâm về việc tìm mảnh giấy và bút chì. Nên nhớ, đây là thời đại điện tử, nên bản sẽ sử dụng một thẻ đánh dấu ảo.
      Khi gặp một trang Web có tăng cường Java hấp dẫn, bản hay đánh dấu nó! Các brower của Web đều cho phép bạn đánh dấy hay liên kết nóng (hotlink) các trang Web để có thể truy cập nhanh sau này. Trong Netscape Navigator, tính năng này gọi là bookmarking; còn trong Microsoft Internet explorer là Favirites. Khi đánh dấu một trang, bạn sẽ có thể quay lại nó một cách nhanh chóng để trí nhớ được nhắc lại sau khi đã bị mụ mẫm đi vì phải xem đến hành trăm trang có Java khác.
      Khi tìm kiếm sự cảm hứng Java trong Web, bạn phải ghi thêm chú thích vào các thẻ đánh dấu mà bạn thực hiện. May mắn là hầu hết các browser đều cho phép bạn nhập các ghi chú này vùng lyvs với việc thực hiện đánh dấu. Trên Netscape Navigator chẳng hạn, bạn chọn Boomarks - Go to Bookmarks thì một cửa sổ riêng sẽ xuất hiện, trong đó có chứa tất cả các thẻ đánh dấu mà bạn đã tạo nên từ trước. Ngay khi có một site làm cho bạn quan tâm (hoặc rất tốt hoặc rất xấu), bạn hãy đánh dấu nó như bình thường và chọn Item Properties trong cửa sổ thẻ đánh dấu (hoặc nếu bạn sử dụng hệ thống Windows, bạn có thể nhấn chuột lên thẻ đánh dấu này bằng phím phải). Cửa sổ Properties (các thuộc tính) đặc biệt sẽ mở ra, trình bày những chi tiết về thẻ đánh dấu (như tên gọi và URL của nó chẳng hanh) đồng thời cũng cung cấp cho bạn một khoảng trống để ghi thêm các chú thích. Tại đây bạn có thể đưa vào các ấn tượng đầu tiên của mình về site đó.
      Phải bảo đảm ghi lại các ấn tượng đầu tiên về trang vào đứng thời điểm mà bạn thực sự đánh dấu nó. Các ấn tượng đầu tiên của người dùng đối với một site rất quan trọng vì chúng có thể làm cho site thành công hay thất bại. Bạn cần thể hiện cảm giác về những gì hấp dẫn và chán ghét đối với người dùng Web, và chỉ có một cách là tiếp xúc trực tiếp với các trang Web.
      Cùng với việc ghi các ấn tượng đầu tiên của bạn về một site, hãy xem xét để xếp hạng nó và ghi điểm kèm theo các thú thích. Bạn có thể chọn bất kỳ hệ thống xếp hạng nào tuỳ ý, cho đến khi tìm được một cách phân biệt giữa các site tốt và site xấu. Ví dụ, bạn có thể chọn hệ thống xếp hạng 1-10, trong đó số nhỏ đại diện cho các site xấu, còn số lớn đại diện cho site tốt, và 10 dành cho site tốt nhất trong các site tốt.
     Đào tìm kho báu trong mã nguồn
      Chỉ thiết lập các thẻ đánh dầu thôi thì chưa đủ. Bạn còn phải liếc ra sau các màn che để xem mã HTML được dùng để tạo ra các trang WEb.
      Nhờ xem kỹ mã nguồn HTML tạo nên các trang gây cảm hứng cho bạn, bạn sẽ biết rõ công thức pha chế của các trang Web hợp "khẩu vị" đó. Tất cả các trình duyệt đều có chức năng cài sẵn cho pohép dễ dàng xem mã nguồn phía sau trang Web. Đối với Netscape Navigator, bạn chỉ cần chọn View - Document Souce. Các browser khác cũng có các chức năng menu tương tự, mặc dù tên của chức năng và menu có thể không giống nhau. (Trong Microsoft's Internet explorer, bạn chọn View-Source)
      Khi xem mã nguồn của trang Web, bạn có thể tìm thấy mọi thứ mà bạn cần để biết trang Web đã được tạo ra bằng cách nào. Và, quan trọng hơn cả là bạn xem được công thức pha chế mà người ta dùng để tạo nên trang Web từ đầu! cụ thể, bạn muốn xem trang này đang sử dụng các applet nào, nếu có.
      Nhắc lại, đâu là một thủ tục đơn giản. Bạn chỉ cần gọi tính năng Find của browser và tìm từ applet. Cách hoạt động của qui trình này đối với Netscape Navigator như sau:
      1. Nhấn Ctrl+F (hoặc +F nếu bạn dùng máy Mac)
      Khác với Microsoft Explorer, Netscape không cho bạn chức năng menu đối với tính năng Find khi xem mã nguồn của trang.
      2. Khi hộp thoại Find xuất hiên, bạn gõ từ applet và nhấn vào nút Search!
      Nếu trang đang xem có dùng applet Java, bạn sẽ tìm thấy thr trong mã nguồn HTML của nó. Tại thời điểm này, bạn được tự do sao chép và dán toàn bộ thẻ vào tài liệu văn bản để tham khảo sau này. Hoặc tốt hơn, bạn có thể cất giữ toàn bộ tập tin mã nguồn vào máy tính cá nhân của mình. Sau đó, bạn cũng muốn biết có còn những applet nào khác chứa trong trang hay không, và do đó bạn vẫn tiếp tục tìm.
      3. Tiếp tục tìm kiếm cho đến khi tìm thấy tên và các thông số cài đặt cảu tất cả các applet trong trang.
      Nên nhớ, từ applet có thể xuất hiện trong thẻ dưới dạng chức thường hoặc chức hoa, mặc dù nên dùng chữ hoa cho dễ đọc. Rất may, theo ngầm định tính năng Find trong hầy hết các browser đều không lưu ý kiểu chức (nếu browser của bạn không như vậy, hay tìm một tuỳ chọn trong cửa sổ Find cho phép khẳng định kiểu chữ sẽ được bỏ qua). Kết quả bạn sẽ tìm được tất xả các thẻ trong tài liệu, bất kể bằng từ applet hoặc APPLET.
      Dĩ nhiên việc xem mã nguồn tài liệu theo cách trực tuyến này không mấy thuận lợi cho bạn vì phải tốn lệ phí trực tuyến. Bạn sẽ phải nối với Web và xem lại mã nguồn mỗi khi cần nhớ lại các chi tiết của cách thức được dùng để tạo nên trang đó. Tuy nhiên, bạn không cần phải có trí nhớ của Einstein để nhớ lại những đặc trưng của dạng thẻ; máy tính của bản đã thực hiện việc này. Đó là local storage (bộ nhớ tại chỗ), thực chất là lưu tập tin trên ổ cứng của bạn.
     Chiếm lĩnh và mang về nhà
      Sau khi đã tìm thấy trang gây được cảm hứng, tại sao không tải luôn cả mã nguồm HTML của nó xuống máy tính bạn, tại đây bạn có thể xem nó bất kể thời gian nào mà không mất xu nào cho lệ phí trực tuyến? Không có lý do nào bắt buộc bạn phải nối với Web để xem mã nguồn khi đã có chính trang đó trên máy của riêng bạn.
      Cất giữ mã nguồn của một trang Web rất dễ dàng. Tất cả công việc phải làm chỉ là nhấn chuột vào tuỳ chọn Save của browser (trong Netscape Navigator, bạn chọn File-Save từ menu của browser). Cần nhớ, với Netscape Navigator, bạn phải chọn Save trong khi đang duyệt chính trang Web đó, chứ không phải mã nguồn, vì không có chức năng menu nào cho bạn dùng khi đang xem mã nguồn.
            Khi lưu một trang Web, phải bảo đảm đã gán cho trang đó một tên, tiếp theo là đuôi mở rộng. HTML (hoặc .HTM). Lưu tài liệu theo cách này bạn sẽ dễ dàng nhận biết nó có chứa mã nguồn của trang Web. Đồng thời, bạn cũng phải bảo đảm lưu trang Web ở dạng HTML nếu được; nếu không, bạn sẽ lưu tài liệu đó như một văn bản đơn giản chứ không phải là mã nguồn! Mặc dù Netscape Navigator tự động gán dạng HTML mặc định khi lưu các trang Web vào đĩa, nhưng các browser khác có thể không như vậy. Nếu bạn không biết chắc dạng nào browser dùng để lưu trang, thì chỉ việc mở tài liệu đó ra xem bằng một trình xử lý văn bản (hoặc bất kỳ chương trình nào có khả năng xem bằng mộ trình xử lý văn bản đơn giản). Nếu dạng thức đó là HTML, bạn sẽ nhìn thấy mã nguồn này ngay tức khắc. Còn nếu không phải, hay quay về lại browser rồi lại tiến hành lưu trang đó một lần nữa - lần này dùng dạng HTML.
     Cũng như mọi tài liệu khác, khi lưu trang Web, bạn phải chọn một vị trí trên ổ cứng cho nó. Nên tạo ra một thư mục mới cho từng site và lưu các trang lấy ra từ site đó trong thư mục này. Dĩ nhiên, bạn có thể lưu mã nguồn ở bất cứ đâu tuỳ thích trong máy của mình. Chỉ cần đảm bảo đã ghi lại mơi cất nó để có thể tìm laị sau này.
     Sau khi đã tải mã nguồn của trang Web xuống máy tính cá nhân của mình, bạn có thể xem nó với browser của bạn bằng cách vào chức năng thích hợp trong menu File. Với Netscape Navigator, bạn dùng tuỳ chọn Open để có thể xem hoặc mở các trang Web đã lưu trong máy tính của bạn.
     Khi đã mở một trang Web nằm trong máy tính của mình, bạn có thể gắn thẻ đánh dấu vào nó giống như trang Web tồn tại trực tuyến, để có thể truy cập nhanh mỗi khi cần xem lại sau này. Và cũng giống như các trang Web trong không gian điều khiển, bạn có thể dùng browser để xem mã nguồn của các trang đang lưu trong máy tính - nhưng với các trang địa phương này, bạn không cần vội vã vì không phải trả lệ phí trực tuyến theo thời gian.
    Tải xuống thêm ngoài mã nguồn
     Lần đầu tiên tải xuống một trang để truy cập tại chỗ, có thể bạn rất ngạc nhiên khi nhận thấy không có hình ảnh, âm thanh, hoặc các applet đi kèm trong đó. Thực tế này có thể làm thay đổi hoàn toàn dáng vẻ của trang so với khi xem trên Web. Xảy ra điều này vì bạn chỉ tải nguồn, không có gì hơn nữa. Nhưng can gì, vì mã nguồn của các trang Web là quan trọng nhất - Đó là công tức cơ bản để xây dựng nên các trang riêng của bạn.
     Nhưng các trang Web có tăng cường Java đã được tạo ra không chỉ bằng mã nguồn HTML và các hình ảnh như hầu hết các trang thông thường. Lưu toàn bộ trang (mã nguồn, đồ hoạ, âm thanh và các applet) vào ổ cứng của bạn ngay cùng một lúc không mấy dễ dàng. Rất may là lưu các hình ảnh của trang Web lại khá đơn giản. Tuy nhiên, lưu các phân tử khác chứa trong trang, như âm thanh và các applet không dễ dàng lắm.
     Mặc dù việc lưu giữ tất cả các phần tử chứa trong trang là hoàn toàn có khả năng về mặt kỹ thuật, nhưng đó là một quá trình tẻ nhạt hơn so với việc lưu hình ảnh. Thực ra, cách thực hiện việc này là một điều bí mật không thể chia sẻ. Bạn thấy đấy, lấy các phần tử này ra để cho vào máy tính địa phương của bạn có thể là một việc vi phạm pháp luật! Pháp luật trong lĩnh vực này chỉ là một cái bóng mờ nhạt, vì Web thực thể công cộng được sử dụng để xuất bản các tài liệu cho một cộng đồng rộng lớn. tuy nhiên, các phần tử chính tạo nên những tài liệu đó có thể không được dự kiến cho việc truy nhập riêng tư.
    Lưu hình ảnh
     Có lúc bạn muốn thêm nhnữg cái khác, ngoài mã nguồn của trang Web, vào máy tính của mình; nhất là khi bạn lướt ngang qua một trang có chứa hình ảnh được dự định dùng kèm với applet Java, hiện tượng rất thường gặp khi bạn sục sạo Web trong quá trình tìm kiếm cảm hứng cho các trang riêng của bạn.
     Rất may, hình ảnh thường được tạo sẵn thông qua các trang Web đều miễn phí và không bị hạn chế, nghĩa là bạn có thể sử dụng chúng trong các trang của mình mà không sợ phạm luật. Điều này thực sự có ích và tiết kiệm thời gian, vì các hình ảnh tinh vi và sinh động rất khó tạo ra bằng hai bàn tay trắng. Thay vì phải tự tạo, bạn có thể lấy các hình ảnh trang nhã trực tiếp từ trang Web để dùng với các applet Java của mình. Dĩ nhiên với điều kiện là trang trang mà bạn lấy hình ảnh có công bố rõ ràng rằng những hình ảnh đó được tự do lấy ra, không hạn chế.
     Với Netscape Navigator hoặc mọi browser hiểu Java có sẵn khác, việc lưu hình ảnh là một khả năng chắc chắn. Tất cả công việc phải làm chỉ là nhấn chuột lên hình theo một cách đặc biệt. Bằng cách nhấn chuột lên hình, bạn sẽ được đưa đến mối liên kết với nó, nếu như hình ảnh đó thực sự là một siêu liên kết. Thực hiện một số động tác, bạn có thể lưu hình ảnh vào đĩa.
     -Nếu bạn dùng máy Macintosh thì thủ thuật đặc biệt ở chỗ không thả nút chuột sau khi đã nhấn. Công việc phải làm chỉ là nhấn và giữ phím chuột trong khi con trở đặt trên hình, một menu xuất hiện, trong đó có tuỳ chọn để cất hình ảnh vào đĩa.
     -Đối với người sử dụng Windows, quá trình có khác chút tí. Vì chuột Windows có hai nút nên có thể báo cho browser Web khác, chứ không chỉ đối với Netscape Navigator. Chỉ cần nhấn chuột lên từng hình trong trang bằng kỹ thuật chuột phù hợp đối với hệ máy của bạn, rồi chọn Save Image trong menu vừa xuất hiện. Mối đe doạ duy nhất cho kế hoạch này là các liên kết bị đứt.
    Giải quyết các liên kết bị đứt
     Vì trang Web có thể chứa các hình ảnh nằm trong nhiều thư mục khác nhau, hoặc thậm chí trên nhiều server khác nhau, nên có thể bạn phải cấp nhật mã nguồn cho trang đó sau khi đã lưu nó vào máy tính của mình. Ví dụ, bạn đã lưu một trang cùng với tất cả hình ảnh của nó vào trong một thư mục trên máy của bạn. Trừ trường hợp trên Web các hình đều nằm trong cùng thư mục với chính trang đó, còn không thì những liên kết với các hình này sẽ bị đứt. Kết quả là bạn sẽ không nhìn thấy khi mở trang ra trên máy tính bằng browser của bạn, vì bây giờ chúng nằm trong cùng thư mục với trang đó, chứ không phải ở vị trí mà trang Web xác định.
     Cách giải quyết là cập nhật mã nguồn, hoặc tạo ra một cấu trúc thư mục trên máy tính của bạn tương đương với cấu trúc thư mục của Web site mà bạn đã lấy nguồn ra. Bạn nên cập nhật mã nguồn, vì lúc nào cũng thực hiện được biện pháp này, ngay cả khi hình ảnh được tham chiến bằng một URL tuyệt đối. Hơn nữa, bạn có thể làm việc với các URL tương đối chỉ đơn giản bằng cách tạo ra đường dẫn thư mục tương được trên máy tính của bạn. Còn với các URL tuyệt đối thì quá tầm giải quyết của bạn, trừ phi tất cả các URL tuyệt đối này đều đi ngang qua cùng thư mục với bản thân trang, mà điều này rất ít gặp. Trong trường hợp đó bạn không còn cách lựa chọn nào khác là thay mã nguồn của trang để nó cũng dùngmột URL tương đối, vì bạn không thể bắt chước toàn bộ các Web server trên máy tính của mình bằng các cấy trúc thư mục đơn giản. Muốn thay đổi mã nguồn, hãy nạp HTML voà bộ soạn thảo văn bản, như Notepad của Windows (hoặc trình ứng dụng Macintosh Simple Test) rồi cập nhật các tham chiếu HTML.
    Cuộc chiến chống tắc nghẽn dải thông
     Rất dễ say mê trong việc tạo ra các trang Web được tăng cường Java chứa đầy ắp âm thành và hoạt hình phức tạp. Làm phong phú cho site của bạn bằng một việc đầy lôi cuốn! Và mặc dù mọi viêc có vẻ như là rất tốt đẹp khi xây dựng các trang như vậy trên máy tính của mình, nhưng bạn sẽ nhận ra sự vướng mắc khi đưa chúng vào cuộc sống trên Web.
     Như bạn thấy, khi xây dựng các trang tại chỗ bằng mã nguồn HTML, các hình, các applet và các tập tin hỗ trợ (thường là hình ảnh và âm thanh đi kèm applet) đều nằm trên ổ cứng của bạn nên mọi chuyện rất trôi chảy. Tất cả các phần tử của trang đều có sẵn trên máy tính, nên không mất thời gian để chờ chúng chạy trên đường dây, và mọi thức nạp vào browser của bạn hầu như tức khắc. Nhưng khi tải trang đó cùng với tất cả các bộ phận của nó lên Web thì bạn lại phải đối mặt với một trở ngại hoàn toàn khác gọi là dải thông (bandwidth).
     Bất kỳ ai đến thăm các trang nằm trên World Wide Web đều chịu ơn huệ của dải thông - nó quyết định tốc độ mà mọi thứ chuyển từ đường dây xuống máy tính của người dùng. Nói rõ hơn, dải thông bị hạn chế là một trong các vấn đề khó khăn nhất trên Web hiện nay. Thay vì lướt qua các trang của bạn, như bạn vẫn làm khi trang còn nằm toàn bộ trên máy tính cá nhân của mình, các khách đến thăm site của bạn sẽ cảm thấy như đang bơi trong cát lún vì phải đợi mọi thức được tải xuống, trước khi hưởng được niềm vui.
     Vì dải thông là một thông số quan trọng đối với đại đa số người dùng Web, nên bạn phải xem xét đến mẫu số chung nhỏ nhất này. Mặc dù bạn có thể cố gắng tự thuyết phục rằng modem 28,8 Kbps là chuẩn mực, và giấc mơ về modem cáp và ISDN tốc độ cao sẽ thành sự thực trong tương lại không xa, thì nhiều người vẫn đang kết nối vào Internet ở tốc độ 14,4 Kbps hoặc thấp hơn. Để tỏ ra lịch sự và tươm tất đối với những khách thăm Web site của mình, bạn hãy đưa ra cho mọi người các trang được tăng cường Java của mình mà không định ra hình phạt đối với những ai truy cập chậm; bạn phải lưu ý khi lập kế hoạch cho các trang Web: cân nhắc kỹ lưỡng vấn đề dải thông.
     Mặc dù các applet rất nhỏ và truyền trên đường dây không mất thời gian, nhưng các tập tin đồ hoạ và âm thanh mà chúng thường sử dụng thì lại tốn thời gian kinh khủng. Bạn có thể thực hiện một số việc để giảm bớt thời gian truyền tải và đề phòng tắc nghẽn khi tải các tập tin này qua mạng.
    Đánh giá các tập tin âm thanh
     Khi làm việc với các tập tin âm thanh, Java chỉ hỗ trợ dạng âm thanh của Sun. Các tập tin dùng dạng này có đuôi mở rộng .au. Nếu bạn có tập tin âm thanh không dùng uLaw, như tập tin .wav của Windows chẳng hạn, bạn phải chuyển nó thành dạng uLaw nếu bạn định dùng nó với một applet.
     Mặc dù dạng uLaw tạo ra những tập tin nhỏ hơn về kích thước so vơí các dạng khác, nhưng chất lượng âm thanh không tốt lắm. Có thể bạn phải tự tìm các chức năng biên tập âm thanh có trong công cụ chuyển đổi nào đó để khử bỏ tiếng nhiễu mà bạn nghe thấy khi chuyển các âm thanh chất lượng cao sang dạng này.
     Mặc dù tiện ích chuyển đổi GoldWare (cung cấp cho người dùng Windows) có chứa một số chức năng biên tập âm thanh (như các hiệu ứng Smooth và Fade), nhưng chương trình uLaw (cung cấp cho người dùng Macintosh) chỉ có khả năng chuyển đổi các tập tin mà thôi; không thể biên tập chúng. Nếu bạn là người dùng Macintosh và nhận thấy âm thanh vừa chuyển đổi bị nhiễu quá mức, thì bạn phải cân nhắc để đầu tư thêm trình công cụ chất lượng tốt, vừa có khả năng biên tập âm thanh vừa lưu chúng theo dạng .au được Java hỗ trợ. Nhưng trước khi ra phố và tiêu di những đồng tiền đã dành dụm, bạn phải kiểm tra trước kho hàng phần mềm dùng chung của Macintosh đang rất dồi dào trên Web.
    Cắt bỏ khoảng lặng
     Nhằn giảm bớt kích thước của các tập tin âm thanh càng nhiều càng tốt khi chuyển đổi chúng để dùng với Java, bạn chỉ cần giữ lại các phần cơ bản của nó. Hãy cắt bỏ mọi khoảng lặng nằm phía trước hoặc sau. Làm như vậy, bạn sẽ thu nhỏ được kích thước của tập tin mà không ảnh hướng xấu đến âm thanh.
     Vì việc cắt bỏ tất cả các khoảng lặng trước và sau của âm thanh làm cho khi phát lại âm thanh đó sẽ bắt đầu và kết thúc một cách bất ngờ hoặc vội vã, nên bạn phải giữ lại một vài khoảng lặng ở mỗi đầu để âm thanh tự nhiên hơn. Rất may là bạn có thể đạt được hiểu quả như vậy bằng cách đặt fade-in vào đầu âm thanh (âm thanh lớn dần) và fade-out ở phần kết thúc (âm thanh nhỏ dần). Các hiệu ứng này tạo ra sự chuyển tiếp đièu hoà cho âm thanh. kết quả không những làm hco âm than hấp dẫn và mang tính chuyên nghiệp hơn, mà còn cho phép bạn tiết kiệm được những giây quý giá trong thời gian tải xuống.
     Một vài giây có vẻ không nhiều, nhưng mỗi giây đó đều đáng giá khi tính vào dải thông. Điều này càng có ý nghĩa khi bạn sử dụng nhiều âm thanh trong một trong Web. Nhiều giây cộng lại thành nhiều phút... và khi truy cập trực tuyến sẽ thành nhiều đô la chi phí.
    Tạo ra các vùng lặp âm thanh
     Ấm thanh là một phương pháp hiệu quả thu hút sự chú ý và bổ sung thêm tác động cho trang Web, đồng thời vì các applet Java làm cho việc sử dụng âm thanh trở nên dễ dàng, nên nhiều người có xu hướng lạm dụng âm thanh trên các trang Web của họ. Như vậy sẽ tạo nên tắc nghẽn dải thông và làm cho khách thăm trang Web của bạn xa lánh.
     Thay vì dùng nhiều đoạn âm thanh kèm theo các applet Java của mình, bạn nên cân nhắc xem biện pháp looping (quay vòng) âm thanh có thể thay thế được hay không. Khi quay vòng một tập tin âm thanh, nó sẽ tự lặp lại liên tục cho đến khi bạn báo dừng. Hiệu ứng này rất tác dụng, đặc biệt khi âm thanh quay vòng là âm thanh tinh tế. Quay vòng có thể là một biện pháp thay thế tốt cho cách "bỏ bom" khách thăm của bạn bằng hết âm thanh này đến âm thanh khác, và cũng giải phóng bớt dải thông trong quá trình này.
     Nhờ tính linh hoạt của Java hỗ trợ âm thanh, bạn sẽ rất vui sướng nhận thấy rằng mình có thể sử dụng một số lượng lớn âm thanh cùng lúc, bạn không phải dừng vòng lặp để nghe âm thanh khác. Trừ trường hợp bạn quy định ngược lại (giả thiết applet bạn dùng cho phép), còn thì tất cả mọi âm thanh mà bạn chơi cùng một lúc sẽ được phối hợp với nhau, tạo nên âm thanh rất phong phú.
    Tạo ra hầu hết các hình ảnh và mầu sắc
     Java cho phép sử dụng các hình ảnh GIF (Graphics Interchange Format) cũng như JPEG (Joint Photographic Experts Group), nghĩa là bạn có thể chọn lựa khi dùng hình ảnh cho các applet của mình.
     Dạng JPEG cho phép bạn dùng hình màu 24 bit (chất lượng gần bằng ảnh chụp) cho applet của mình. Thế nhưng với GIF bạn bị giới hạn trong phạm vi hẹp hơn rất nhiều khi chọn màu - chính xác là không quá 256 màu.
     Mặc dù việc sử dụng hình JPEG đủ màu cho các applet là rất hấp dẫn, vì dạng này hỗ trợ một phổ màu rộng hơn nhiều so với GIF, nhưng không nên quá tham. Bạn hãy cố giảm bớt số lượng màu trong các hình của mình xuống còn 256 hoặc ít hơn nữa; như vậy bạn sẽ giảm được lượng thời gian bị mất cho tập tin của bạn di chuyển trên đường dây. Dĩ nhiên làm cho các hình giảm xuống dưới 256 màu phải có mẹo. Khi thực hiện biện pháp tối thiểu hoá này, bạn còn phải quyết định dùng dạng tập tin nào để lưu chúng GIF hay JPEG?
    Thu gon bảng màu của hình
     Bất kể dùng dạng nào, các hình đều chiếm một phần dải thông. Để giảm thời gian cần thiết cho một hình truyền qua đường dây, bạn phải cắt bớt lượng dữ liệu dùng để biểu diễn hình đó. Rất may, hầu hết các chương trình đồ hoạ phổ biến trên thị trường (Adobe Photoshop, CorelDraw!, Fractal Design Painter...) cũng như nhiều chương trình đồ hoạ thuộc phần mềm dùng chung khác, đều cho phép bạn giảm nhỏ kích thước tập tin một cách đáng kể bằng cách giảm bớt số lượng màu khác, hay palette (bảng màu) dùng để biểu thị một hình.
     Chính bạn cũng có thể tự tìm được khả năng sử dụng dưới 256 màu trong hình ảnh của mình. Bằng cách loại bỏ những màu không cần thiết ra khỏi bảng màu, bạn sẽ bảo toàn được không gian lưu trữ và giảm bớt được thời gian tải xuống. Một cách khác để thu gọn bảng mày của hình là hạn chế số lượng các sắc thái của mọi màu được sử dụng. Chẳng hạn, thay vì phải có 16 sắc thái khác nhau của màu vàng trong một hình, bạn có thể thu nhỏ bẳng màu chỉ hỗ trợ ba sắc vàng. Nếu áp dụng kỹ thuật này cho tất cả các màu, bạn có thể thu nhỏ bảng màu của một hình, đồng thời rút gọn một cách đáng kể kích thước tập tin đó.
     Dĩ nhiên có một sự trả giá giữa chất lượng hình và kích thước lưu trữ. Tuy nhiên, bạn có thể thu gọn bảng màu một cách đáng kể mà không ảnh hưởng xấu đến chất lượng hình.
    Chọn GIF hay JPEG
     Khi bổ sung hình vào trang Web của mình, bạn phải chọn dạng để hỗ trợ. Java hỗ trợ cả hai dạng GIF và JPEG, nhưng có một số yếu tố làm cho bạn thích dùng cái này hơn cái kia.
     Sử dụng các hình GIF có một số điểm lợi. Đối với những người mới bắt đầu, hầu hết các chương trình đồ hoạ, kể cả các tiện ích của phần mềm dùng chung, đều hỗ trợ dạng phổ biến này, cho nên không bao giờ bạn phải mất tiền cho các công cụ giúp bạn hình thành và biên tập các hình theo dạng này. Trong thực tế, GIF là dạng đồ hoạ phổ biến nhất được dùng trên Web hiện nay. Hơn nữa, dạng GIF có hiệu quả cao và có tính năng nén bên trong làm cho các hình ảnh tương đối nhỏ. Cuối cùng, GIF hỗ trợ transparency và interlacing là các tính năng có thể nâng cao rất nhiều sự hấp dẫn của applet.
    *Thực hiện transparency với GIF
     Transparency (sự trong suốt) cho phép người nghệ sĩ đồ hoạ có thể đưa bất kỳ màu nào vào trong hình như thể nó là trong suốt. Khi được đưa ra trên màn hình, màu này không được tiêu biểu bằng tất cả các màu trong bảng màu, kể cả màu nền của hình đó. Kết quả là chúng có thể không hấp dẫn lắm - trừ trường hợp màu của các phần này phù hợp một cách chính xác với nền bên dưới. Do vậy, dạng GIF là sự lựa chọn duy nhất đối với các hình cần phải có một phần "có thể nhìn xuyên qua".
     Đáng tiếc là không phải tất cả các applet Java đều biết cách hoạt động với các hình trong suốt. cho nên, dù bạn đã đi hết quá trình vất vả của việc tạo ra hình GIF trong suốt (đôi khi bạn phải dùng đến những tiện ích đặc biệt để làm), các hình của bạn vẫn có thể hiện thị cả màu nền, tuỳ vào loại applet mà bạn dùng. Kết quả là bạn sẽ phải dùng các applet có khả năng hỗ trợ hình trong suốt khi được phép chọn. Làm thế nào để biết một applet hỗ trợ hình trong suốt? Bạn sẽ phải hỏi chính người đã biên soạn ra applet, hoặc đọc các tài liệu đi kèm với các applet đó. Cũng có thể dùng thử rồi tự nhận xét.
     Đôi khi bạn không được lựa chọn - chỉ có thể tìm thấy một applet đúng với những gì bạn muốn, nhưng lại không hỗ trợ hình trong suốt. Trong trường hợp này, cách giải quyết là sử dụng một chương trình đồ hoạ để thay đổi các hình mà applet đó sẽ dùng, thiết lập một màu nền đúng như màu của trang Web mà nó sẽ được hiển thị trên đó. Theo cách này, khi mỗi hình được hiển thị, nó sẽ xuất hiện dưới dạng trong suốt mặc dù thực tế không phải - chỉ vì nó có màu nền giống như màu trang Web mà thôi.
     Thiết lập màu trong suốt và chọn màu nền cho hình của bạn đều là chức năng của chương trình đồ hoạ mà bạn tình cờ sử dụng. Để tìm cách xây dựng hình trong suốt hoặc đặt trước một màu nền cụ thể cho nó, bạn hãy tham khảo tài liệu thuyết minh của chương trình đó.
     Mặc dù hiện nay chưa, nhưng tất cả các applet rồi sẽ hỗ trợ cho hình trong suốt. Vì bản thân ngôn ngữ lập trình Java không tạo điều kiện dễ dàng để các nhà lập trình có thể hỗ trợ tính năng trong suốt trong các applet của mình, nên nhiều nhà lập trình không thực hiện việc này. Tuy nhiên, trong một tương lại gần, ngôn ngữ lập trình Java sẽ được cải tiến để có nhiều tính năng hơn nữa so với hiện nay. Lúc đó, khoảng cuối 1996, khả năng hỗ trợ đối với hình trong suốt sẽ được xây dựng trực tiếp trong ngôn ngữ này. Và nếu điều đó là hiện thực, thì tất cả các applet được biện soạn từ thời điểm này về sau sẽ hỗ trợ đối với các hình trong suốt.
    *Thực hiện interlacing với GIF
     Interlacing (xen kẽ) là một tính năng độc đáo khác cho dạng GIF, nhưng khác với sự trong suốt, nó được tất cả các applet hỗ trợ. Sự xen kẽ cho phép các hình ảnh xuất hiện dần trên màn hình trong quá trình chúng vẫn đang đi qua đường dây, người xem không phải đợi cho đến khi toàn bộ hình được truyền cong. Hiệu ứng này cũng tương tự như khi quan sát sự hiện hình của bức ảnh chụp Polaroid; bạn có ý tưởng về bức ảnh trước kh nó được hiện hình xong.
     Vì tính năng xen kẽ cung cấp cho người dùng Web có cái để xem trong khi hình đang trở nên rõ dần lên, cho nên họ không bỏ qua quá trình này để chuyển đi nơi khác. Nhiều người sẽ dán mắt vào để xem hình ảnh đàn hiện dần, bị mê hoặc bởi sự kỳ diệu của nó.
    *Có nhiều màu hơn JPEG
     Vì dạng GIF hỗ trợ cho hình trong suốt lẫn hình xen kẽ, ngoài ra nó là dạng mặc định cho đồ hoạ Web nói chung, cho nên bạn sẽ thường nhận thấy chọn nó cho các applet của mình không tốt bằng JPEG.
     Dù thế nào đi nữa thì các hình GIF hiện nay cũng bị hạn chế trong phạm vi 256 (8bit) màu. Mặc dù một ngày nó đó sẽ có nâng cấp cho dạng này, nhưng tại thời điểm viết quyển sách này (cuối 1996), bạn không thể dùng các hình GIF để hiện thị số lượng màu nhiều hơn số đó. Ngược lại, dạng JPEG hỗ trợ cho trên 16 triệu (24 bit) màu khác nhau. ở nơi nào nhất thiết phải có hơn 256 màu trong một hình thì nhất thiết phải dùng dạng JPEG.
     Mặc dù JPEG có vẻ như là một chọn lựa phù hợp khi cần dùng hơn 256 màu, nhưng bản phải cân nhắc một điều là bất kỳ lúc nào applet cũng chạy trong các hệ máy Windows, mọi hình ảnh mà nó dùng đều được giảm xuống 256 màu trước khi hiển thị! Đây là một vấn đề đối với các applet Java đang chạy trên máy có cơ sở Windows - nhất định sẽ được khắc phục trong tương lai khi phiên bản nâng cấp Java được phát hình cho các hệ thống máy này. còn hiện nay, dù bạn có sử dụng các hình ảnh JPEG đi nữa thì những chi tiết đẹp của chúng cũng bị vô dụng đối với người dùng Web trên hệ máy Windows.
    *Chiếm ít không gian hơn với JPEG
     Một quy tắc chung; phải duy trì tổng số tài liệu được tải xuống cho mỗi trang (các tập văn bản, đồ hoạ, âm thanh, các applet...) luôn luôn dưới 250K. Vậy làm cách nào để biết một tập tin lớn nhỏ ra sao?
     -Người dùng Macitosh có thể đến với Finder, điểm sang tập tin đó, rồi chọn File-Get Info.
     -Người dùng Windows thì đến với Windows Explorer, nhấn chuột lên tệp tin bằng phím bên phải, rồi chọn Properties từ menu vừa xuất hiện.
     Dĩ nhiên các kỹ thuật này chỉ cho bạn biết kích cỡ của một tập tin, bạn phải tiến hành lặp lại đối với từng tập tin xuất hiện trên trang Web của mình rồi tổng cộng tất cả số liệu đó lại. Ngoài ra, bạn cũng có thể chọn Get Info (Mac) hoặc Properties (Windows) trên thư mục chứa trang của bạn, chứa applet, và tất cả các tập tin đồ hoạ cũng như âm thanh mà nó sử dụng (giả thiết rằng tất cả chúng đều nằm trong cùng một thư mục). Bạn phải bảo đảm thư mục này chỉ chứa các tập tin được dùng trong trang đó - kích thước được báo cáo sẽ bao gồm mọi tập tin chứa trong thư mục này.
     Nếu bạn có một số lượng lớn đồ hoạ và có tổng cộng hơn 250K tài liệu dùng trong trang Web, bạn phải tính đến việc sử dụng dạng JPEG để đạt mức độ nén cao nhất. Vì các hình ảnh có hơn 100 màu sẽ được nén hiệu quả hơn khi. ở dạng JPEG so với GIF, cho nên mục tiêu đầu tiên mà các hình này phải nhằm vào là giữ được hầu hết màu sắc đối với JPEG.
     Sau khi đã thu hẹp bảng màu và nén từng hình sẽ xuất hiện trong trang của bạn (dù là một bộ phận của trang cũ dùng HTML, hay chỉ được dùng bởi applet), bạn phải tính toán lại tổng lượng bộ nhớ mà trang của bạn sẽ chiếm: Nếu kích thước tổng cộng của trang lớn hơn 250K, bạn phải xem xét một cách nghiêm túc việc giảm bớt lượng tài liệu dùng trên nó. Bạn cũng có thể giám bớt kích thước của các hình, cắt bỏ toàn bộ các tài liệu dư thừa. Và dĩ nhiên, lúc nào bạn cũng có thể sử dụng dạng JPEG với mức độ nén cao nhất đối với tất cả các hình. Nhưng phải nhớ rằng, nếu dùng dạng JPEG, bạn sẽ mất cả khả năng hình trong suốt lẫn khả năng hình xen kẽ có sẵn trong GIF.
    *Lưu ý đến các hệ thống máy của khách đến thăm
     Điều cân nhắc cuối cùng của bạn khi lựa chọn dạng là thiết bị của những người dùng thuộc loại nào. Nếu bạn vẫn thích sử dụng các hình trong trang Web và trong các applet có chứa hơn 256 màu, thì phải chú ý đến tình trạng đa số người dùng Web không có trong tay loại máy tính có thể hiển thị quá 256 màu. Thực tế, nhiều hệ máy nối với Web thậm chí không hiển thị nổi quá 16 màu. Kết quả là những hình ảnh đầy đủ màu sắc tuyệt đẹp của bạn sẽ bị thu hẹp xấu xí đến mức đáng thương haị trên các máy đó. Để tránh thảm kịch này, bạn hãy đầu tư thời gian để giảm bớt bảng màu của các hình càng nhiều càng tốt, ngay từ đầu.
     Mặc dù không cần phải bỏ thật nhiều thời gian để cố làm phù hợp với các hệ thống máy chất lượng thấp, nhưng bạn nên giả thiết rằng phần lớn người dùng Web chỉ có thể xem đến 256 màu. Nếu bạn đồng ý như vậy thì việc lựa chọn giữa JPEG và GIF sẽ trở nên rất dễ dàng.
Java, ngôn ngữ lập trình và ứng dụng
 
        Java, đó là một ngôn ngữ lập trình mới xuất hiện, một cuộc cách mạng trong công nghệ phần mềm. Trong mấy tháng nay, khi bạn lướt trên các trang web, vào các máy tìm kiếm, xem các nhóm thảo luận, đọc các báo, đâu đâu cũng thấy nhắc tới Java. Người thì cho rằng, Java cũng như các ngôn ngữ khác, chẳng có gì đặc biệt và thú vị và đưa ra danh sách các yếu điểm, thiếu sót, lỗi lầm và những lời giải thích dài dằng dặc và cũng khó hiểu vô cùng. Trong khi đó, phần đông người sử dụng, lập trình viên, các nhà sản xuất phần mềm lại ưa thích Java, nhiều công ty đã công bố kế hoạch phát triển các sản phẩm phần mềm của mình dựa trên nền tảng Java, các báo, nhóm thảo luận về Java, lập trình Java và một số vấn đề liên quan nở rộ khắp nơi. Còn ý kiến của bạn về vấn đề này như thế nào?
        Hãy cùng xem xét một số nhận định về Java và một vài ngôn ngữ lập trình khác. Như các bạn đã biết, các ngôn ngữ lập trình được ra đời từ rất lâu, và tính cho đến nay đã có tới hàng chục loại khác nhau. Tuy nhiên số này được phân chia ra làm 2 loại, các ngôn ngữ lập trình bậc thấp và các ngôn ngữ lập tnình bậc cao. Những ngôn ngữ lập trình bậc thấp, (điển hình nh assembler) hỗ trợ rất ít cho ngời sử dụng, các câu lệnh thường khó hiểu vì nó đòi hỏi bạn phải trực tiếp điều khiển việc giao tiếp với máy và các ngôn ngữ bậc cao (có hỗ trợ cho ngời lập trình thông qua chơng trình dịch và một số môđun có sẵn - chẳng hạn như Turbo Pascal, C, Java...). Tất nhiên nếu phải chọn lựa giữa ngôn ngữ lập trình bậc thấp và ngôn ngữ lập trình bậc cao, hầu hết các lập trình viên sẽ chọn giải pháp thứ hai vì họ sẽ tiết kiệm đợc nhiều thời gian, công sức và đạt hiệu quả cao hơn (ví dụ như phải viết một chương trình để truyền file giữa 2 máy qua mạng điện thoại, với ngôn ngữ assembler bạn cần phải có một nỗ lực cỡ Hécquyn, với khoảng vài trăm dòng lệnh trong khi đó, nếu bạn thông thạo Java, bạn sẽ thấy điều này chẳng có gì khó khăn cả - đơn giản là viết vài chục dòng lệnh mà thôi).
        Liệu Java có khó học hơn assembler không? Điều này còn tuỳ thuộc vào quan điểm và cách học tập của mỗi người. Cái khó của assembler là phải hiểu được cơ chế cấp phát, sắp xếp bộ nhớ, điều khiển các biến, các vòng lặp của bộ xử lý, còn với Java, cái khó lại là hiểu được cách thức lập trình hướng đối tượng, các trường, xử lý sự kiện, điều khiển đa luồng... Assembler có ưu thế trong việc viết những phần mềm yêu cầu nhỏ, nhanh, không mầu mè. Với xu thế ngày càng phát triển và thịnh hành của giao diện đồ hoạ, đa nhiệm, xử lý đa luồng và tương tác giữa các hệ điều hành với nhau, hệ điều hành DOS dần dần bị lãng quên và assembler cũng vậy. Nếu bạn chưa biết gì về lập trình mạng cũng như chưa biết gì về Java, đây sẽ là thời điểm tốt để bạn bắt đầu học tập. Đầu tiên, để có được những kiến thức cơ bản về Java, bạn nên tìm đọc các bài báo nói về vấn đề này trên tạp chí PCWorld - Thế giới vi tính (tôi không nghĩ rằng những bài báo này là một tài liệu tốt cho bạn trong những bước khởi đầu, tuy nhiên, đây là một trong những bài/sách nói về Java được xuất bản theo tiếng Việt hiện nay. Phải nói thật rằng, các sách nói về Java đã được dịch ra tiếng Việt có thể chỉ đếm trên 1 bàn tay). Chính vì thế, tôi khuyên các bạn nên tập đọc các tài liệu bằng tiếng Anh và nếu có thể, nên tham gia vào một số nhóm thảo luận về đề tài Java. Tất nhiên, nếu bạn quyết tâm, ngôn ngữ sẽ không là một vấn đề quan trọng, hãy cài một từ điển Anh-Việt nào đó và bắt đầu xem các trang với chủ đề Java tại địa chỉ www.yahoo.com. Hãy bát đầu đến với Java ngay từ bây giờ.

Bài đăng phổ biến