你可以試試popen 這個函數去實現下:
#include<stdio.h>
#include<string.h>
intmain(void)
{
chartmp_buf[1024+1];
FILE*fp;
memset(tmp_buf,0,sizeoftmp_buf);
fp=popen("ls-l","r");
if(fp!=NULL)
fgets(tmp_buf,sizeof(tmp_buf),fp);
printf("out:[%s] ",tmp_buf);
pclose(fp);
return0;
}
⑵ C語言中什麼是重定向
重定向不是C語言而是是shell(命令行窗口)做的事情,它把文件接到程序的標准輸入、標准輸出、或標准錯誤流上。
如果程序准備用重定向來做,直接從標准輸入讀數據,比如scanf或者cin,然後往標准輸入寫結果,printf或者cout。
然後程序執行的時候,在命令行窗口下使用重定向來指定將輸出重定向到一個文件:
例如,當你的程序名叫做test.exe:
執行 test.exe > essayct.txt。
⑶ linux 管道和輸入輸出重定向如何用c語言結合實現
兩種方法(實用)
1:直接系統調用,管道建立分命名管道和非命名管道,使用參考unix手冊或UNP第二卷進程間通信。輸入輸出重定向就用read(source);write(destination);
2:使用系統shell
功能:即調用
system("cat
file.a
|
grep
bb
>
file.c");
⑷ Linux c 符號的重定位信息
當編譯器生成一個目標文件後,其並不知道代碼和變數最終的存儲位置,也不知道定義在其他文件中的外部符號。因此編譯器會生成一個重定位表目,裡面存儲著關於每一個符號的信息。這個表目告知鏈接器在合並目標文件時應該如何修改每個目標文件中對符號的引用。這種重定位表目存儲在.rel.text 段中和.rel.data 段中。該表目可以理解為一個結構體,其中存儲著每一個符號的重定位信息。
offset表示該符號在存儲的段中的偏移值。symbol 代表該符號的名稱,字元串實際存儲在.strtab 段中,這里存儲的是該字元串首地址的下標。type表示重定位類型,鏈接器只關心兩種類型,一種是與PC相關的重定位引用,另一種是絕對地址引用。
PC相關的重定位引用表示將當前的PC值(這個值通常是下一條指令的存儲位置)加上該符號的偏移值。絕對地址引用表示將當前指令中已經指定的地址引用直接作為跳轉的地址,不需要進行任何修改。
有了這些信息,鏈接器就可以將符號在存儲段中的偏移值加上該段在重定位後該段的新地址,這樣就得到了一個新的引用地址,而這個引用地址就是該符號的最終地址。同樣,在程序所有引用該地址的部分都要作修改,使用這個新的絕對地址代替舊的偏移地址。當新的符號地址被修改完畢之後,鏈接器的工作就結束了。
⑸ linux重定向的基本概念
(這是理解後面的知識的前提,請務必理解)
a、 I/O重定向通常與 FD 有關,shell的FD通常為10個,即 0~9;
b、 常用FD有3個,為0(stdin,標准輸入)、1(stdout,標准輸出)、2(stderr,標准錯誤輸出),默認與keyboard、monitor有關;
c、 用 < 來改變讀進的數據信道(stdin),使之從指定的檔案讀進;
d、 用 > 來改變送出的數據信道(stdout, stderr),使之輸出到指定的檔案;
e、 0 是 < 的默認值,因此 < 與 0<是一樣的;同理,> 與 1> 是一樣的;
f、 在IO重定向 中,stdout 與 stderr 的管道會先准備好,才會從 stdin 讀進資料;
g、 管道「|」(pipe line):上一個命令的 stdout 接到下一個命令的 stdin;
h、 tee 命令是在不影響原本 I/O 的情況下,將 stdout 復制一份到檔案去;
i、 bash(ksh)執行命令的過程:分析命令-變數求值-命令替代(``和$( ))-重定向-通配符展開-確定路徑-執行命令;
j、 ( ) 將 command group 置於 sub-shell 去執行,也稱 nested sub-shell,它有一點非常重要的特性是:繼承父shell的標准輸入、標准輸出、標准錯誤和任何其他打開的文件描述符。
k、 exec 命令:常用來替代當前 shell 並重新啟動一個 shell,換句話說,並沒有啟動子 shell。使用這一命令時任何現有環境都將會被清除。exec 在對文件描述符進行操作的時候,也只有在這時,exec 不會覆蓋你當前的 shell 環境。
⑹ 簡述linux系統中有哪些重定向的方式
重定向能夠實現Linux命令的輸入輸出與文件之間重定向,以及實現將多個命令組合起來實現更加強大的命令。這部分涉及到的比較多的命令主要有:
cat:連接文件 sort:排序文本行 uniq:忽略或者報告重復行
wc:統計文件的行數、詞數、位元組數
grep:列印匹配製定模式的行
head:輸出文件的頭部 tail:輸出文件的尾部
tee:從標准輸入讀,並往標准輸出或者文件寫
重定向標准輸出
使用>可以將本來出現在屏幕的標准輸出信息重定向到一個文件中。
使用>>可以在實現重定向時不覆蓋原有內容,而是在文件末尾追加內容。
重定向標准錯誤信息到文件
使用文件描述符,在shell中,默認用數字0,1,2分別代表標准輸入、標准輸出、標准錯誤。
屏蔽不想看到的信息
Linux中有一個特殊的文件/dev/null,這個文件叫做bit bucket,可以接受輸入信息但是什麼都不做。例如:ls/usr/> /dev/null
重定向標准輸入
cat命令可以接受一組文件為參數,將這些文件復制到標准輸出。我們前面的例子中已經多次使用到cat命令來將文本文件的內容讀取到屏幕上。cat還有一個很重要的功能:接受一組文件,然後通過重定向將他們重新組合到一個文件中。
cat ls1 ls2 > ls這個命令將ls1和ls2文件中的內容合並到ls文件中了。cat命令的這種功能不僅僅適用於文本文件,同樣對二進制文件有效。這個場景主要在將多個壓縮包文件合並到一個壓縮包中用到。
cat也可以不傳遞參數,這種情況下,cat會重定向標准輸入到標准輸出。
管道
Linux提供|操作符,該操作符可以將一個命令的輸出作為另一個命令的輸入,這樣通過多個命令的協作來完成一些比較復雜的內容。比如,我們可以通過uniq命令來排除重復的行。但是uniq命令往往需要和sort命令配合使用。因為uniq接收一組排好序的文本,而剛好sort可以將文本行排序。
⑺ linux重定向命令應用及語法
1.
標准輸入的控制
語法:命令
文件將命令的執行結果送至指定的文件中。
例如:
ls
-l
>
list
將執行ls
-l
命令的結果寫入文件list
中。
語法:命令>!
文件將命令的執行結果送至指定的文件中,若文件已經存在,則覆蓋。
例如:
ls
-lg
>!
list
將執行ls
-
lg
命令的結果覆蓋寫入文件list
中。
語法:命令>&
文件將命令執行時屏幕上所產生的任何信息寫入指定的文件中。
例如:
cc
file1.c
>&
error
將編譯file1.c
文件時所產生的任何信息寫入文件error
中。
語法:命令>>
文件將命令執行的結果附加到指定的文件中。
例如:
ls
-
lag
>>
list
將執行ls
-
lag
命令的結果附加到文件list
中。
語法:命令>>&
文件將命令執行時屏幕上所產生的任何信息附加到指定的文件中。
例如:
cc
file2.c
>>&
error
將編譯file2.c
文件時屏幕所產生的任何信息附加到文件error
中。
3.
命令語法
⑻ 請解釋linux中的「重定向」的概念,由淺入深!
重定向是個操作系統的概念
它的主要含義是將原本從一個輸入輸出設備的輸入輸出操作,轉向到從另外一個輸入輸出設備進行。
例如:linux系統中sh啟動進程時會默認打開三個輸入輸出文件:標准輸入文件、標准輸出文件和標准錯誤文件(一般情況下是控制台),他們的文件句柄分別是0,1,2,
有時候你需要將進程的輸出輸出到一個文件的時候,你會這樣處理:a>file.txt(假定a是程序名稱)
那麼sh就會將默認的兩個輸出文件1和2改為:file.txt
這就叫重定向。
例如下面的sh命令:a
<fa.txt
1>fo.txt
2>fe.txt
sh就將0的輸入文件該向為:fa.txt,也就是將輸入改為從文件fa.txt
將1輸出文件重定向為:fo.txt
將2輸出文件重定向為:fe.txt
一般這些都是操作系統記得內容,基本上與開發沒有關系,你說gfortran要用重定向,我不太明白。
⑼ 如何使用Linux重定向符
1,標准輸入的控制
語法:命令< 文件將文件做為命令的輸入。
例如:
mail -s 「mail test」 [email protected] < file1
將文件file1 當做信件的內容,主題名稱為mail test,送給收信人。
2,標准輸出的控制
語法:命令> 文件將命令的執行結果送至指定的文件中。
例如:
ls -l > list
將執行「ls -l」 命令的結果寫入文件list 中。
語法:命令>! 文件將命令的執行結果送至指定的文件中,若文件已經存在,則覆蓋。
例如:
ls -lg >! list
將執行「ls - lg」 命令的結果覆蓋寫入文件list 中。
語法:命令>& 文件將命令執行時屏幕上所產生的任何信息寫入指定的文件中。
例如:
cc file1.c >& error
將編譯file1.c 文件時所產生的任何信息寫入文件error 中。
語法:命令》 文件將命令執行的結果附加到指定的文件中。
例如:
ls - lag 》 list
將執行「ls - lag」 命令的結果附加到文件list 中。
語法:命令》& 文件將命令執行時屏幕上所產生的任何信息附加到指定的文件中。
例如:
cc file2.c 》& error
將編譯file2.c 文件時屏幕所產生的任何信息附加到文件error 中。
關於輸入、輸出和錯誤輸出
在字元終端環境中,標准輸入/標准輸出的概念很好理解。輸入即指對一個應用程序或命令的輸入,無論是從鍵盤輸入還是從別的文件輸入;輸出即指應用程序或命令產生的一些信息;與 Windows 系統下不同的是,Linux 系統下還有一個標准錯誤輸出的概念,這個概念主要是為程序調試和系統維護目的而設置的,錯誤輸出於標准輸出分開可以讓一些高級的錯誤信息不幹擾正常的輸出信息,從而方便一般用戶的使用。
在 Linux 系統中:標准輸入(stdin)默認為鍵盤輸入;標准輸出(stdout)默認為屏幕輸出;標准錯誤輸出(stderr)默認也是輸出到屏幕(上面的 std 表示 standard)。在 BASH 中使用這些概念時一般將標准輸出表示為 1,將標准錯誤輸出表示為 2。下面我們舉例來說明如何使用他們,特別是標准輸出和標准錯誤輸出。
輸入、輸出及標准錯誤輸出主要用於 I/O 的重定向,就是說需要改變他們的默認設置。
先看這個例子:
$ ls > ls_result
$ ls -l 》 ls_result
上面這兩個命令分別將 ls 命令的結果輸出重定向到 ls_result 文件中和追加到 ls_result 文件中,而不是輸出到屏幕上。">"就是輸出(標准輸出和標准錯誤輸出)重定向的代表符號,連續兩個 ">" 符號,即 "》" 則表示不清除原來的而追加輸出。
再來看一個稍微復雜的例子:
$ find /home -name lost* 2> err_result
這個命令在 ">" 符號之前多了一個 "2","2>" 表示將標准錯誤輸出重定向。由於 /home 目錄下有些目錄由於許可權限制不能訪問,因此會產生一些標准錯誤輸出被存放在 err_result 文件中。大家可以設想一下 find /home -name lost* 2》err_result 命令會產生什麼結果?
如果直接執行 find /home -name lost* > all_result ,其結果是只有標准輸出被存入 all_result 文件中,要想讓標准錯誤輸出和標准輸入一樣都被存入到文件中,那該怎麼辦呢?看下面這個例子:
$ find /home -name lost* > all_result 2>& 1
上面這個例子中將首先將標准錯誤輸出也重定向到標准輸出中,再將標准輸出重定向到 all_result 這個文件中。這樣我們就可以將所有的輸出都存儲到文件中了。為實現上述功能,還有一種簡便的寫法如下:
$ find /home -name lost* >& all_result
如果那些出錯信息並不重要,下面這個命令可以讓你避開眾多無用出錯信息的干擾:
$ find /home -name lost* 2> /dev/null
有興趣的朋友,可以試驗下如下的幾種重定向方式,看看結果是什麼?
$ find /home -name lost* > all_result 1>& 2
$ find /home -name lost* 2> all_result 1>& 2
$ find /home -name lost* 2>& 1 > all_result
另外一個非常有用的重定向操作符是 "-",請看下面這個例子:
$ (cd /source/directory && tar cf - . ) | (cd /dest/directory && tar xvfp -)
該命令表示把 /source/directory 目錄下的所有文件通過壓縮和解壓,快速的全部移動到 /dest/directory 目錄下去,這個命令在 /source/directory 和 /dest/directory 不處在同一個文件系統下時將顯示出特別的優勢。
另外,幾種不常見的用法:
n<&- 表示將 n 號輸入關閉
<&- 表示關閉標准輸入(鍵盤)
n>&- 表示將 n 號輸出關閉
>&- 表示將標准輸出關閉
⑽ linux中的重定向問題
不管是>>還是2>>都屬於追加重定向。也就說,新重定向的內容不會覆蓋掉原有文件里的內容,而是另起一行。只不過>>,是只對正確的內容或者結果進行重定向;而2>>,只對錯誤的內容或結果進行重定向。
比如原有文件a.txt,裡面有一內容this is a test。現在我執行了命令:ls -l >> a.txt, 那麼這個時候,因為的ls -l這個命令是正確的,所以ls -l 這個命令的結果將會被追加到a.txt中,以行為單位,寫在了this is a test這段內容下面。
相反如果我執行了命令aaaa 2>> a.txt,那麼因為這個命令是錯的,所以會把我執行的aaaa命令之後所提示的錯誤提示(比如: command not found)追加到a.txt,同樣是在this is a test這段話的下面。
而> 和2>卻是不追加,而是覆蓋掉原有內容,其他意思一樣。