Linux正在成為開發(fā)人員的編程天堂,成為開源和免費(fèi)操作系統(tǒng)。 Turbo C編譯器已經(jīng)是一種編譯程序的舊方法,所以讓程序員轉(zhuǎn)向Linux以獲得新的編程環(huán)境。 在本文中,我們將解釋如何編寫,編譯和運(yùn)行一個簡單的C程序。 這將成為您遷移到可以在Linux上編寫和執(zhí)行的更復(fù)雜和有用的C程序的基礎(chǔ)。
創(chuàng)新互聯(lián)建站是一家集網(wǎng)站建設(shè),呼倫貝爾企業(yè)網(wǎng)站建設(shè),呼倫貝爾品牌網(wǎng)站建設(shè),網(wǎng)站定制,呼倫貝爾網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,呼倫貝爾網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。
我們在Ubuntu 18.04 LTS系統(tǒng)上運(yùn)行了本文中提到的步驟和命令。
我們將使用Linux命令行工具Terminal,以編譯一個簡單的C程序。 要打開終端,您可以使用Ubuntu Dash或Ctrl + Alt + T快捷方式。
第1步:安裝build-essential軟件包
為了編譯和執(zhí)行C程序,您需要在系統(tǒng)上安裝必要的軟件包。 在Linux終端中以root用戶身份輸入以下命令:
sudo apt-get install build-essential
系統(tǒng)會要求您輸入root用戶密碼; 安裝過程將在此之后開始。 請確保您已連接到互聯(lián)網(wǎng)。
第2步:編寫一個簡單的C程序
安裝必要的軟件包之后,讓我們編寫一個簡單的C程序。
打開Ubuntu的圖形文本編輯器,將以下示例程序?qū)懭牖驈?fù)制到其中:
#include
int main()
{
printf("nA sample C program ");
return 0;
}
然后使用.c擴(kuò)展名保存文件。 在這個例子中,我將我的C程序命名為linuxidc.c
或者,您可以通過gedit中的終端編寫C程序,如下所示:
gedit linuxidc.c
這將創(chuàng)建一個.c文件,您可以在其中編寫和保存程序。
第3步:使用gcc編譯C程序
在終端中,輸入以下命令以生成您編寫的程序的可執(zhí)行版本:
句法:
$ gcc [programName].c -o programName
示例:
$ gcc linuxidc.c -o linuxidc
liunx是系統(tǒng),你學(xué)linux一般就是學(xué)習(xí)使用系統(tǒng)而已,難道是要開發(fā)linux嗎?
linux有圖形界面版和命令行版,一般服務(wù)器就是命令行版本。你說學(xué)習(xí)linux,應(yīng)該就是學(xué)習(xí)使用命令行版linux了,主要涉及復(fù)制,移動,編輯,創(chuàng)建目錄,創(chuàng)建文件,更改權(quán)限,配置網(wǎng)絡(luò),查看進(jìn)程等命令操作。圖形界面和命令行的區(qū)別就是:圖形界面直觀易操作,不過占資源比較多,命令行反之。
shell 編程,主要是控制進(jìn)程和文件,以及啟動和控制其它程序。shell 通過提示您輸入,向操作系統(tǒng)解釋該輸入,然后處理來自操作系統(tǒng)的任何結(jié)果輸出來管理您與操作系統(tǒng)之間的交互。一般用于系統(tǒng)的運(yùn)維。
c語言是編程語言,開發(fā)系統(tǒng)用的,也可以做嵌入式,例如linux就是c語言開發(fā)的。你想要做c開發(fā)就學(xué)c,想要java開發(fā)就學(xué)java,這些編程語言的學(xué)習(xí)都能在win或linux中進(jìn)行。
linux終端下,編譯C語言程序步驟為:
采用vi進(jìn)行源代碼編寫,編寫完成后,:wq存盤退出,如:
vi
test.c
在命令行下,運(yùn)行g(shù)cc編譯程序,生成執(zhí)行碼,如:
gcc
-o
test
test.c
-o
表示指明生成的執(zhí)行碼名稱
運(yùn)行編譯后的執(zhí)行碼
./test
命令是查詢當(dāng)前登錄的每個用戶,它的輸出包括用戶名、終端類型、登錄日期及遠(yuǎn)程主機(jī),在Linux系統(tǒng)中輸入who命令輸出如下:
我們先man一下who,在幫助文檔里可以看到,who命令是讀取/var/run/utmp文件來得到以上信息的。
我們再man一下utmp,知道utmp這個文件,是二進(jìn)制文件,里面保存的是結(jié)構(gòu)體數(shù)組,這些數(shù)組是struct utmp結(jié)構(gòu)體的。
struct utmp {
short ut_type;
pid_t ut_pid;
char ut_line[UT_LINESIZE];
char ut_id[4];
char ut_user[UT_NAMESIZE];
char ut_host[UT_HOSTSIZE];
struct {
int32_t tv_sec;
int32_t tv_usec;
} ut_tv;
/***等等***/
};
要實(shí)現(xiàn)who只需要把utmp文件的所有結(jié)構(gòu)體掃描過一遍,把需要的信息顯示出來就可以了,我們需要的信息有ut_user、ut_line、ut_tv、ut_host。
老師給的初始代碼:who1.c運(yùn)行結(jié)果如下:
需要注意的是utmp中所保存的時間是以秒和微妙來計算的,所以我們需要把這個時間轉(zhuǎn)換為我們能看懂的時間,利用命令man -k time | grep 3搜索C語言中和時間相關(guān)的函數(shù):
經(jīng)過搜索發(fā)現(xiàn)了一個ctime()函數(shù),似乎可以滿足我們的需求,于是對代碼中關(guān)于時間的printf進(jìn)行修改:
printf("%s",ctime(utbufp-ut_time));
編譯運(yùn)行發(fā)現(xiàn)出來的結(jié)果雖然已經(jīng)轉(zhuǎn)換成了我們能看懂的時間格式,但是很明顯這個時間是錯的:
搜索一下ut_time這個宏,發(fā)現(xiàn)它被定義為int32_t類型:
但是ctime()函數(shù)中要求參數(shù)的類型是time_t類型,所以重新定義一下類型,編譯運(yùn)行之后,發(fā)現(xiàn)時間已經(jīng)改成了正確的,但是發(fā)現(xiàn)()中的內(nèi)容被換行了,猜想ctime()函數(shù)的返回值可能自動在最后補(bǔ)了一個字符\n:
一開始想通過\r\b來實(shí)現(xiàn)“退行”,但實(shí)踐后發(fā)現(xiàn)并不可取,最后考慮到直接修改字符串中最后一個字符為\0,讓其字符串結(jié)束,使輸出達(dá)到與系統(tǒng)who命令一樣的效果,即在輸出語句前添加如下代碼:
cp[strlen(cp)-1] = '\0'
最后編譯執(zhí)行效果,發(fā)現(xiàn)解決了該問題:
雖然能看出基本上和who指令的執(zhí)行結(jié)果一致,但是并非完全一樣,主要在兩點(diǎn),第一是時間格式不一樣,第二個是比who執(zhí)行的結(jié)果多了幾條,需要注意的是utmp中保存的用戶,不僅僅是已經(jīng)登陸的用戶,還有系統(tǒng)的其他服務(wù)所需要的“用戶”,所以在顯出所有登陸用戶的時候,應(yīng)該過濾掉其他用戶,只保留登陸用戶。我們可以通過ut_type來區(qū)別,登陸用戶的ut_type是USER_PROCESS。
先用if語句對執(zhí)行結(jié)果進(jìn)行過濾,效果如下:
接著解決時間格式問題,利用man命令收到了兩個非常有用的函數(shù):localtime()和strftime(),localtime()是把從1970-1-1零點(diǎn)零分到當(dāng)前時間系統(tǒng)所偏移的秒數(shù)時間轉(zhuǎn)換為本地時間,strftime()則是用來定義時間格式的,如:年-月-日,利用這兩個函數(shù)對時間進(jìn)行修改后,結(jié)果顯示終于和系統(tǒng)中who命令一模一樣:
最終完整的代碼如下:
#include stdio.h
#include stdlib.h
#include utmp.h
#include fcntl.h
#include unistd.h
#include time.h
#define SHOWHOST
void show_time(long timeval){
char format_time[40];
struct tm *cp;
cp = localtime(timeval);
strftime(format_time,40,"%F %R",cp);
printf("%s",format_time);
}
int show_info( struct utmp *utbufp )
{
if(utbufp-ut_type == USER_PROCESS){
printf("%-8.8s", utbufp-ut_name);
printf(" ");
printf("%-8.8s", utbufp-ut_line);
printf(" ");
show_time(utbufp-ut_time);
printf(" ");
#ifdef SHOWHOST
printf("(%s)", utbufp-ut_host);
#endif
printf("\n");
}
return 0;
}
int main()
{
struct utmp current_record;
int utmpfd;
int reclen = sizeof(current_record);
if ( (utmpfd = open(UTMP_FILE, O_RDONLY)) == -1 ){
perror( UTMP_FILE );
exit(1);
}
while ( read(utmpfd, current_record, reclen) == reclen )
show_info(current_record);
close(utmpfd);
return 0;
}
我不太明白你說的是什么意思,Linux下的C編程一般是通過gcc實(shí)現(xiàn)的。\x0d\x0a例如,創(chuàng)建了一個hello.c文本,在文本中寫入\x0d\x0a#include\x0d\x0aintmain(void)\x0d\x0a{\x0d\x0aprintf(“helloworld!!”);\x0d\x0areturn0;\x0d\x0a}\x0d\x0a然后在終端輸入\x0d\x0a$gcc_ohellohello.c\x0d\x0a$/tmp/hello\x0d\x0a注:hello.c文件放在/tmp目錄下,通過gcc-ohellohello.c命令生成一個hello文件,它是一個可執(zhí)行文件,然后直接執(zhí)行,就可以運(yùn)行該程序了。