OPENCORES 網站
OPENCORES提供許多開發完成的IP(Intellectual Property,矽智產),其特色是這些IP都是以Open source形式發佈的,每個IP都以專案進行。
網址:http://www.opencores.org/
當你遇到左右為難時,其實你不需要煩惱, 代表兩方都有優點, 你的機會還比別人多
OPENCORES提供許多開發完成的IP(Intellectual Property,矽智產),其特色是這些IP都是以Open source形式發佈的,每個IP都以專案進行。
網址:http://www.opencores.org/
修改設定檔
# vi /etc/ssh/sshd_config
在最後面加入設定值
AllowUsers acos
修改完後記得重新啟動sshd服務
# /etc/rc.d/init.d/sshd restart
註:acos→請填入自己的帳號,如果有多個帳號用空格格開就可以
今天(不!是昨天),追隨李開復博士的兩場演講(選擇的智慧、做二十一世紀的人才),中間還接了兩堂專業選修課程,晚上則是協助阿拉工作站的設定,難得一天可以如此"充實"。廢話不多,以下為聽演講實作的簡單筆記:
選擇的智慧
寒假開的嵌入式系統相關課程已經公告了!請參考網頁資訊→http://www.cslab.iecs.fcu.edu.tw/esrc/news.php?id=6
至於推不推薦麻~因為是第一次開課也不知道教的程度到哪,不過我覺得只要對該領域有一點點興趣就參加吧,具備邏設基礎應該就可以聽懂大部分課程了!
關於Linux該怎麼唸(發音)這老梗的爭論議題,似乎還是沒有個權威跳出來拍板定案。
不過各地口音本來就不盡相同,因此這也沒什麼好爭論的XD,倒是可以參考Linux創始人的念法,錄音檔請參考→http://tinyurl.com/24xjon
詳細說明請參考網址→http://www.programmersheaven.com/articles/pathak/article1.htm
之前暑假在樓下學SoC程式設計時就遇過volatile這關鍵字,當時授課的助教只說他也不清楚這意思,要大家照抄就是了。現在實驗室也開始玩SoC發展平台,自然的有一部分就是要寫一些程式控制周邊硬體,以上都是廢話XD
由於ARM都是採用memory-map方式存取周邊裝置,因此要對周邊裝置溝通只要把資料丟進記憶體或從記憶體讀取資料就可以了,但這時聰明的編譯器反而可能變成壞了大了事的老鼠屎,原來是幫程式碼最佳化的功能反而成了困擾,請參考底下程式碼:
*ptr = 0;
while(*ptr){
*ptr = 4 ;
*ptr = 0 ;
}
*ptr = 0
while(0) {
}
Dev-C++在Vista系統下似乎都會遇到無法編譯的問題。詳細解法請參考網頁→http://msml92.net/blog/LD/archives/229
感謝金剛學弟熱情提供資訊!
對新手來說很重要的觀念!
請思考的程式碼印出結果,究竟會印出0.5或是0?
#include <stdio.h>很多新手應該會選擇0.5吧!確實~以人類思考角度來看0.5應該是正確的,可是在C語言看來0才是正確解答。
int main() {
int a = 10 ;
int b = 20 ;
printf("%f\n", a/b) ;
system("pause") ;
return 0 ;
}
#include <stdio.h>
int main() {
float a = 2 ;
float b = 3 ;
printf("%f\n", a/b) ;
system("pause") ;
return 0 ;
}
功能說明:
在校外以HiNet、SeedNet要連線圖書館所訂購的電子資料庫時,應先進行代理伺服器的設定。
Proxy網址:
http://proxy.lib.fcu.edu.tw/proxy.pac
詳細設定說明請參考:
http://www.lib.fcu.edu.tw/eresources/er_outcampus_services.htm
把七張牌值印出來,並且將最大獎的組合用顏色強調,花色代碼改成以圖示顯示。
NEW_LINE MACRO
push ax
push dx
mov ah,02
mov dl,10
int 21h
mov dl,13
int 21h
pop dx
pop ax
ENDM
GET_CHAR MACRO char
push ax
mov ah,01
int 21h
mov char,al
pop ax
ENDM
END_PROCESS MACRO
mov ah,4ch
int 21h
ENDM
.model small
.data
abc equ 61
cba equ 55
card_7 db 7 dup(?)
card_5 db 5 dup(?)
temp_5 db 5 dup(?)
max_prize db ?
max_num db ?
ceq db ?
prize db ?
_mask db 00001000b,00000100b,00000010b,00000001b
pr_tab db 0,1,1,3,1,2,3,7,1,2,2,6,3,6,7,10
card_tab db 1,2,3,4,5, 1,2,3,4,6, 1,2,3,5,6
db 1,2,4,5,6, 1,3,4,5,6, 2,3,4,5,6
db 1,2,3,4,7, 1,2,3,5,7, 1,2,4,5,7
db 1,3,4,5,6, 2,3,4,5,7, 1,2,3,6,7
db 1,2,4,6,7, 1,3,4,6,7, 2,3,5,6,7
db 1,2,5,6,7, 1,3,5,6,7, 2,3,5,6,7
db 1,4,5,6,7, 2,4,5,6,7, 3,4,5,6,7
card_52 db 01h,02h,03h,04h,05h,06h,07h
db 08h,09h,0ah,0bh,0ch,0dh
db 11h,12h,13h,14h,15h,16h,17h
db 18h,19h,1ah,1bh,1ch,1dh
db 21h,22h,23h,24h,25h,26h,27h
db 28h,29h,2ah,2bh,2ch,2dh
db 31h,32h,33h,34h,35h,36h,37h
db 38h,39h,3ah,3bh,3ch,3dh
card_28 db 01h,11h,2dh,34h,35h,26h,08h
db 01h,11h,2ch,05h,15h,26h,27h
db 21h,31h,2bh,34h,35h,36h,37h
db 01h,11h,03h,15h,05h,25h,0ah
mess db ' ** sorry !!! ** $'
db 'one pair. $'
db 'two pairs. $'
db 'three of a kind. $'
db 'straight. $'
db 'flush. $'
db 'full house. $'
db 'four of a king. $'
db 'flush straight. $'
db 'flush royal. $'
db 07h,'%% data error %% $'
;============================================================================================================================
.stack 1000h
;============================================================================================================================
.code
main proc far
mov ax,@data
mov ds,ax
bbloop:
call far ptr cdgen
call far ptr check_7
call far ptr p_result
NEW_LINE
GET_CHAR dl
cmp dl,13 ;press ENTER for next turn
je bbloop
END_PROCESS
main endp
;
;---------------------------------------------------------------------------------------------------------------------------
;
check_7 proc far
mov [max_prize],0
mov [max_num],0
mov cx,21
ckloop1: mov al,05h
mov dl,cl
dec dl
mul dl
mov bx,ax
mov si,5
ckloop2: dec si
mov al,[card_tab + bx + si]
mov di,ax
mov al,[card_7 - 1 + di]
mov [card_5 + si],al
xor si,0
jnz ckloop2
call check_5
mov ah,[prize]
cmp ah,[max_prize]
jbe nextturn
mov [max_prize],ah
mov [max_num],cl
nextturn: loop ckloop1
ret
check_7 endp
;---------------------------------------------------------------------------------------------------------------------------
check_5 proc near
mov [prize],0
mov ah,0fh
call copypure
call sorttemp_5
call compare
cmp [ceq],0
jne setprize
call checkstr
mov ah,30h
call copypure
call compare
cmp [ceq],0fh
jne noflush
cmp1: cmp bh,0
jne cmp2
mov [prize],5
jmp checkexit
cmp2: cmp bh,1
jne cmp3
mov [prize],8
jmp checkexit
cmp3: mov [prize],9
jmp checkexit
noflush: cmp bh,0
je nostraight
mov [prize],4
jmp checkexit
nostraight: mov [ceq],0
setprize: lea bx,pr_tab
mov al,[ceq]
xlat
mov [prize],al
checkexit: ret
check_5 endp
;---------------------------------------------------------------------------------------------------------------------------
copypure proc
mov si,5
pureloop: dec si
mov al,[ card_5 + si ]
and al,ah
mov [ temp_5 + si ],al
cmp si,0
jne pureloop
ret
copypure endp
;---------------------------------------------------------------------------------------------------------------------------
sorttemp_5 proc near
mov si,4
sortloop1: mov al,[ temp_5 + si ]
mov di,0
sortloop2: cmp al,[ temp_5 + di ]
jge sortnext
xchg al,[ temp_5 + di ]
sortnext: inc di
cmp di,si
jne sortloop2
mov [ temp_5 + si ],al
dec si
jnz sortloop1
ret
sorttemp_5 endp
;---------------------------------------------------------------------------------------------------------------------------
compare proc
mov [ceq],0
mov si,0
cmploop: mov ah,[temp_5 + si]
xor ah,[temp_5 + si + 1]
jnz cmpnext
mov al,[_mask + si ]
or [ceq],al
cmpnext: inc si
cmp si,4
jnz cmploop
ret
compare endp
;---------------------------------------------------------------------------------------------------------------------------
checkstr proc near
mov bh,0
mov al,[temp_5 +4]
sub al,[temp_5 +0]
cmp al,4
je addbh
cmp al,12
jne strexit
cmp [temp_5 + 1],10 ;@@?
jne strexit
inc bh
addbh: inc bh
strexit: ret
checkstr endp
;---------------------------------------------------------------------------------------------------------------------------
p_result proc far
mov bl,[max_prize]
mov al,20
mul bl
lea dx,mess
add dx,ax
mov ah,09h
int 21h
cmp bl,0
je pr_exit
mov bl,[max_num]
dec bl
mov al,05h
mul bl
mov bx,ax
mov si,0
temploop: mov dl,[card_tab + bx + si]
mov [temp_5 + si],dl
inc si
cmp si,5
jne temploop
mov si,0
print_7: mov di,0
temploop2: mov dl,[temp_5 + di]
dec dl
mov dh,0
cmp si,dx
jne tempnext2
mov ah,09h
mov bh,0
mov bl,0001100b
mov cx,3
int 10h
tempnext2: inc di
cmp di,5
jne temploop2
mov cl,[card_7 + si]
and cl,0fh
mov ch,[card_7 + si]
and ch,0f0h
mov dl,6 ;spade
cmp ch,30h
je color
mov dl,3 ;heart
cmp ch,20h
je color
mov dl,4 ;diamond
cmp ch,10h
je color
mov dl,5 ;club
color: mov ah,02h
int 21h
;;card value convert
mov dl,'A'
cmp cl,1
je printnext1
mov dl,cl
or dl,30h
cmp cl,9
jbe printnext1
mov dl,'J'
cmp cl,11
je printnext1
mov dl,'Q'
cmp cl,12
je printnext1
mov dl,'K'
cmp cl,13
je printnext1
mov dl,'1'
int 21h
mov dl,'0'
printnext1: int 21h
mov dl,' '
int 21h
inc si
cmp si,7
jne print_7
pr_exit: ret
p_result endp
;---------------------------------------------------------------------------------------------------------------------------
cdgen proc far
call randomize
mov cx,7
mov dh,4
rndloop: call random
lea bx,card_28
mul cl
xor ah,ah
add bx,ax
mov si,cx
mov ah,[bx + si - 1]
mov [card_7 - 1 + si],ah
loop rndloop
ret
cdgen endp
;---------------------------------------------------------------------------------------------------------------------------
randomize proc near
mov ah,2ch
int 21h
;shl dh,1
add dl,dh
ret
randomize endp
;---------------------------------------------------------------------------------------------------------------------------
random proc near
mov al,abc
mul dl
add ax,cba
mov dl,al
mul dh
mov al,ah
ret
random endp
end main
=============================================================================================================================
把七張牌值印出來,並且將最大獎的組合用顏色強調。
NEW_LINE MACRO
push ax
push dx
mov ah,02
mov dl,10
int 21h
mov dl,13
int 21h
pop dx
pop ax
ENDM
GET_CHAR MACRO char
push ax
mov ah,01
int 21h
mov char,al
pop ax
ENDM
PUT_CHAR MACRO char
mov dl,char
mov ah,02h
int 21h
ENDM
END_PROCESS MACRO
mov ah,4ch
int 21h
ENDM
.model small
.data
abc equ 61
cba equ 55
card_7 db 7 dup(?)
card_5 db 5 dup(?)
temp_5 db 5 dup(?)
max_prize db ?
max_num db ?
ceq db ?
prize db ?
_mask db 00001000b,00000100b,00000010b,00000001b
pr_tab db 0,1,1,3,1,2,3,7,1,2,2,6,3,6,7,10
card_tab db 1,2,3,4,5, 1,2,3,4,6, 1,2,3,5,6
db 1,2,4,5,6, 1,3,4,5,6, 2,3,4,5,6
db 1,2,3,4,7, 1,2,3,5,7, 1,2,4,5,7
db 1,3,4,5,6, 2,3,4,5,7, 1,2,3,6,7
db 1,2,4,6,7, 1,3,4,6,7, 2,3,5,6,7
db 1,2,5,6,7, 1,3,5,6,7, 2,3,5,6,7
db 1,4,5,6,7, 2,4,5,6,7, 3,4,5,6,7
card_52 db 01h,02h,03h,04h,05h,06h,07h
db 08h,09h,0ah,0bh,0ch,0dh
db 11h,12h,13h,14h,15h,16h,17h
db 18h,19h,1ah,1bh,1ch,1dh
db 21h,22h,23h,24h,25h,26h,27h
db 28h,29h,2ah,2bh,2ch,2dh
db 31h,32h,33h,34h,35h,36h,37h
db 38h,39h,3ah,3bh,3ch,3dh
card_28 db 01h,11h,2dh,34h,35h,26h,08h
db 01h,11h,2ch,05h,15h,26h,27h
db 21h,31h,2bh,34h,35h,36h,37h
db 01h,11h,03h,15h,05h,25h,0ah
mess db ' ** sorry !!! ** $'
db 'one pair. $'
db 'two pairs. $'
db 'three of a kind. $'
db 'straight. $'
db 'flush. $'
db 'full house. $'
db 'four of a king. $'
db 'flush straight. $'
db 'flush royal. $'
db 07h,'%% data error %% $'
;============================
.stack 1000h
;============================
.code
main proc far
mov ax,@data
mov ds,ax
bbloop:
call far ptr cdgen
call far ptr check_7
call far ptr p_result
NEW_LINE
GET_CHAR dl
cmp dl,13 ;press ENTER for next turn
je bbloop
END_PROCESS
main endp
;
;---------------------------------------
;
check_7 proc far
mov [max_prize],0
mov [max_num],0
mov cx,21
ckloop1: mov al,05h
mov dl,cl
dec dl
mul dl
mov bx,ax
mov si,5
ckloop2: dec si
mov al,[card_tab + bx + si]
mov di,ax
mov al,[card_7 - 1 + di]
mov [card_5 + si],al
xor si,0
jnz ckloop2
call check_5
mov ah,[prize]
cmp ah,[max_prize]
jbe nextturn
mov [max_prize],ah
mov [max_num],cl
nextturn: loop ckloop1
ret
check_7 endp
;-------------------------------
check_5 proc near
mov [prize],0
mov ah,0fh
call copypure
call sorttemp_5
call compare
cmp [ceq],0
jne setprize
call checkstr
mov ah,30h
call copypure
call compare
cmp [ceq],0fh
jne noflush
cmp1: cmp bh,0
jne cmp2
mov [prize],5
jmp checkexit
cmp2: cmp bh,1
jne cmp3
mov [prize],8
jmp checkexit
cmp3: mov [prize],9
jmp checkexit
noflush: cmp bh,0
je nostraight
mov [prize],4
jmp checkexit
nostraight: mov [ceq],0
setprize: lea bx,pr_tab
mov al,[ceq]
xlat
mov [prize],al
checkexit: ret
check_5 endp
;----------------------------
copypure proc
mov si,5
pureloop: dec si
mov al,[ card_5 + si ]
and al,ah
mov [ temp_5 + si ],al
cmp si,0
jne pureloop
ret
copypure endp
;--------------------------
sorttemp_5 proc near
mov si,4
sortloop1: mov al,[ temp_5 + si ]
mov di,0
sortloop2: cmp al,[ temp_5 + di ]
jge sortnext
xchg al,[ temp_5 + di ]
sortnext: inc di
cmp di,si
jne sortloop2
mov [ temp_5 + si ],al
dec si
jnz sortloop1
ret
sorttemp_5 endp
;----------------------------
compare proc
mov [ceq],0
mov si,0
cmploop: mov ah,[temp_5 + si]
xor ah,[temp_5 + si + 1]
jnz cmpnext
mov al,[_mask + si ]
or [ceq],al
cmpnext: inc si
cmp si,4
jnz cmploop
ret
compare endp
;------------------------------
checkstr proc near
mov bh,0
mov al,[temp_5 +4]
sub al,[temp_5 +0]
cmp al,4
je addbh
cmp al,12
jne strexit
cmp [temp_5 + 1],10 ;@@?
jne strexit
inc bh
addbh: inc bh
strexit: ret
checkstr endp
;---------------------------
p_result proc far
mov bl,[max_prize]
mov al,20
mul bl
lea dx,mess
add dx,ax
mov ah,09h
int 21h
cmp bl,0
je pr_exit
mov bl,[max_num]
dec bl
mov al,05h
mul bl
mov bx,ax
mov si,0
temploop: mov dl,[card_tab + bx + si]
mov [temp_5 + si],dl
inc si
cmp si,5
jne temploop
mov si,0
print_7: mov di,0
temploop2: mov dl,[temp_5 + di]
dec dl
mov dh,0
cmp si,dx
jne tempnext2
mov ah,09h
mov bh,0
mov bl,0001100b
mov cx,3
int 10h
tempnext2:
inc di
cmp di,5
jne temploop2
mov cl,[card_7 + si]
mov ch,cl
and ch,0f0h
or ch,30h
PUT_CHAR ch
mov ch,cl
and ch,0fh
cmp ch,9
jbe not_convert
add ch,7h
not_convert:
add ch,30h
PUT_CHAR ch
PUT_CHAR ' '
inc si
cmp si,7
jne print_7
pr_exit: ret
p_result endp
;-----------------------------
cdgen proc far
call randomize
mov cx,7
mov dh,4
rndloop: call random
lea bx,card_28
mul cl
xor ah,ah
add bx,ax
mov si,cx
mov ah,[bx + si - 1]
mov [card_7 - 1 + si],ah
loop rndloop
ret
cdgen endp
;-------------------------
randomize proc near
mov ah,2ch
int 21h
;shl dh,1
add dl,dh
ret
randomize endp
;-------------------------
random proc near
mov al,abc
mul dl
add ax,cba
mov dl,al
mul dh
mov al,ah
ret
random endp
end main
某學弟好心整理的考古題(含解答)
1.說明下列三到指令之功能,並敘述多種用法:
1) 指令功能說明
a.AND x,y 讓 x 與 y 做 AND 邏輯運算,並把結果存在 x
b.OR x,y 讓 x 與 y 做 OR 邏輯運算,並把結果存在 x
c.XOR x,y 讓 x 與 y 做 OR 邏輯運算,並把結果存在 x
2) 指令應用
A. and
對某些位元作清除(清除為0),如:要將1byte的第1、5位元清除為0,並保留其他位元的值
可用 and al,11011101b
B. or
對某些位元作設定(設定為1),如:要將1byte的第1、5位元設為1
可用 or al, 00100010b
C. xor
對某些位元作0、1轉換,如:要對1byte的第1、5位元作0、1轉換
可用xor al, 00100010b
2.說明80x86 cpu 之 addressing mode
2)
80X86指令的定址法共分三類七大定址法,所謂的三類即立即定址法、暫存器定址法、與記憶體定址法,其中記憶體定址法又分為五種,所以總共是七大定址法。
一、立即定址法(Immediate Addressing Mode)
二、暫存器定址法(Register Addressing Mode)
三、記憶體直接定址法(Direct memory Addressing Mode)或直接定址法(Direct Addressing Mode)
四、記憶體間接定址法(Indirect memory Addressing Mode)或間接定址法(Indirect Addressing Mode)
五、基底定址法(Based Addressing Mode).
六、索引定址法(Indexed Addressing Mode)
七、基底索引定址法(Based Indexed Addressing Mode)
以下我們對各種定址法分別加以說明:
暫存器定址法(Register Addressing Mode):運算元是暫存器,就是暫存器定址法。
* 例如: MOV DS,AX
此指令以暫存器定址法取得,AX暫存器的資料,之後以暫存器定址法寫入到DS暫存器中。
* 例如: MOV MEM1,AX
第一個運算元MEM1 不是暫存器定址法,第二個運算元AX是使用暫存器定址法。
* 例如: MOV AX,BX
說明:上述指令執行完後,AX、BX內容相同。在80X86的暫存器群中,區段暫存器的使用有其限制,即區段暫存器不能互相傳送資料,例如:將CS暫存器的內容存入DS暫存器中,則必須寫成如下格式。MOV AX,CS
MOV DS,AX。
* 例 : INC AX
說明:運算元為AX暫存器。執行後,AX暫存器的內容加1。
* 例 : PUSH BX
說明:運算元為BX暫存器。執行後,BX暫存器的內容存入堆疊中 。
立即定址法(Immediate Addressing Mode):運算元是一個數字(立即值),就是所謂的立即定址法。* 如右例:
記憶體直接定址法(Direct memory Addressing Mode):是記憶體定址法的一種,直接定址法就是運算元直接指出資料所在記憶體的位址的方法,如右圖:
執行之後AX=5678;PI是所謂的資料標名,組譯時會算出其PI的實際位址。
* 例 : MOV AL,VALUE
說明:上述指令之運算元VALUE為一資料變數,VALUE必須在資料區段中定義。假設我們在資料區段中定義"VALUE DB 100H",且記憶體100H中的資料如右圖所示,則上述指令執行完後,AL=01H。
間接定址法 (Indirect Addressing Mode)
將暫存器的值當做是記憶體的位址,而暫存器可以看成是個資料的指標,到此位址去取得運算元的方法,而暫存器能是BX、BP、SI或DI,暫存器名必須用中括號[ ]括起來。如右圖所示以上是把BX內含視為一位址,再依此位址所指之內容搬至AX暫存器內。
基底定址法 (Based Addressing Mode)
BX及BP暫存器有一項特殊用途即是做為基底暫存器使,那基底定址法就是以基底暫存器所指的位址為基底,再加上一個固定的距離來得到資料所在的位址。
索引定址法(Indexed Addressing Mode)
索引定址法與基底定址法類似,但索引定址法是以固定的位址為基底再加上索引暫存器SI或Dl的值以得出資料所在的位址,因為是用SI與Dl這兩個索引暫存器,所以叫索引定址法,尤其處理一維陣列的元素,索引定址法最方便。
[註]:SI或DI暫存器都可透過加減指令來改變其內容。
基底索引定址法(Based Indexed Addressing Mode)
基底索引定址法與索引定址法類似,但是基底索引定址法有兩個變數,一個基底暫存器,另一個是索引暫存器,如此在處理二維陣列的元素,基底索引定址法最方便。例如:執行前,已知AX=3388H,SI=0001H,SI=0002H,MEM1 DW 1234H,5678H
[註1]:基底暫存器與索引暫存器都可透過加減指令來改變其內容。
[註2]:以上這些記憶體定址法的表示法都很有彈性,例如以下四種寫法結果都是相同的:
MOV AX,[BX+DI+3] MOV AX,[BX+3][DI]
MOV AX,[BX+DI]3 MOV AX,[BX][DI][3]
[註3]:在記憶體間接定址法中包含三種定址法,即基底定址法、索引定址法與基底索引定址法,必須注意的是,其運算元只能使用BX,BP,SI,DI這四個暫存器,不可使用其它暫存器。例如指令"MOV AX,[CX]"即是一個錯誤的例子。
3.說明ZF,CF,SF,OF四旗標(flog)之意義
3)
ZF (零旗標),運算結果為零時,此旗標會被設定為 1,若比較相同兩數, ZF 也會被設為一,若比較不相同的兩數,ZF 會被清除為零。
CF (進位旗標)表示進位或借位。如果加法有進位(80h+80h=100h),則此位元會被設為 1,當然減法乘法除法也是一樣,對減法來講就是借位。
SF (符號旗標),運算結果為負數,就是最高位元為 1 時,SF 會被設為 1,否則被清除。
OF (溢位旗標),可以反映出運算結果是否超出有號數之範圍。
4.下列各指令會檢查哪些旗標?
A. JBE B. JAG C. JG
D. JB E. JLE
4)
a.CF or ZF
b.
c.ZFand SF 、OF
d.CF
e.ZF or SF 、 OF
5.請說明bubble sort 之工作原理,請以80X86組合語言設計bubble sort之program
GETCHAR MACRO char
mov ah,01h
int 21h
mov char,al
ENDM
PUTCHAR MACRO char
mov ah,02h
mov dl,char
int 21h
ENDM
END_PROCESS MACRO
mov ah,4ch
int 21h
ENDM
NEW_LINE MACRO
mov ah,02h
mov dl,0dh
int 21h
mov dl,0ah
int 21h
ENDM
.model small
.data
run_time equ 5
temp db 5 dup(?)
.stack
.code
mov ax,@data
mov ds,ax
mov si,run_time
begin: dec si
GETCHAR [temp+si]
NEW_LINE
cmp si,0
jnz begin
mov di,run_time
sort: dec di
mov si,run_time
bobble: dec si
mov al,temp[si]
cmp al,temp[si-1]
jle bobblenext
xchg al,temp[si-1]
mov temp[si],al
bobblenext:
cmp si,1
jnz bobble
cmp di,0
jnz sort
mov si,run_time
print: dec si
PUTCHAR temp[si]
cmp si,0
jnz print
END_PROCESS
.exit
END
;;修正第二運算元,第二運算元如果只有一位元,可以選擇按enter鍵即進行運算。
;;前一版請參考http://new-acos.blogspot.com/2007/10/x86_21.html
GETCHAR MACRO char
push ax
mov ah,01h
int 21h
mov char,al
pop ax
ENDM
PUTCHAR MACRO char
push dx
push ax
mov dl,char
mov ah,02h
int 21h
pop ax
pop dx
ENDM
END_PROCESS MACRO
mov ah,4ch
int 21h
ENDM
.MODEL SMALL
.DATA
values db 2 dup(?)
operator db 1 dup(?)
answer db 1 dup(?)
.STACK
.CODE
main_pro proc far
mov dl,3
count_loop: mov si,0
keyin_loop: GETCHAR bl
cmp bl,'+'
je go_1
cmp bl,'-'
jne continue
go_1: cmp si,0
je invalid
mov [operator],bl
jmp keyin_loop
go_2: mov [operator],bl
jmp finish
continue: call check_num
mov cl,bl
GETCHAR bl
cmp bl,'+'
je go_2
cmp bl,'-'
je go_2
cmp bl,0dh
je finish
mov al,10
mul cl
mov cl,al
call check_num
add cl,bl
finish: mov [values+si],cl
inc si
cmp si,2
jne keyin_loop
mov al,[values]
mov bl,[values+1]
mov cl,[operator]
cmp cl,'-'
jne do_add
sub al,bl
mov [answer],al
call print_ans
jmp ok
do_add: add al,bl
mov [answer],al
call print_ans
ok: dec dl
jnz count_loop
END_PROCESS
main_pro endp
check_num proc far
cmp bl,'0'
jl invalid
cmp bl,'9'
jg invalid
sub bl,'0'
ret
check_num endp
print_ans proc far
call cr
xor ax,ax
mov al,[values]
call print_num
PUTCHAR [operator]
xor ax,ax
mov al,[values+1]
call print_num
PUTCHAR '='
xor ax,ax
mov al,[answer]
call print_num
call lf
ret
print_ans endp
print_num proc far
push cx
mov ch,1
cmp al,100
jb ignore_h
xor ch,ch
PUTCHAR '1'
sub al,100
ignore_h: mov cl,10
div cl
cmp al,0
jne go_3
cmp ch,0
jne go_4
go_3: add al,'0'
PUTCHAR al
go_4: add ah,'0'
PUTCHAR ah
pop cx
ret
print_num endp
cr proc near
push ax
push dx
mov ah,2
mov dl,0dh
int 21h
pop dx
pop ax
ret
cr endp
lf proc far
push ax
push dx
call cr
mov ah,2
mov dl,0ah
int 21h
pop dx
pop ax
ret
lf endp
invalid: PUTCHAR '!'
END_PROCESS
END
作業二,0~99兩數字加減法
;;;; 程式說明 ;;;;
;; 使用者輸入一算數
GETCHAR MACRO char
push ax
mov ah,01h
int 21h
mov char,al
pop ax
ENDM
PUTCHAR MACRO char
push dx
push ax
mov dl,char
mov ah,02h
int 21h
pop ax
pop dx
ENDM
END_PROCESS MACRO
mov ah,4ch
int 21h
ENDM
.MODEL SMALL
.DATA
values db 2 dup(?)
operator db 1 dup(?)
.STACK
.CODE
main_pro proc far
mov dl,3
count_loop: mov si,0
keyin_loop: GETCHAR bl
cmp bl,'+'
je go_1
cmp bl,'-'
jne continue
go_1: cmp si,0
je invalid
mov [operator],bl
jmp keyin_loop
go_2: mov [operator],bl
jmp finish
continue: call check_num
mov cl,bl
GETCHAR bl
cmp bl,'+'
je go_2
cmp bl,'-'
je go_2
mov al,10
mul cl
mov cl,al
call check_num
add cl,bl
finish: mov [values+si],cl
inc si
cmp si,2
jne keyin_loop
mov al,[values]
mov bl,[values+1]
mov cl,[operator]
cmp cl,'-'
jne do_add
sub al,bl
call print_ans
jmp ok
do_add: add al,bl
call print_ans
ok: dec dl
jnz count_loop
END_PROCESS
main_pro endp
check_num proc far
cmp bl,'0'
jl invalid
cmp bl,'9'
jg invalid
sub bl,'0'
ret
check_num endp
print_ans proc far
PUTCHAR '='
cmp al,100
jb ignore_h
PUTCHAR '1'
sub al,100
ignore_h: mov cl,10
div cl
add al,'0'
add ah,'0'
PUTCHAR al
PUTCHAR ah
call cr_lf
ret
print_ans endp
cr_lf proc far
push ax
push dx
mov ah,2
mov dl,0dh
int 21h
mov dl,0ah
int 21h
pop dx
pop ax
ret
cr_lf endp
invalid: PUTCHAR '!'
END_PROCESS
END
作業一
說明:
使用者每次輸入五個數值(五張撲克牌),若輸入錯誤牌值或是輸入'!'字元程式結束。
程式不印中獎名稱,改印中獎編號。
PS. 僅接受01~0d, 11~1d, 21~2d, 31~3d(限小寫)
GETCHAR MACRO char
mov ah,01h
int 21h
mov char,al
ENDM
PUTCHAR MACRO char
mov ah,02h
mov dl,char
int 21h
ENDM
END_PROCESS MACRO
mov ah,4ch
int 21h
ENDM
.MODEL SMALL
.DATA
abc equ 61
cde equ 55
key_temp db 2 dup(?)
card_5 db 5 dup(?)
temp_5 db 5 dup(?)
max_prize db ?
max_num db ?
ceq db ?
prize db ?
_mask db 00001000b,00000100b,00000010b,00000001b
pr_tab db 0,1,1,3,1,2,3,7,1,2,2,6,3,6,7,10
card_tab db 1,2,3,4,5, 1,2,3,4,6, 1,2,3,5,6
db 1,2,4,5,6, 1,3,4,5,6, 2,3,4,5,6
db 1,2,3,4,7, 1,2,3,5,7, 1,2,4,5,7
db 1,3,4,5,7, 2,3,4,5,7, 1,2,3,6,7
db 1,2,4,6,7, 1,3,4,6,7, 2,3,4,6,7
db 1,2,5,6,7, 1,3,5,6,7, 2,3,5,6,7
db 1,4,5,6,7, 2,4,5,6,7, 3,4,5,6,7
card_52 db 01h,02h,03h,04h,05h,06h,07h
db 08h,09h,0ah,0bh,0ch,0dh
db 11h,12h,13h,14h,15h,16h,17h
db 18h,19h,1ah,1bh,1ch,1dh
db 21h,22h,23h,24h,25h,26h,27h
db 28h,29h,2ah,2bh,2ch,2dh
db 31h,32h,33h,34h,35h,36h,37h
db 38h,39h,3ah,3bh,3ch,3dh
mess db '** sorry !! ** $'
db ' ===> 1 $'
db ' ===> 2 $'
db ' ===> 3 $'
db ' ===> 4 $'
db ' ===> 5 $'
db ' ===> 6 $'
db ' ===> 7 $'
db ' ===> 8 $'
db ' ===> 9 $'
db 07h, ' %% error %% $'
;----------------------------------------------------------
.STACK 1000h
.CODE
main proc far
;
mov ax,@data
mov ds,ax
continue: mov di,5
key_round: GETCHAR [key_temp]
cmp [key_temp], '!'
je exit
GETCHAR [key_temp+1]
cmp [key_temp+1], '!'
je exit
PUTCHAR ' '
call transform
dec di
xor di,0
jne key_round
call check_5
;
call far ptr p_result
;
jmp continue
exit: END_PROCESS
main endp
;
transform proc
mov si,2
trans_run: mov ch,[key_temp-1+si]
cmp ch,'0'
jl err
cmp ch,'9'
jle is_num
cmp ch,'a'
jl err
cmp ch,'f'
jg err
sub ch,87
jmp go_f
is_num: sub ch,'0'
go_f: mov [key_temp-1+si],ch
dec si
xor si,0
jnz trans_run
;
mov cl,[key_temp]
mov al,16
mul cl
mov cl,[key_temp+1]
add al,cl
mov [card_5+di-1],al
ret
transform endp
err: PUTCHAR 'E'
PUTCHAR 'R'
PUTCHAR 'R'
PUTCHAR 'O'
PUTCHAR 'R'
PUTCHAR '!'
PUTCHAR '!'
END_PROCESS
;-----------------------------------------------------------------
check_5 proc near
mov [prize],0
mov ah,0fh
call copypure
call sorttemp_5
call compare
cmp [ceq],0
jne setprize
call checkstr
mov ah,30h
call copypure
call compare
cmp [ceq],0fh
jne noflush
cmp1: cmp bh,0
jne cmp2
mov [prize],5
jmp checkexit
cmp2: cmp bh,1
jne cmp3
mov [prize],8
jmp checkexit
cmp3: mov [prize],9
jmp checkexit
noflush: cmp bh,0
je nostraight
mov [prize],4
jmp checkexit
nostraight: mov [ceq],0
setprize: lea bx,pr_tab
mov al,[ceq]
xlat
mov [prize],al
checkexit: ret
check_5 endp
;---------------------------------------------------------------
copypure proc
mov si,5
pureloop: dec si
mov al,[card_5 + si]
and al,ah
mov [temp_5 + si],al
cmp si,0
jne pureloop
ret
copypure endp
;--------------------------------------------------------------
sorttemp_5 proc near
mov si,4
sortloop1: mov al,[ temp_5 + si ]
mov di,0
sortloop2: cmp al,[ temp_5 + di ]
jge sortnext
xchg al,[ temp_5 +di ]
sortnext: inc di
cmp di,si
jne sortloop2
mov [ temp_5 + si ],al
dec si
jnz sortloop1
ret
sorttemp_5 endp
;--------------------------------------------------------------
compare proc
mov [ceq],0
mov si,0
cmploop: mov ah,[temp_5 + si]
xor ah,[temp_5 + si + 1]
jnz cmpnext
mov al,[_mask + si]
or [ceq],al
cmpnext: inc si
cmp si,4
jnz cmploop
ret
compare endp
;--------------------------------------------------------------
checkstr proc near
mov bh,0
mov al,[temp_5 +4]
sub al,[temp_5 +0]
cmp al,4
je addbh
cmp al,12
jne strexit
mov al,[temp_5+1]
cmp al,10
jne strexit
inc bh
addbh: inc bh
strexit: ret
checkstr endp
;----------------------------------------------------
p_result proc far
mov bl,[prize]
mov al,16
mul bl
lea dx,mess
add dx,ax
mov ah,09h
int 21h
cmp bl,0
ret
p_result endp
END main
徐泓洋老師上課教學用的程式碼。
功能說明:程式每次執行會自動抓取亂數設定牌值與花色,並且依照亂數產生的牌判斷得到的是one pair、two pair...等獎項或是槓龜...
.MODEL SMALL
.DATA
abc equ 61
cde equ 55
card_7 db 7 dup(?)
card_5 db 5 dup(?)
temp_5 db 5 dup(?)
max_prize db ?
max_num db ?
ceq db ?
prize db ?
_mask db 00001000b,00000100b,00000010b,00000001b
pr_tab db 0,1,1,3,1,2,3,7,1,2,2,6,3,6,7,10
card_tab db 1,2,3,4,5, 1,2,3,4,6, 1,2,3,5,6
db 1,2,4,5,6, 1,3,4,5,6, 2,3,4,5,6
db 1,2,3,4,7, 1,2,3,5,7, 1,2,4,5,7
db 1,3,4,5,7, 2,3,4,5,7, 1,2,3,6,7
db 1,2,4,6,7, 1,3,4,6,7, 2,3,4,6,7
db 1,2,5,6,7, 1,3,5,6,7, 2,3,5,6,7
db 1,4,5,6,7, 2,4,5,6,7, 3,4,5,6,7
card_52 db 01h,02h,03h,04h,05h,06h,07h
db 08h,09h,0ah,0bh,0ch,0dh
db 11h,12h,13h,14h,15h,16h,17h
db 18h,19h,1ah,1bh,1ch,1dh
db 21h,22h,23h,24h,25h,26h,27h
db 28h,29h,2ah,2bh,2ch,2dh
db 31h,32h,33h,34h,35h,36h,37h
db 38h,39h,3ah,3bh,3ch,3dh
mess db ' ** sorry !!! ** $'
db 'one pair $'
db 'two pairs $'
db 'three of a kind $'
db 'straight $'
db 'flush $'
db 'full house $'
db 'four of a kind $'
db 'flush straight $'
db 'flush royal $'
db 07h, '%% data error %% $'
;----------------------------------------------------------
.STACK 1000h
.CODE
main proc far
;
mov ax,@data
mov ds,ax
;
call far ptr cdgen
;
call far ptr check_7
;
call far ptr p_result
;
mov ah,4ch
int 21h
main endp
;
;----------------------------------------------------------
;
check_7 proc far
;
mov [max_prize],0
mov [max_num],0
;
mov cx,21
ckloop1: mov al,05h
mov dl,cl
dec dl
mul dl
mov bx,ax
mov si,5
ckloop2: dec si
mov al,[card_tab + bx + si]
mov di,ax
mov al,[card_7 - 1 + di]
mov [card_5 + si],al
xor si,0
jnz ckloop2
;
call check_5
;
mov ah,[prize]
cmp ah,[max_prize]
jbe nextturn
;
mov [max_prize],ah
mov [max_num],cl
nextturn: loop ckloop1
ret
check_7 endp
;-----------------------------------------------------------------
check_5 proc near
mov [prize],0
mov ah,0fh
call copypure
call sorttemp_5
call compare
cmp [ceq],0
jne setprize
call checkstr
mov ah,30h
call copypure
call compare
cmp [ceq],0fh
jne noflush
cmp1: cmp bh,0
jne cmp2
mov [prize],5
jmp checkexit
cmp2: cmp bh,1
jne cmp3
mov [prize],8
jmp checkexit
cmp3: mov [prize],9
jmp checkexit
noflush: cmp bh,0
je nostraight
mov [prize],4
jmp checkexit
nostraight: mov [ceq],0
setprize: lea bx,pr_tab
mov al,[ceq]
xlat
mov [prize],al
checkexit: ret
check_5 endp
;---------------------------------------------------------------
copypure proc
mov si,5
pureloop: dec si
mov al,[card_5 + si]
and al,ah
mov [temp_5 + si],al
cmp si,0
jne pureloop
ret
copypure endp
;--------------------------------------------------------------
sorttemp_5 proc near
mov si,4
sortloop1: mov al,[ temp_5 + si ]
mov di,0
sortloop2: cmp al,[ temp_5 + di ]
jge sortnext
xchg al,[ temp_5 +di ]
sortnext: inc di
cmp di,si
jne sortloop2
mov [ temp_5 + si ],al
dec si
jnz sortloop1
ret
sorttemp_5 endp
;--------------------------------------------------------------
compare proc
mov [ceq],0
mov si,0
cmploop: mov ah,[temp_5 + si]
xor ah,[temp_5 + si + 1]
jnz cmpnext
mov al,[_mask + si]
or [ceq],al
cmpnext: inc si ;74
cmp si,4
jnz cmploop
ret
compare endp
;--------------------------------------------------------------
checkstr proc near
mov bh,0
mov al,[temp_5 +4]
sub al,[temp_5 +0]
cmp al,4
je addbh
cmp al,12
jne strexit
cmp [temp_5 + si],10
jne strexit
cmp [temp_5 + si],10
jne strexit
inc bh
addbh: inc bh
strexit: ret
checkstr endp
;----------------------------------------------------
p_result proc far
mov bl,[max_prize]
mov al,20
mul bl
lea dx,mess
add dx,ax
mov ah,09h
int 21h
cmp bl,0
je pr_exit
mov bl,[max_num]
dec bl
mov al,05h
mul bl
mov bx,ax
mov ah,02h
mov dl,[card_tab + bx + 0]
or dl,30h
int 21h
mov si,1
prloop: mov dl,","
int 21h
mov dl,[card_tab + bx + si]
or dl,30h
inc si
cmp si,5
jne prloop
pr_exit: ret
p_result endp
;----------------------------------------------------
cdgen proc far
call randomize
mov cx,7
mov dh,52
rndloop: call random
lea bx,card_52
xor ah,ah
add bx,ax
mov ah,[bx]
mov si,cx
mov [card_7 - 1 + si],ah
xchg ah,[card_52 + 44 + si]
mov [bx],ah
dec dh
loop rndloop
ret
cdgen endp
;----------------------------------------------------
randomize proc near
mov ah,2ch
int 21h
shl dh,1
add dl,dh
ret
randomize endp
;----------------------------------------------------
random proc near
mov al,abc
mul dl
add ax,cde
mov dl,al
mul dh
mov al,ah
ret
random endp
END main
這幾天讓人很興奮的是Ubuntu 7.10終於要釋出了!今天已經進入倒數九天了,從倒數十一天起就一直跑去Ubuntu官網晃,關注了兩天終於開放申請索取7.10的光碟,身為Ubuntu的忠實愛好者,當然也要趕緊來參一腳。這次申請選項少了一點,預設的光碟索取組合變得比較『不浪費』,這次預設選項最多2張光碟片,可以選擇兩張PC版的或是選擇PC、64bit版各一張。
有興趣的使用者也可已到https://shipit.ubuntu.com/申請,如果需要地址翻譯的話可以參考台灣郵政網頁提供的轉換服務
題目說明:
等待使用者輸入字母('a'~'z'與'A'~'Z'),並做大小寫轉換。如果使用者輸入小寫字母,則螢幕印出對應的大寫字母,反之印出對應小寫字母,若輸入字母以外的字元則結束程式。
程式流程:
程式碼:
GETCHAR MACRO
mov ah, 01h
int 21h
ENDM
PUTCHAR MACRO
mov ah, 02h
int 21h
ENDM
END_PROCESS MACRO
mov ah, 4ch
int 21h
ENDM
.MODEL SMALL
.CODE
begin: GETCHAR
cmp al, 'A'
jl exit
cmp al, 'Z'
jle upper
cmp al, 'a'
jl exit
cmp al, 'z'
jg exit
sub al, 20h
mov dl, al
PUTCHAR
jmp begin
upper: add al, 20h
mov dl, al
PUTCHAR
jmp begin
exit: END_PROCESS
.STACK
END begin
Googlepedia是FireFox瀏覽器結合google搜尋所出的的個套件。讓使用者在使用FireFox作google搜尋時,可以同時找到維基百科中對應或相關的文章。
在https://addons.mozilla.org/firefox/2517/ 點頁面上的Install Now」後,等安裝完成,再重新啟動FireFox,就可以使用Google搜尋時,同時得到wikipedia的結果。
參考畫面:
step1) 加入金鑰
$ wget -q http://medibuntu.sos-sts.com/repo/medibuntu-key.gpg -O- | sudo apt-key add -
step2) 編輯套件來源
$ sudo gedit /etc/apt/sources.list
加入以下內容
## Medibuntu - Ubuntu 7.04 "feisty fawn"
## Please report any bug on https://launchpad.net/products/medibuntu/+bugs
deb http://medibuntu.sos-sts.com/repo/ feisty free non-free
deb-src http://medibuntu.sos-sts.com/repo/ feisty free non-free
step3) 更新套件列表,安裝Adobe Reader
$ sudo apt-get update && sudo apt-get install acroread
step4.1) 下載繁體中文字型
到http://www.adobe.com/products/acrobat/acrrasianfontpack.html下載
頁面選項版本請選擇Adobe Reader 7、Chinese Traditional、Linux如下圖所示
step4.2) 安裝中文字型
下載後解壓縮,進入解壓縮得到的資料夾,進行安裝
$ sudo ./INSTALL
會問你確定安裝?按y,按Enter鍵
會問接受授權?輸入accept,按Enter鍵
接下來問安裝路徑,複製貼上/usr/lib/Adobe/Acrobat7.0 ,按Enter鍵
PS. Ubuntu預設的文件檢視器本身就可以瀏覽PDF的檔案,不過對於有中文內容的文件就會發生字體被分解、支離破碎的問題。
step1) 安裝gstreamer的解碼器
$ sudo apt-get install gstreamer0.10-ffmpeg gstreamer0.10-plugins-bad gstreamer0.10-plugins-bad-multiverse gstreamer0.10-plugins-ugly gstreamer0.10-plugins-ugly-multiverse
step2) 安裝xine及解碼器
$ sudo apt-get install libxine-extracodecs totem-xine ffmpeg lame faad sox mjpegtools libxine-main1
step3) 安裝w32codecs
先把這一個伺服器位址http://packages.medibuntu.org/ feisty 加入sources.list清單,並且更新
$ echo "deb http://packages.medibuntu.org/ feisty free non-free" | sudo tee -a /etc/apt/sources.list
$ wget -q http://packages.medibuntu.org/medibuntu-key.gpg -O- | sudo apt-key add - && sudo apt-get update
接著就可以用apt-get輕鬆安裝了!
$ sudo apt-get install w64codecs
step4) 其他請參考【Ubuntu】讓ubuntu可以觀看wmv, mpg, rm, asx...等格式的影片
PS. 這在Ubuntu 7.04 64-bit上安裝成功,之前從64bit換回32bit就是w32decodecs搞不定,後來在網路上看到有阿肚仔說這解碼器for 64bit版本的套件名稱叫做w64decodecs,找了一下才發現Medibuntu已經提供Packages...,之前搞了好久的東西想不到只要幾個指令就簡單完成安裝了>"<
這個問題其實困擾我很久了,找了很多種解決方法:在作業階段加入pon dsl-provider指令、改變/etc/resolv.conf的inode資訊等,本來已經習慣開機手動連線了>"< 今天下午不知道哪來的動力又再一次嘗試這些解決方法,才發現自己是如此的豬頭,第一次找到的解決方法就是上上之道了...。
解決方法:
step0) 第一步往往是最重要的一步,要設定ADSL撥接相信大家都一樣很熟巧的知道要使用sudo pppoeconf指令了,重點是在設定的倒數第二步驟會詢問是否開機自動連線,這時候請選擇「否」,這個工作交給下面設定的作業階段自動連線就好,如果選「是」不知道什麼原因在domain name server的設定總會發生錯誤
step1) 點選「系統」→「偏好設定」→「作業階段」
step2) 在「初始啟動程式」頁面,點選「新增」
step3) 名稱隨意輸入(可以輸入有意義名稱比如:ADSL),重點是指令這裡要輸入pon dsl-provider,輸入完畢後點選「確定」就可以了
Ubuntu版Linux創始人Mark Shuttleworth說,戴爾公司不久後將擴大銷售安裝Linux作業系統的個人電腦。
Shuttleworth也是Linux支援服務商Canonical公司的創辦人。他表示,戴爾5月間推出Linux PC後,市場需求不錯,令戴爾相當滿意。
戴爾是世界第二大PC製造商,銷售額僅次於惠普公司。目前戴爾對消費者供應五款採用Ubuntu Linux作業系統的PC。
Shuttleworth上周接受訪問時表示:「目前為止,戴爾所宣布的還不是全貌。未來幾個月,會陸續有更多款Linux PC上市。」
戴爾發言人Anne Camden拒絕評論,只重申戴爾對尚未發表的產品無可奉告。但她強調,戴爾對Linux PC引起的消費者迴響感到欣慰。
諸如Shuttleworth私人擁有的Canonical公司,以及Red Hat和Novell等公司,都靠銷售標準版Linux軟體以及附帶的支援服務獲利。
Shuttleworth表示,他所屬的公司除了與戴爾合作外,並未與惠普或其他名列前五大的PC製造商洽談隨機搭售Ubuntu的合作計畫。全球前五大PC製造商還包括聯想、宏碁與東芝。(唐慧文/譯)
hi.
我是。。。
為什麼會使用Ubuntu?=》
1.我已厭倦每買一PC或NB,就非得被迫買一次窗戶。我又不是要蓋房子,不過就一PC加一NB,有需要那麼多個窗戶嗎?
2.誰說電腦只有窗戶可以用?企鵝,大腳,紅帽子。。也都很可愛。
3.我不想再花時間去當海盜學破解序號,現在學會了,很快就不能用了。那我何必花時間去做無意義的事?寧可把時間花在Linux上,因為現在學會了,以後還是自己的知識。
4.我只是上上網,打打文件,沒事再看影片,聽音樂,何必拿一個龐然大物來找麻煩?
5.我只是一個月光族的上班族,沒有多$$,可以給M$,一天到晚要我升級,要我花$$。
6.我要過“有點硬”的人生,不想再過“有點軟”的生活。
使用感想是什麼?
爽。。爽。。爽。
對新手來說,真的不難學,陣痛期是一定有的,使用窗戶難道沒有陣痛期??你一定也有經過,只是你忘了。
step1) 安裝JRE
$ sudo apt-get install sun-java6-jre
step2) 安裝java-plugin(讓firefox可以瀏覽需要jvm的網頁)
$ sudo apt-get install sun-java6-plugin
step3) 測試安裝是否成功
瀏覽網頁http://java.com/zh_TW/download/help/testvm.xml
如果能看到一個三角形的小玩偶在那邊揮手亂跑就表示成功了!
64位元的使用者請看這篇:【Ubuntu】(for 64位元版本)讓ubuntu可以觀看wmv, mpg, rm, asx...等格式的影片
step1) 安裝gstreamer的解碼器
$ sudo apt-get install gstreamer0.10-pitfdll gstreamer0.10-ffmpeg gstreamer0.10-plugins-bad gstreamer0.10-plugins-bad-multiverse gstreamer0.10-plugins-ugly gstreamer0.10-plugins-ugly-multiverse
step2) 安裝xine及解碼器
$ sudo apt-get install libxine-extracodecs totem-xine ffmpeg lame faad sox mjpegtools libxine-main1
step3) 安裝w32codecs
$ wget -c http://www.debian-multimedia.org/pool/main/w/w32codecs/w32codecs_20061022-0.0_i386.deb
$ sudo dpkg -i w32codecs_20061022-0.0_i386.deb
很多人對於Unix-like作業系統小有好奇心,最常見的作法莫過於在電腦上安裝windows系統(可能選擇Vista、XP、2000、或更舊的版本),然後再安裝虛擬機器(像是VirtualBox、VMware...等)藉此虛擬出一個子作業系統。
上面的方法對於好奇Linux系統的初學者來說,可以說是最佳的作法,幾個月前我也是這樣玩的(畢竟不可能拿系上或實驗室的上線伺服器直接測試),隨著VirtualBox的成熟、穩定,終於讓我在一個月前決定反其道而行,把自家電腦主系統(Host-OS)安裝Ubuntu、子系統(Guess-OS)才用VirtualBox虛擬出來。
這樣玩了將近一個月,我發現要戒掉windows的毒癮其實不難,把windows的操作環境毀掉其實就成功一半了!這意思是想告訴有心轉換作業系統的玩家:別擔心太多,殺了M$公司的作業系統,改安裝免錢、社群龐大的Ubuntu系統吧!如果你跟我一樣擔心毒癮偶爾會發作,就安裝VirtualBox來解決需求。
感覺越來越像在賣藥...,安裝請參考下面步驟:
step1) 先安裝一些相依套件
$ sudo apt-get install libxalan110 libxerces27 build-essential linux-headers-`uname -r`
$ sudo apt-get install libqt3-mt
step2) 到http://www.virtualbox.org/wiki/Downloads下載最新套件(64位元電腦請下載AMD64)
step3) 安裝
$ sudo dpkg -i virtualbox_1.4.0-21864_Ubuntu_feisty_amd64.deb
step4) 將自己(允許可以使用VirtualBox的帳戶)加入vboxusers群組
$ sudo usermod -G vboxusers -a 你的帳號
step5) 重新登入系統後就可以開啟VirtualBox了!
開啟選單:應用程式 -> 系統工具 -> innotek VirtualBox
製作網頁表單常常為了統一使用者輸入日期格式煩惱?一般都是用select標籤來限制使用者或使透過JavaScript檢查使用者輸入的格式是否正確,前幾天在網路上不小心撿到好康的程式(JavaScript Calendar)。
JavaScrip Calendar讓你的網頁可以輕鬆的增加月曆讓使用者方便點選,月曆出現的方式也可以選擇彈跳出新視窗或用浮現在原頁面,選擇完畢後自動將日期填入對應的欄位中,其中日期產生格式也可以由你自訂,是一套十分靈活的JavaScript模組。
參考原著網頁:http://www.dynarch.com/projects/calendar/
使用示範:
step1) 到http://www.dynarch.com/projects/calendar/下載最新版本
step2) 將下載回來的套件解壓縮丟入網頁目錄
step3) 下載範例網頁並將之跟解壓縮的資料夾放在同一層目錄中即可
更多進階使用方法:
解壓縮後資料夾中英該有一個doc子資料夾,裡面有完整的使用說明!
step1) 先到http://www.rarlab.com/download.htm下載RAR for Linux
step2) 將下載回來的檔案解壓縮
$ tar zxvf 檔名
step3) 把解壓縮得到的幾個檔案丟到/usr/local/bin目錄下就可以了
$ sudo mv default.sfx rar rar_static unrar /usr/local/bin/
PS. 系統內的解壓縮軟體就可以正確解壓縮RAR檔!!
安裝pure-ftpd with MySQL
$ sudo apt-get install pure-ftpd-mysql
切換到網頁目錄
$ cd /var/www
下載PureFTPd網頁管理系統(系統需支援PHP)
$ wget http://machiel.generaal.net/files/pureftpd/ftp_v2.1.tar.gz
(可以到http://machiel.generaal.net/查詢是否有新版的管理系統)
解壓縮下載的套件
$ tar zxvf ftp_v2.1.tar.gz
開啟瀏覽器, 輸入網址:
http://你的ip/ftp/install.php
接著照網頁提示依序完成每個步驟就可以了
最後會提示修改檔案mysql.conf
首先切換到檔案所在的目錄
$ cd /etc/pure-ftpd/db
先備份原先的設定檔
$ sudo mv mysql.conf mysql.conf.bak
將管理系統網頁step6頁面所提示要修改的內容全部複製起來
建立設定檔mysql.conf並貼上複製的內容
$ sudo vi mysql.conf
重新啟動Pure-FTPd伺服器
$ sudo pure-ftpd-control restart
開啟網頁編輯ftp使用者
http://你的ip/ftp
登入後即可管理ftp使用者
PS1.
出現錯誤 Checking if config.php is writable Failed!
解決=>將ftp目錄下的config.php改為可寫入即可
PS2.
出現錯誤 Checking if PHP Extension MYSQL is enabled Failed!
解決=>確定是否已安裝php5-mysql套件
PS3.
避免日後遭受駭客攻擊, 設定完畢後應該刪除ftp目錄下的install.php檔案
安裝JAVA執行環境jre
sudo apt-get install sun-java5-jre
安裝JAVA開發套件jdk
sudo apt-get install sun-java6-jdk
網路上看到有人解釋下面這指令是:設置當前預設的java解釋器
sudo update-alternatives --config java
(選2, 選項中有sun字串者)
抓取tomcat套件(可以到http://tomcat.apache.org/download-60.cgi找最新套件)
wget http://apache.stu.edu.tw/tomcat/tomcat-6/v6.0.13/bin/apache-tomcat-6.0.13.tar.gz
移到/opt下
sudo mv apache-tomcat-6.0.13.tar.gz /opt/
cd /opt
sudo tar zxvf apache-tomcat-6.0.13.tar.gz
sudo mv apache-tomcat-6.0.13 tomcat
編輯檔案/etc/profile
sudo vi /etc/profile
加入以下敘述
export JAVA_HOME=/usr/lib/jvm/java-6-sun
啟動apache-tomcat
sudo /opt/tomcat/bin/startup.sh
如果出現以下指令, 則伺服器成功啟動!
Using CATALINA_BASE: /opt/tomcat
Using CATALINA_HOME: /opt/tomcat
Using CATALINA_TMPDIR: /opt/tomcat/temp
Using JRE_HOME: /usr/lib/jvm/java-6-sun
apache-tomcat預設開啟的服務port是8080
因此開啟網頁記得指定port, 參考下面格式
http://你的ip:8080
新增tomcat管理帳號
sudo vi /opt/tomcat/conf/tomcat-users.xml
在<tomcat-users>與≶/tomcat-users>之間加入以下敘述
<user username="用戶名" password="密碼" roles="admin,manager"></user>
再重新啟動apache-tomcat即可
sudo /opt/tomcat/bin/shutdown.sh
sudo /opt/tomcat/bin/startup.sh
即可點選http://你的ip:8080
左方選單Tomcat Manager項目進入管理伺服器
修改伺服器服務的port為80
sudo vi /opt/tomcat/conf/server.xml
找到<connector port="8080" protocol="HTTP/1.1"></connector>敘述
修改成<connector port="80" protocol="HTTP/1.1"></connector>
再重新啟動apache-tomcat即可
sudo /opt/tomcat/bin/shutdown.sh
sudo /opt/tomcat/bin/startup.sh
修改port為80後開啟網頁就不必另外指定port了
直接輸入網址及可
http://你的ip
【關鍵字:Ubuntu、Apache-tomcat、伺服器套件安裝、網頁伺服器】
問題:
假若給一字串abc , 寫一程式能夠印出其所有的排列組合
abc acb bac bca cba cab
想法:
n為字串長度
讓所有字元皆出現在第n位置一次
abc
acb
cba
接著分n組個別探討,此時第n位置已固定
m為剩下字元,讓剩下所有字元皆出現在第m位置一次
依此類推,當n為1時直接印出字串,即完成。
用C語言實作:
#include <stdio.h>
void p(char *str, int n) {
char ch ;
int i ;
if(n==1) {
printf("%s\n", str) ;
}
else {
for(i=n-1 ; i>=0 ; i--) {
ch = *(str+i) ;
*(str+i) = *(str+n-1) ;
*(str+n-1) = ch ;
p(str, n-1) ;
ch = *(str+i) ;
*(str+i) = *(str+n-1) ;
*(str+n-1) = ch ;
}
}
}
int main() {
char ch[] = "abcd" ;
p(ch, 4) ;
system("pause") ;
return 0 ;
}