導航:首頁 > 程序命令 > linux命令c語言實現

linux命令c語言實現

發布時間:2022-07-15 07:27:11

A. linux中,運行一個C語言程序如何運行

在Linux中,可以使用gcc編譯器編譯C語言程序,生成可執行文件,並最終執行。
具體步驟如下:
1、編譯。
由.c文件生成.o文件,寫作:
gcc a.c -o a.o -c這個命令可以將a.c編譯成a.o。
如果存在多個文件,可以逐個編譯,即a.c
b.c...
生成a.o
b.o...等。
2、鏈接。
由.o文件生成可執行文件,寫作:
gcc a.o b.o c.o -o a.out這個命令將a.o
b.o
c.o三個目標文件,生成可執行文件a.out。
3、執行。
調用命令:
./a.out即可執行生成的可執行文件a.out。
4、注意事項:
(1)
當文件較少時,可以省略目標文件步驟,編譯鏈接一步執行,如:
gcc a.c b.c c.c -o a.out(2)
提供的示例為最基礎的編譯功能,在實際應用中gcc有很豐富的編譯選項,根據需求進行添加。
(3)
當項目包含文件較多時,可以使用makefile進行管理。

B. 如何用c語言實現 linux的rm命令

./rm filename和
在你的bash裡面輸入rm filename本質不是一樣的么
就是把那個rm的實現放在你的自己的mini bash裡面就可以了啊
調用
remove(filename);
就行了

C. 怎麼在linux中編寫c語言程序

首先需要有一個安裝好gcc的Linux系統,然後進行代碼的編寫進行測試演示

工具:

Ubuntu12.04

步驟

  1. 進入Linux系統後,啟動一個shell命令終端,在Ubuntu的三鍵啟動終端方法是同時按下Ctrl鍵+Alt鍵+t啟動後如下圖所示:

D. 在linux環境下用c語言代碼實現功能

創建空文件 ***.c(記得後綴名是 .c)
雙擊,顯示,打開
編寫···
保存···
打開終端輸入
編譯命令 gcc ***.c -o ***
報錯的話就回去修改
運行命令 ./***
我新手的時候就是這樣的

E. 怎麼用C語言實現linux的命令

命令是查詢當前登錄的每個用戶,它的輸出包括用戶名、終端類型、登錄日期及遠程主機,在Linux系統中輸入who命令輸出如下:

我們先man一下who,在幫助文檔里可以看到,who命令是讀取/var/run/utmp文件來得到以上信息的。

我們再man一下utmp,知道utmp這個文件,是二進制文件,裡面保存的是結構體數組,這些數組是struct utmp結構體的。

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;

/***等等***/
};

要實現who只需要把utmp文件的所有結構體掃描過一遍,把需要的信息顯示出來就可以了,我們需要的信息有ut_user、ut_line、ut_tv、ut_host。
老師給的初始代碼:who1.c運行結果如下:

需要注意的是utmp中所保存的時間是以秒和微妙來計算的,所以我們需要把這個時間轉換為我們能看懂的時間,利用命令man -k time | grep 3搜索C語言中和時間相關的函數:

經過搜索發現了一個ctime()函數,似乎可以滿足我們的需求,於是對代碼中關於時間的printf進行修改:
printf("%s",ctime(&utbufp->ut_time));

編譯運行發現出來的結果雖然已經轉換成了我們能看懂的時間格式,但是很明顯這個時間是錯的:

搜索一下ut_time這個宏,發現它被定義為int32_t類型:

但是ctime()函數中要求參數的類型是time_t類型,所以重新定義一下類型,編譯運行之後,發現時間已經改成了正確的,但是發現()中的內容被換行了,猜想ctime()函數的返回值可能自動在最後補了一個字元\n:

一開始想通過\r\b來實現「退行」,但實踐後發現並不可取,最後考慮到直接修改字元串中最後一個字元為\0,讓其字元串結束,使輸出達到與系統who命令一樣的效果,即在輸出語句前添加如下代碼:
cp[strlen(cp)-1] = '\0'

