公告版位
若有資料錯誤請不吝指教。

在這篇主要是想要來分享自己的一個習慣

Notepad++ 的 Nppexec 可以對目前編輯的檔案,執行你腳本所定義的事情

於是,我就希望 Nppexec 也可以快速的察看 PHP 的執行結果

但是研究了 Nppexec 的說明文件之後

發現必須要寫一隻小程式,才能夠達到我的要求

( 也就是按了 Ctrl + F6 之後,我的預設瀏覽器,可以開啟該網頁 )

( http://127.0.0.1/...... )

現在來分享給大家我的作法。

首先,先簡介一下,我使用的環境是 ( Windows 7 + Appserv 2.6.0 )

我是把我自己的電腦當作測試伺服器使用,網頁寫好才放到正式伺服器

在 Notepad++ 裡面安裝了 Nppexec 之後,按下 F6,貼入以下指令

NPP_CONSOLE ?
npp_save
set PHP_www = D:\Dropbox\wwwhtml\
set PHP_url = http://127.0.0.1/
set PHP_open = D:\Dropbox\Public\program\NppExecPHPopen.exe
cmd.exe /c ""$(PHP_open)" "$(PHP_www)\" "$(PHP_url)" "$(FULL_CURRENT_PATH)""

簡單說明一下這段代碼

NPP_CONSOLE ?

這個是保留目前 Notepad++ 的 CONSOLE 開啟狀態,因為 CONSOLE 對 PHP 沒用

所以用這個指令可以讓 Notepad++ 不自動開啟 CONSOLE

npp_save 是幫你把目前的檔案儲存

再來的三個 set 指令都是設定變數

其中 PHP_www 是伺服器預設之網站資料夾,請改成你自己的路徑

PHP_url 是網頁開啟時要打的基本 URL,這個也一樣要改成自己的設定

例如你的伺服器不是開 80 port 的話,可以改成 http://127.0.0.1:8080/ (例如 tomcat )

再來 PHP_open 就是我寫的小程式了

這隻程式可以在 http://dl.dropbox.com/u/12113131/program/NppExecPHPopen.exe 抓到

抓下來之後,找一個地方放著,再把路徑設定給 PHP_open

最後的 cmd.exe 就是開啟這個網頁啦~~

( p.s. 這隻程式是我自己用 C++ 寫的

如果對這隻程式不放心,可以自己寫一個

原始碼可以在底下的連結抓到

https://www.dropbox.com/s/3t7afqz6gk3iv0z/NppExecPHPopen.cpp )

o932859222 發表在 痞客邦 留言(0) 人氣()

新增 jQuery 語法

javascript: var head= document.getElementsByTagName('head')[0]; var script= document.createElement('script'); script.type= 'text/javascript'; script.src= '//ajax.googleapis.com/ajax/libs/jquery/1/jquery.js'; head.appendChild(script);

[將我加入書籤]

配合 Chrome 可以利用 F12 來快速指定指令。

o932859222 發表在 痞客邦 留言(0) 人氣()

hyper-V 是在 Windows Server 2008 R2 上的虛擬主機程式,

由於工作上的需求,我開始使用這套系統,

這個東西對我來說,也是第一次碰到。

在安裝 CentOS 6 之前,有先裝過一個 Windows Server 2008 R2 的 Client,

支援度還不錯,用得很開心 :)

但是在莊 CentOS 6 時,就開始出現了一大堆問題...

先稍微提一下環境的設定,

由於主機是放機房內,所以要管理只能夠使用遠端軟體,

但是一使用遠端之後才發現,

CentOS 出現了一大堆問題...

首先,滑鼠無法使用...  (圖形介面沒滑鼠真的不知道該怎麼用...)

然後,CentOS 也抓不到網卡 (我想要 yum update 都沒辦法的說...)


滑鼠無法使用,所以我第一個想到的就是,先看看能不能開遠端

使用 putty 連進去指令介面,

(不知為何無法使用 Ctrl + Alt + F? 切換到指令介面,可能是遠端軟體把組合鍵吃掉了)

可是就不小心發現,連網卡也抓不到,

沒有網路也別想使用 ssh 連線...

所以就開始瘋狂 Google...

我有找過網路問題,但是我用 Windows Server 2008 R2 的 Client 試過可以用,

CentOS 圖形化介面 沒辦法用滑鼠,整個就是不知道該如何處理起

後來偶然之下,試出來按 Alt + F1 可以跳到主選單上

於是 終於可以成功地開啟終端機介面


由於之前玩過虛擬機器

所以大概知道,玩虛擬機器都要灌整合服務

可是我卻發現 hyper-v 的【插入整合服務安裝磁片】給的是 for Windows 的安裝檔

而且他並不會自動幫你 mount 起來

( 真的是爛到爆炸... 怒!!! )

在網路上 Google 了很久,有看到很多人有提到

Windows 有提供整合服務(Integration Services)可供下載

可是那些文章的連結不是失連,

就是版本太舊無法安裝

( 為什麼不是hyper-V內建,生氣....)

害我還從 2.0 開始試,2.1 -> 2.2 -> 3.0 -> .....

前面版本的還要你自己 make

但是我 CentOS 又沒有網卡,該怎麼裝 gcc ...

後來有找到辦法,原來可以從 CentOS 的安裝光碟內安裝

/etc/yum/repo.d/CentOS-Media.repo,詳細教學文章如此

可惜,這個並沒有成功的在 CentOS 6.3 安裝整合服務

後來 我是找到了 Linux Integration Services Version v3.3 for Hyper-V 才安裝成功

( 微軟自己的搜尋是怎麼樣...都搜尋不到最新版,一直給我 v2.1 是怎樣....真的是爛爆了 )

(為了防止網址失效,備份載點在此 hyper-V_CentOS_Integration_Services_v3.3.iso )

於是,終於可以成功的使用了滑鼠

以及成功的抓到了網卡

終於可以像真的 CentOS 系統一樣了

( 我為了這個問題,處理了十幾個小時, hyper-V 還我這些光陰阿~~ )


在裝好整合服務之後,需要依照說明文件設定網路卡

在設定好之後,不知為何還需要手動 service network restart

在網路也處理好之後

就可以進行其他的工作啦

但是請注意 不要手癢打了 yum update ,

因為現在整合服務只支援到 CentOS 6.2

如果下了 yum update ,會直接更新到 CentOS 6.3

然後就會打不開了 (害我整個流程又都重跑一遍 QAQ )


2012 年 07 月 27 日 By 和風信使

o932859222 發表在 痞客邦 留言(0) 人氣()

更新日期:2012/06/22 (原網頁:Jul 18, 2011)


Google Refine 是什麼?

查看 這些影片(英文) 來簡單了解 Google Refine 能夠做到什麼事情

看看大家對於 Google Refine 的一些 用法和評論(英文)

開始:

如何安裝 Google Refine (英文)

給使用者的 說明文件(英文)

尋找幫助:

網上論壇(英文) 提出問題

在此提出 想要的功能 or 程式錯誤 (英文)

曾經安裝過舊的版本?

看看最近的更新項目(英文)

查看 該如何備份 以便從 Google Refine 2.0 升級至 Google Refine 2.1

如果你是開發者,請看

給開發者的 說明文件(英文)

文章標籤

o932859222 發表在 痞客邦 留言(0) 人氣()

/*
    mkfifo fifo1
    mkfifo fifo2
    echo "test" > fifo1
*/
#include<stdlib.h>
#include<stdio.h>
#include<string.h>
#include<sys/select.h>
#include<limits.h>
#include<unistd.h>
#include<fcntl.h>
#include <sys/time.h>
#include <sys/types.h>
#include <unistd.h>

int main()
{
    char buffer[PIPE_BUF];
    int fd1 = open("fifo1",O_RDWR | O_NONBLOCK);
    int fd2 = open("fifo2",O_RDWR | O_NONBLOCK);
    int maxfd=fd1;
    if(maxfd<fd2)maxfd=fd2;
    maxfd++;
    printf("fd1=%d, fd2=%d, maxfd=%d",fd1,fd2,maxfd);
    fd_set fdSet;
    struct timeval tv;
    
    while(1)
    {
        FD_ZERO(&fdSet);
        tv.tv_sec=3;
        tv.tv_usec=0;
        FD_SET(fd1,&fdSet);
        FD_SET(fd2,&fdSet);
        memset(buffer,0,sizeof(buffer));
        int ready=select(maxfd,&fdSet,NULL,NULL,&tv);
        if(ready==-1)
        {
            printf("failure\n");
            continue;
        }
        if(ready==0)
        {
            printf("Timeout\n");
            continue;
        }
        if(FD_ISSET(fd1,&fdSet))
        {
            read(fd1,&buffer,sizeof(buffer));
            printf("Device 1: %s\n",buffer);
        }
        if(FD_ISSET(fd2,&fdSet))
        {
            read(fd2,&buffer,sizeof(buffer));
            printf("Device 2: %s\n",buffer);
        }
    }
    close(fd1);
    close(fd2);
}

o932859222 發表在 痞客邦 留言(0) 人氣()

轉自:http://60.248.128.85/bbs/dv_rss.asp?s=xhtml&boardid=63&id=491&page=3

這是一篇程式員寫給程式員的趣味讀物。所謂趣味是指可以比較輕鬆地瞭解一些原來不清楚的概念,增進知識,類似於打RPG遊戲的升級。整理這篇文章的動機是兩個問題:

問題一:

使用Windows記事本的「另存為」,可以在GBK、Unicode、Unicode big endian和UTF-8這幾種編碼方式間相互轉換。同樣是txt文件,Windows是怎樣辨識編碼方式的呢?

我很早前就發現Unicode、Unicode big endian和UTF-8編碼的txt文件的開頭會多出幾個字元,分別是FF、FE(Unicode),FE、FF(Unicode big endian),EF、BB、BF(UTF-8)。但這些標記是基於什麼標準呢?

問題二:
最近在網上看到一個ConvertUTF.c,達到了UTF-32、UTF-16和UTF-8這三種編碼方式的相互轉換。對於Unicode(UCS2)、GBK、UTF-8這些編碼方式,我原來就瞭解。但這個程式讓我有些糊塗,想不起來UTF-16和UCS2有什麼關係。

查了查相關資料,總算將這些問題弄清楚了,順帶也瞭解了一些Unicode的細節。寫成一篇文章,送給有過類似疑問的朋友。本文在寫作時盡量做到通俗易懂,但要求讀者知道什麼是字元,什麼是十六進制。

0、big endian和little endian

big endian和little endian是CPU處理多字元數的不同方式。例如「漢」字的Unicode編碼是6C49。那麼寫到文件裡時,究竟是將6C寫在前面,還是將49寫在前面?如果將6C寫在前面,就是big endian。還是將49寫在前面,就是little endian。

「endian」這個詞出自《格列佛遊記》。小人國的內戰就源於吃雞蛋時是究竟從大頭(Big-Endian)敲開還是從小頭(Little-Endian)敲開,由此曾發生過六次叛亂,其中一個皇帝送了命,另一個丟了王位。

我們一般將endian翻譯成「字元序」,將big endian和little endian稱作「大尾」和「小尾」。

1、字元編碼、內碼,順帶介紹中文字編碼

字元必須編碼後才能被電腦處理。電腦使用的缺省編碼方式就是電腦的內碼。早期的電腦使用7位的ASCII編碼,為了處理中文字,程式員設計了用於簡體中文的big5和用於繁體中文的big5。

big5(1980年)一共收錄了7445個字元,包括6763個中文字和682個其它符號。中文字區的內碼範圍高字元從B0-F7,低字元從A1-FE,佔用的碼位是72*94=6768。其中有5個空位是D7FA-D7FE。

big5支援的中文字太少。1995年的中文字擴展規範GBK1.0收錄了21886個符號,它分為中文字區和圖形符號區。中文字區包括21003個字元。2000年的GB18030是取代GBK1.0的正式國家標準。該標準收錄了27484個中文字,同時還收錄了藏文、蒙文、維吾爾文等主要的少數民族文字。現在的PC平台必須支援GB18030,對嵌入式產品暫不作要求。所以手機、MP3一般只支援big5。

從ASCII、big5、GBK到GB18030,這些編碼方法是向下兼容的,即同一個字元在這些方案中總是有相同的編碼,後面的標準支援更多的字元。在這些編碼中,英文和中文可以統一地處理。區分中文編碼的方法是高字元的最高位不為0。按照程式員的稱呼,big5、GBK到GB18030都屬於雙字元字元集 (DBCS)。

有的中文Windows的缺省內碼還是GBK,可以透過GB18030升級包升級到GB18030。不過GB18030相對GBK增加的字元,普通人是很難用到的,通常我們還是用GBK指代中文Windows內碼。

這裡還有一些細節:

  • big5的原文還是區位碼,從區位碼到內碼,需要在高字元和低字元上分別加上A0。

  • 在DBCS中,GB內碼的存儲格式始終是big endian,即高位在前。

  • big5的兩個字元的最高位都是1。但符合這個條件的碼位只有128*128=16384個。所以GBK和GB18030的低字元最高位都可能不是1。不過這不影響DBCS字元流的解析:在讀取DBCS字元流時,只要遇到高位為1的字元,就可以將下兩個字元作為一個雙字元編碼,而不用管低字元的高位是什麼。

2、Unicode、UCS和UTF

前面提到從ASCII、big5、GBK到GB18030的編碼方法是向下兼容的。而Unicode只與ASCII兼容(更準確地說,是與ISO-8859-1兼容),與GB碼不兼容。例如「漢」字的Unicode編碼是6C49,而GB碼是BABA。

Unicode也是一種字元編碼方法,不過它是由國際組織設計,可以容納全世界所有語言文字的編碼方案。Unicode的學名是"Universal Multiple-Octet Coded Character Set",簡稱為UCS。UCS可以看作是"Unicode Character Set"的縮寫。

根據維基百科全書(http://zh.wikipedia.org/wiki/)的記載:歷史上存在兩個試圖獨立設計Unicode的組織,即國際標準化組織(ISO)和一個軟體製造商的協會(unicode.org)。ISO開發了ISO 10646項目,Unicode協會開發了Unicode項目。

在1991年前後,雙方都認識到世界不需要兩個不兼容的字元集。於是它們開始合併雙方的工作成果,並為創立一個單一編碼表而協同工作。從Unicode2.0開始,Unicode項目採用了與ISO 10646-1相同的字庫和字碼。

目前兩個項目仍都存在,並獨立地公佈各自的標準。Unicode協會現在的最新版本是2005年的Unicode 4.1.0。ISO的最新標準是10646-3:2003。

UCS規定了怎麼用多個字元表示各種文字。怎樣傳輸這些編碼,是由UTF(UCS Transformation Format)規範規定的,常見的UTF規範包括UTF-8、UTF-7、UTF-16。

IETF的RFC2781和RFC3629以RFC的一貫風格,清晰、明快又不失嚴謹地描述了UTF-16和UTF-8的編碼方法。我總是記不得IETF是Internet Engineering Task Force的縮寫。但IETF負責維護的RFC是Internet上一切規範的基礎。

3、UCS-2、UCS-4、BMP

 

UCS有兩種格式:UCS-2和UCS-4。顧名思義,UCS-2就是用兩個字元編碼,UCS-4就是用4個字元(實際上只用了31位,最高位必須為0)編碼。下面讓我們做一些簡單的數學遊戲:

UCS-2有2^16=65536個碼位,UCS-4有2^31=2147483648個碼位。

UCS-4根據最高位為0的最高字元分成2^7=128個group。每個group再根據次高字元分為256個plane。每個plane根據第3個字元分為256行 (rows),每行包含256個cells。當然同一行的cells只是最後一個字元不同,其餘都相同。

group 0的plane 0被稱作Basic Multilingual Plane, 即BMP。或者說UCS-4中,高兩個字元為0的碼位被稱作BMP。

將UCS-4的BMP去掉前面的兩個零字元就得到了UCS-2。在UCS-2的兩個字元前加上兩個零字元,就得到了UCS-4的BMP。而目前的UCS-4規範中尚未任何字元被分配在BMP之外。

4、UTF編碼

 

UTF-8就是以8位為單元對UCS進行編碼。從UCS-2到UTF-8的編碼方式如下:

 

UCS-2編碼(16進制) UTF-8 字元流(二進制)
0000 - 007F 0xxxxxxx
0080 - 07FF 110xxxxx 10xxxxxx
0800 - FFFF 1110xxxx 10xxxxxx 10xxxxxx

 

例如「漢」字的Unicode編碼是6C49。6C49在0800-FFFF之間,所以肯定要用3字元模板了:1110xxxx 10xxxxxx 10xxxxxx。將6C49寫成二進制是:0110 110001 001001, 用這個比特流依次代替模板中的x,得到:11100110 10110001 10001001,即E6 B1 89。

讀者可以用記事本測試一下我們的編碼是否正確。

UTF-16以16位為單元對UCS進行編碼。對於小於0x10000的UCS碼,UTF-16編碼就等於UCS碼對應的16位無符號整數。對於不小於0x10000的UCS碼,定義了一個算法。不過由於實際使用的UCS2,或者UCS4的BMP必然小於0x10000,所以就目前而言,可以認為UTF-16和UCS-2基本相同。但UCS-2只是一個編碼方案,UTF-16卻要用於實際的傳輸,所以就不得不考慮字元序的問題。

5、UTF的字元序和BOM

UTF-8以字元為編碼單元,沒有字元序的問題。UTF-16以兩個字元為編碼單元,在解釋一個UTF-16文本前,首先要弄清楚每個編碼單元的字元序。例如收到一個「奎」的Unicode編碼是594E,「乙」的Unicode編碼是4E59。如果我們收到UTF-16字元流「594E」,那麼這是「奎」還是「乙」?

Unicode規範中推薦的標記字元順序的方法是BOM。BOM不是「Bill Of Material」的BOM表,而是Byte Order Mark。BOM是一個有點小聰明的想法:

在UCS編碼中有一個叫做"ZERO WIDTH NO-BREAK SPACE"的字元,它的編碼是FEFF。而FFFE在UCS中是不存在的字元,所以不應該出現在實際傳輸中。UCS規範建議我們在傳輸字元流前,先傳輸字元"ZERO WIDTH NO-BREAK SPACE"。

這樣如果接收者收到FEFF,就表明這個字元流是Big-Endian的;如果收到FFFE,就表明這個字元流是Little-Endian的。因此字元"ZERO WIDTH NO-BREAK SPACE"又被稱作BOM。

UTF-8不需要BOM來表明字元順序,但可以用BOM來表明編碼方式。字元"ZERO WIDTH NO-BREAK SPACE"的UTF-8編碼是EF BB BF(讀者可以用我們前面介紹的編碼方法驗證一下)。所以如果接收者收到以EF BB BF開頭的字元流,就知道這是UTF-8編碼了。

Windows就是使用BOM來標記文本文件的編碼方式的。

6、進一步的參考資料

本文主要參考的資料是 "Short overview of ISO-IEC 10646 and Unicode" (http://www.nada.kth.se/i18n/ucs/unicode-iso10646-oview.html)。

我還找了兩篇看上去不錯的資料,不過因為我開始的疑問都發現了答案,所以就沒有看:

  1. "Understanding Unicode A general introduction to the Unicode Standard" (http://scripts.sil.org/cms/scripts/page.php?site_id=nrsi&item_id=IWS-Chapter04a)
  2. "Character set encoding basics Understanding character set encodings and legacy encodings" (http://scripts.sil.org/cms/scripts/page.php?site_id=nrsi&item_id=IWS-Chapter03)

我寫過UTF-8、UCS-2、GBK相互轉換的軟體包,包括使用Windows API和不使用Windows API的版本。以後有時間的話,我會整理一下放到我的個人首頁上(http://fmddlmyy.home4u.china.com)。

我是想清楚所有問題後才開始寫這篇文章的,原以為一會兒就能寫好。沒想到考慮措辭和查證細節花費了很長時間,竟然從下午1:30寫到9:00。希望有讀者能從中受益。

o932859222 發表在 痞客邦 留言(0) 人氣()

/dev/hda1 / ext4 8191MB

/dev/hda2 swap 512MB

/dev/hda3 /home ext4 1024MB

Free Free 521MB

使用VirtualBox架設,開始練習鳥哥!!

 


 

剛剛發生了一個小小的疑問點

就是我剛剛打vi可以執行,可是打vim時卻跳出找不到,然後自動上網下載套件,結果下載完,兩個東西顯示的畫面完全一模一樣,這是怎麼回事??

和風信使 發表在 痞客邦 留言(0) 人氣()

 

一、基本概念
  一.OS 之定義
    OS 為使用者和硬體溝通的介面,並滿足:
    1. efficiency (有效率的管理資源)
    2. user friendly (友善的使用者介面)
  二.job 的種類
    1. CPU Bound
      需 CPU 之比例大於需 I/O 之比例。例:科學計算 
    2. I/O Bound
      需 I/O 之比例大於需 CPU 之比例。例:列印
    (note)CPU 要挑選 I/O Bound 的工作優先執行;I/O 設備要挑選 CPU Bound 工作優先執行。
  三.各種 system
    1. Batch(批次)
      1- 定義:將相同或類似的 job 集中一次讓 CPU 處理。
      2- 目標:為了提高 CPU 的效率。
      3- 缺點:不適合交談式的環境。例:提款機
    2. multiprogramming
      1- 定義:允許在 memory 中同時存在多個 process。
      2- 目標:為了提高 CPU 的效率。
      3- 方法:當某個 process 需等候 I/O 或等候某個事件發生,為了避免 CPU idle,CPU 選擇其他 process 來執行。
    3. time sharing
      1- 定義:為 multiprogramming 的一種,在選擇 process 時使用 round-robin,即每一個 process 只能用 CPU 一個 time slice,一但時間到了,就切換給其他 process。
      2- 優點:適合用在交談式和多使用者的環境。
  四.distributed system
    1. tightly-coupled
      1- 有很多 CPU
      2- 共用 memory、OS 和週邊設備
      3- CPU 採用 share memory
      4- 依 CPU 能力分兩種: 
        a. symmetric (CPU 能力相同)
        b. asymmertric (CPU 能力不同)
    2. loosely-coupled
      1- 每個 CPU 有自己的 OS、memory 和週邊設備
      2- 溝通用網路和 message passing 
      3- 分兩種:
        a.client-server:client 和 server 要求 service 
        b.peer to peer:在 network 上能力相同,可接受 service,也可提供 service。
  五.real time system
    1.特徵:在此系統中,對於完成 process 之 time 有嚴格限制。
    2.分兩種:
      1- soft:確保優先權高之 job 最先被完成。
      2- hard:在限時內必完成,否則視為失敗。


二、系統架構 
  一.處理 I/O 的形式
    當某個正在擁有 CPU 資源之 process p,要作 I/O,系統的處理方式:
    1.輪詢式(polling)
      cons:CPU 會花很多時間檢查 I/O,花較少時間在 process 上。
      此法適合慢速 I/O 設備。例:printer,keyboard,mouse。
    2.Interrupt I/O
      I/O 完成時發出 "I/O complete" 給 OS,以提示進行下一步動作。
    3.DMA (Direct Memory Access)
      1.DMA controler 負責 CPU 和 memory 間傳輸,不需 CPU 參與監督,CPU 使用率上升。
      2.適合高效率的 I/O device。例:disk
      3.利用 cycle stealing 技巧。
        在 CPU 一定不會 access memory 之 cycle,才作 memory 與 I/O 之間的傳輸。


三、Interrupt 探討
  一.Interrupt 分類
    1.Interal:CPU 本身執行到不合法的指令時發出。例:除以零。
    2.external:CPU 外之 device 發出。例:I/O complete。
    3.software:User Program 要 OS 提供服務時,才發出此種中斷。(systme call)
  二.Interrupt 與 Trap(含要求 service 和運算有誤)
    前者是由硬體發出,後者是由軟體發出。
  三.Interrupt 是以階層方式執行的。(priority hierarchy)


四.系統保護
  一.保護實施之前提:dual mode
  二.I/O 保護:避免 I/O device 被不當使用,將所有 I/O operation 設為特權指令。
  三.CPU 保護:避免 CPU 被 Process 無限期佔用。
    幫正在使用 CPU 的 Process 設定 timer 倒數,待時間到強制釋放 CPU。
  四.Memory 保護:
    避免 Process 使用不屬於自己的 memory 空間。使用 base reg 和 limit reg,若存取之 memory address:
    1.小於 base reg
    2.大於 base reg + limit reg
    則視為非法存取。
五.Virtual Mechine
  (待續) 

 

o932859222 發表在 痞客邦 留言(0) 人氣()

    在開始寫程式前,要先準備好編譯器,才能把程式碼轉換成程式加以執行。Dev-C++是一個免費的編譯程式,在章魚教學網中,可以從 “電腦教學→檔案下載” 中下載到。程式寫好後,按F9進行存檔並編譯,就可以看到程式的結果囉!附註:驗證密碼為"chsh"


相關前置設定:

1.改成中文介面
   若你的Dev-C++的介面是英文的,可以照此步驟改成中文。
   「Tools」->「Environment Options」->「Interface」分頁->「Language」->「Chinese(TW)」->「確定(O)」

2.取消智慧型Tab
   智慧型Tab雖然有它的好用之處,可是它也是造成程式碼排版亂掉的一個設定,對於初學者來說,排版可能不是那麼重要,可是,在等到你必須寫到大型程式的時候,排版就是不可或缺的東西,建議把取消智慧型Tab取消,以方便排版。依照下列步驟即可取消智慧型Tab。
    「工具(T)」->「編輯器選項(E)」->「一般」分頁->取消勾選「智慧型Tab」->「確定(O)」

3.開啟行號的顯示
   開啟行號的用處在於請教他人的時後會比較方便,你只要把檔案用即時通或msn傳給會的人,然後就可以用行號來指正錯誤了。依照下列步驟即可開啟行號的顯示。
   「工具(T)」->「編輯器選項(E)」->「顯示」分頁->「輔助資訊區」->勾選「顯示行號」->「確定(O)」

4.設定預設程式碼
   設定預設程式碼,可以在每次開新檔案的時候,自動打好預設程式碼,節省一小段時間。依照下列步驟即可設定預設程式碼。
   「工具(T)」->「編輯器選項(E)」->「程式碼」分頁->底下「預設程式碼」分頁->打入所需的預設程式碼(以下有一個範例)

o932859222 發表在 痞客邦 留言(0) 人氣()

 

一、詞類
  1.名詞(N)
    泛指人、事、時、地、物等名稱。
  2.代名詞(pro)
    用以代替名詞之詞。
  3.形容詞(adj)
    用以修飾名詞或代名詞之字,分為限定和補述語法。
    例:Sam is a happy boy.
        He looks young for his age.
  4.動詞(V)
    用以表示動作、狀態之詞。
  5.連接詞(conj)
    用以連接單字、片語、子句或句子之字。
    例:He is good at English and Japanese.
        When I was a child, I was fat.
  6.介係詞(pre)
    放於名詞之前,用以表示該名詞與前面其他字詞之間的關係。
  7.感嘆詞
    用以表示情緒反應或情感所發出的聲音。
    e.g. Ouch!
二、片語
  由兩個以上的單字組成。 
  1.名詞片語
    可當主詞或受詞用。
    例:She is fond of reading novels.
        To keep early hours makes us healthy.
  2.形容詞片語
    用法如同形容詞,用以修飾名詞。
    例:The girl with pearl earrings is pretty.
  3.副詞片語
    如同副詞,用以修飾動詞、形容詞、副詞或一整句話。
三、子句
  含主詞、動詞,可為句子之一部分,但非獨立之句子。
四、英文五大基本句型
  1. S + Vi
    此類動詞不及於物或人,動詞本身就可表達完整意思,不需受詞或補語,但可用副詞修飾。
    e.g.rise,ring,come,fall,happen
    例:Nothing happen.
        When spring comes, many beautiful flowers bloom in the gardon. 
  2. S + Vi + Sc
    動詞本身尚無法表達完整意思,需補語補充說明主詞。
    e.g.
      A.be V (可接 adj,n,地方 adv)
      B.become,turn,appear,seem,remain (可接 adj,n)
      C.go,get,graw,fall,come,run 及感官動詞 (可接 adj)
    例:I'm in Taipei.
        He is ugly.
        Andy become popular with his classmates.
        Sandra become a teacher.
        The soup taste good.
  3. S + Vt + O
    動詞可及於人或物,需受詞使句意完整。 
    e.g.love,have,enjoy,do
    例:We learn English from an American teacher.
        The result disappointed me.
  4. S + Vt + IO + DO
    需兩個受詞才使句意完整清楚。 
    e.g.give,bring,send,show
    例:Show me the money.
        Please read me a story.
        Give me a hand.
    (note)
      to:send,show,lend,read,sing,bring,teach,tell
      for:make,buy,cook,do,sing,brind
      of:ask
  5. S + Vt + O + OC 
    動詞除了需要受詞之外,還需要受詞補語才能使句意完整,受詞補語通常為形容詞或名詞。 
    e.g.make,find,keep,see,consider,have
    例:Tom named his new boat Titanic.
        The American people elected Bush President.
        They warmed me not to come late.

 

o932859222 發表在 痞客邦 留言(0) 人氣()