最後編譯執行效果,發現解決了該問題:

雖然能看出基本上和who指令的執行結果一致,但是並非完全一樣,主要在兩點,第一是時間格式不一樣,第二個是比who執行的結果多了幾條,需要注意的是utmp中保存的用戶,不僅僅是已經登陸的用戶,還有系統的其他服務所需要的「用戶」,所以在顯出所有登陸用戶的時候,應該過濾掉其他用戶,只保留登陸用戶。我們可以通過ut_type來區別,登陸用戶的ut_type是USER_PROCESS。
先用if語句對執行結果進行過濾,效果如下:

接著解決時間格式問題,利用man命令收到了兩個非常有用的函數:localtime()和strftime(),localtime()是把從1970-1-1零點零分到當前時間系統所偏移的秒數時間轉換為本地時間,strftime()則是用來定義時間格式的,如:年-月-日,利用這兩個函數對時間進行修改後,結果顯示終於和系統中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, ¤t_record, reclen) == reclen )
show_info(¤t_record);
close(utmpfd);
return 0;
}

F. 怎麼用linux寫c語言

Linux正在成為開發人員的編程天堂,成為開源和免費操作系統。 Turbo C編譯器已經是一種編譯程序的舊方法,所以讓程序員轉向Linux以獲得新的編程環境。 在本文中,我們將解釋如何編寫,編譯和運行一個簡單的C程序。 這將成為您遷移到可以在Linux上編寫和執行的更復雜和有用的C程序的基礎。

我們在Ubuntu 18.04 LTS系統上運行了本文中提到的步驟和命令。

我們將使用Linux命令行工具Terminal,以編譯一個簡單的C程序。 要打開終端,您可以使用Ubuntu Dash或Ctrl + Alt + T快捷方式。

第1步:安裝build-essential軟體包

為了編譯和執行C程序,您需要在系統上安裝必要的軟體包。 在Linux終端中以root用戶身份輸入以下命令:

sudo apt-get install build-essential

系統會要求您輸入root用戶密碼; 安裝過程將在此之後開始。 請確保您已連接到互聯網。

第2步:編寫一個簡單的C程序

安裝必要的軟體包之後,讓我們編寫一個簡單的C程序。

打開Ubuntu的圖形文本編輯器,將以下示常式序寫入或復制到其中:

#include<stdio.h>

int main()

{

printf("nA sample C program www.linuxidc.comnn");

return 0;

}

然後使用.c擴展名保存文件。 在這個例子中,我將我的C程序命名為linuxidc.c

或者,您可以通過gedit中的終端編寫C程序,如下所示:

gedit linuxidc.c

這將創建一個.c文件,您可以在其中編寫和保存程序。

第3步:使用gcc編譯C程序

在終端中,輸入以下命令以生成您編寫的程序的可執行版本:

句法:

$ gcc [programName].c -o programName

示例:

$ gcc linuxidc.c -o linuxidc

G. 在linux如何c語言編寫程序。

linux終端下,編譯C語言程序步驟為:
採用vi進行源代碼編寫,編寫完成後,:wq存檔退出,如:
vi test.c
在命令行下,運行gcc編譯程序,生成執行碼,如:
gcc -o test test.c
-o 表示指明生成的執行碼名稱
運行編譯後的執行碼
./test

H. 通過幾個簡單的Linux命令,深入理解c語言編

主要使用gcc命令以及以下幾個參數:

-E Preprocess only; do not compile, assemble or link
-S Compile only; do not assemble or link
-c Compile and assemble, but do not link
-o <file> Place the output into <file>

環境配置好以後,讓我們開始c語言的編譯之旅吧~

編寫c語言源代碼
很多linux命令都可以新建一個文件,比如

$ touch test.c

建立一個空白的文件

$ vim test.c

使用vim(文本編輯器)編輯test.c,如果test.c不存在,則創建

$ echo "123" > test.c

通過輸出重定向新建一個文件

創建完test.c後,將下面這段Hello World代碼寫到test.c中(很多方法)

#include <stdio.h>
int main(){
printf("Hello world\n");
return 0;
}

寫完之後可以使用ls命令來查看當前目錄下的文件,檢查test.c是否存在

$ ls

使用cat命令查看test.c中的內容,檢查是否寫入成功

$ cat test.c

ls-cat

展開頭文件(預處理)
$ gcc -E test.c -o test_pre.c

這個命令把源代碼test.c中的頭文件展開,並把結果輸出到test_pre.c

(可以使用cat或者vim命令查看test_pre.c文件中的內容)
per
test_pre.c中的內容是這樣的,可以發現原本幾行的代碼變成了幾百行,而且已經見不到include關鍵字了,取而代之的是一些變數定義的代碼,這些代碼就是stdio.h中的內容,和stdio.h中頭文件展開後的內容。

編譯
$ gcc -S test_pre.c -o test_asm.s

這一條命令將上一步預處理過後的源代碼編譯成為匯編代碼

asm
現在看到的是test_asm.s裡面的匯編代碼。

什麼是匯編?

匯編語言是匯編指令集、偽指令集和使用它們規則的統稱,使用具有一定含義的符號為助憶符,用指令助憶符、符號地址等組成的符號指令稱為匯編格式指令。

簡單的可以理解為匯編語言是一本詞典,01100101011010這樣的二進制字元串是單詞,匯編指令是單詞的含義。計算機能讀懂二進制字元串,而人能讀懂的是翻譯過來的匯編指令。

匯編
$ gcc -c test_asm.s -o test_obj.o

這一步將test_asm.s匯編成為目標文件,目標文件中存儲的就是010101010這樣的字元串了,可以用cat命令試試去讀取test_obj.o

obj

可以發現列印出來許多不可見的字元,原因是目標文件已經是二進制格式的了,不同於源代碼(文本格式)

有關文件的格式可以看下這里的介紹:
http://www.cnblogs.com/zhangjiankun/archive/2011/11/27/2265184.html

鏈接
鏈接器負責將程序的目標文件與所需的所有附加的目標文件連接起來,最終生成可執行文件。附加的目標文件包括靜態連接庫和動態連接庫。

這個例子中沒有附加的目標文件,所以只需要目標文件做被鏈接的對象。

有關鏈接器的詳細講解大家可以看下這里:
https://www.hu.com/question/27386057

$ gcc test_obj.o -o hello

gcc本身可以充當鏈接器,這里使用gcc命令將目標文件test_obj.o鏈接成了可執行文件hello

ld

運行程序!
至此,源代碼已經經歷了預處理、編譯、匯編、鏈接四步成為了可執行文件,現在試著運行一下這個程序吧

$ ./hello

hello

小結
首先我們創建了源文件test.c,然後用gcc -E將源文件中的頭文件展開,這一步叫做預處理;
之後通過gcc -S將預處理後的源文件編譯了匯編代碼,這一步叫做編譯;
接著使用gcc -c命令將匯編代碼轉換成了二進制的目標文件,這一步操作叫做匯編;
目標文件不同於源代碼,是二進制格式,是源文件編譯過程中產生的中間文件,通過鏈接器可以將多個目標文件鏈接成為可執行文件,這一步叫做鏈接。

源文件->(預處理->編譯->匯編->鏈接)->可執行文件

一般大家所說的c語言編譯,其實是上述這四步的簡稱。

I. 基於linux的ls命令的c語言實現

system("ls");

J. linux中cp命令如何用 C語言實現

1,首先需要了解cp的原理。

2,可以參考cp的源碼去了解其原理

3,cp命令的源碼可以在linux內核中找到。

4,或者下載busybox其中也會有cp的源碼

只有了解其原理之後才能談如何實現。參考代碼如下:

#include<stdio.h>
#include<stdlib.h>
#include<sys/stat.h>
#include<sys/types.h>
#include<fcntl.h>
#include<errno.h>
#include<unistd.h>
#include<string.h>

#defineBUF_SIZE1024
#definePATH_LEN128

voidmy_err(char*err_string,intline)
{
fprintf(stderr,"line:%d",line);
perror(err_string);
exit(1);
}

void_data(constintfrd,constintfwd)
{
intread_len=0,write_len=0;
unsignedcharbuf[BUF_SIZE],*p_buf;

while((read_len=read(frd,buf,BUF_SIZE))){

if(-1==read_len){
my_err("Readerror",__LINE__);
}
elseif(read_len>0){//把讀取部分寫入目標文件
p_buf=buf;
while((write_len=write(fwd,p_buf,read_len))){
if(write_len==read_len){
break;
}
elseif(write_len>0){//只寫入部分
p_buf+=write_len;
read_len-=write_len;
}
elseif(-1==write_len){
my_err("Writeerror",__LINE__);
}
}
if(-1==write_len)break;
}
}
}

intmain(intargc,char**argv)
{

intfrd,fwd;//讀寫文件描述符
intlen=0;
char*pSrc,*pDes;//分別指向源文件路徑和目標文件路徑
structstatsrc_st,des_st;

if(argc<3){
printf("用法./MyCp<源文件路徑><目標文件路徑> ");
my_err("argumentserror",__LINE__);
}

frd=open(argv[1],O_RDONLY);
if(frd==-1){
my_err("Cannotopnefile",__LINE__);
}

if(fstat(frd,&src_st)==-1){
my_err("staterror",__LINE__);
}
/*檢查源文件路徑是否是目錄*/
if(S_ISDIR(src_st.st_mode)){
my_err("略過目錄",__LINE__);
}

pDes=argv[2];
stat(argv[2],&des_st);
if(S_ISDIR(des_st.st_mode)){//目標路徑是目錄,則使用源文件的文件名

len=strlen(argv[1]);
pSrc=argv[1]+(len-1);//指向最後一個字元
/*先找出源文件的文件名*/
while(pSrc>=argv[1]&&*pSrc!='/'){
pSrc--;
}
pSrc++;//指向源文件名

len=strlen(argv[2]);
//.表示復制到當前工作目錄
if(1==len&&'.'==*(argv[2])){
len=0;//沒有申請空間,後面就不用釋放
pDes=pSrc;
}
else{//復制到某目錄下,使用源文件名
pDes=(char*)malloc(sizeof(char)*PATH_LEN);
if(NULL==pDes){
my_err("mallocerror",__LINE__);
}

strcpy(pDes,argv[2]);

if(*(pDes+(len-1))!='/'){//目錄缺少最後的'/',則補上』/『
strcat(pDes,"/");
}
strcat(pDes+len,pSrc);
}
}

/*打開目標文件,使許可權與源文件相同*/
fwd=open(pDes,O_WRONLY|O_CREAT|O_TRUNC,src_st.st_mode);
if(fwd==-1){
my_err("Cannotcreatfile",__LINE__);
}
_data(frd,fwd);
//puts("endof");
if(len>0&&pDes!=NULL)
free(pDes);

close(frd);
close(fwd);

return0;
}
閱讀全文

與linux命令c語言實現相關的資料

熱點內容
自己購買雲主伺服器推薦 瀏覽:414
個人所得稅java 瀏覽:756
多餘的伺服器滑道還有什麼用 瀏覽:184
pdf劈開合並 瀏覽:21
不能修改的pdf 瀏覽:745
同城公眾源碼 瀏覽:481
一個伺服器2個埠怎麼映射 瀏覽:288
java字元串ascii碼 瀏覽:69
台灣雲伺服器怎麼租伺服器 瀏覽:468
旅遊手機網站源碼 瀏覽:325
android關聯表 瀏覽:938
安卓導航無聲音怎麼維修 瀏覽:328
app怎麼裝視頻 瀏覽:427
安卓系統下的軟體怎麼移到桌面 瀏覽:89
windows拷貝到linux 瀏覽:765
mdr軟體解壓和別人不一樣 瀏覽:897
單片機串列通信有什麼好處 瀏覽:333
游戲開發程序員書籍 瀏覽:855
pdf中圖片修改 瀏覽:281
匯編編譯後 瀏覽:484