linux函數
1. linux中gethostent函數的全稱
/*SystemV/POSIXextension*/
structhostent*gethostent(void);
/*GNUextensions*/
intgethostent_r(
structhostent*ret,char*buf,size_tbuflen,
structhostent**result,int*h_errnop);
2. Linux系統函數調用
指令很多,你只要記住常用的就行了,其它的用到了在查閱
我舉幾個常用的命令
查看cpu cat /proc/cpuinfo
查看內存 free -m
查看掛載的硬碟 df -h
查看所有硬碟 fdisk -l
復制
移動 mv
打開目錄 cd 目錄名稱
cat 查看文件內容
more 分屏查看內容
head 查看文件開頭部分內容
tail 查看文件結尾部分內容
mail 查看當前用戶的郵件
等等
3. linux下如何編寫函數
sed -n '/^[0-9]\+:/p' filename
4. 如何在查看linux內核中的函數
如果要看這兩個函數在標准庫中的定義用ctags或cscope生成索引.h,cscope,可以跳轉到函數定義,man malloc,聲明見stdlib。
如果仍然找不到,可以用ctags,si或grep。
windows下用source insight也可,然後查找函數定義,用grep -r 搜索關鍵字,atoi和malloc在C的標准庫中有定義。
1.安裝ctags
在源代碼目錄下運行
ctags -R
這樣,會遞歸生成當前目錄下及其子目錄的tags文件。
2.使用VIM根據tags文件查找函數或結構定義。
1.在源碼目錄下查找
vi -t tagname
2.如果要在任意位置使用,則需要把該tags文件添加到~/.vimrc文件中
set tags=/home/money/sda8/2.6232/tags
3.如果要在代碼中實時跟蹤,則游標移動到函數名上,使用CTRL+]鍵,按CTRL+t可以返回。
如果要跟蹤系統函數,使用shift+K可以自動跳轉道游標所在函數的手冊。
5. linux下系統調用函數read()
open系統調用
open函數的三個參數:
(1)path是已經存在的文件的路徑;
(2)oflags參數:若值為 O_RDONLY ,就以只讀方式打開文件;
若值為 O_WDONLY,就以只寫方式打開文件;
若值為 O_RDWR,就以讀寫方式打開文件;
(3)參數mode:文件的許可權,對於一個已經存在的文件,參數mode是沒有用的,通常將其省略,因此這種情況下open調用只需兩個參數。
創建新文件:
前面已經說到,當文件不存在時,open會創建一個新文件(僅能是普通文件),我們只需要用 or操作向open的 oflags參數中加入標志O_CREAT即可。這樣可以創建一個新的只讀文件,但是這沒有任何意義,因為所創建的新文件沒有任何可讀內容。因此一般需要 O_CREAT與 O_WRONLY或 O_RDWR一起使用,此時就需要mode參數了。
例如:
int fd = open("/home/LY/newfile",O_RDWR | O_CREAT,MODE_FILE)
參數mode僅在創建新文件時有效,對於一個已經存在的文件,它沒有任何作用。
關於open的flags參數:
除了以上介紹的 open標志外,open還有許多標志,具體的如下表所示:
標志
解釋
O_RDONLY
只讀方式打開
O_WRONLY
只寫方式打開
O_RDWR
讀寫方式打開
O_APPEND
每次寫都追加到文件的尾端
O_CREAT
若文件不存在則創建文件
O_DSYNC
設置同步I/O方式
O_EXCL
如果文件已存在,則出錯;必須與O_CREAT一起使用
O_NOCTTY
不將此設備作為控制終端
O_NONBLOCK
不等待命名管道或特殊文件准備好
O_RSYNC
設置同步I/O方式
O_SYNC
設置同步I/O方式
O_TRUNC
將其長度截短為0
write系統調用
write函數的三個參數:
(1)fildes: 文件描述符
(2)buf:指定寫入數據的數據緩沖區
(3)nbytes:指定寫入的位元組數
函數返回值:
成功:已寫的位元組數
-1 :出錯
0:未寫入任何數據
例子:
運行結果:
read系統調用
read函數的三個參數:
(1)fildes:文件描述符
(2)buf:指定讀入數據的數據緩沖區
(3)nbytes:指定讀入的位元組數
函數返回值:
成功:已讀的位元組數
0:未讀入任何數據
-1:出錯
例子:
運行結果:
close系統調用
通過對 close進行分析,我們會發現close並沒有做什麼實質工作,它沒有刷新任何內核緩沖區,而僅僅是使文件描述符可以重用。
6. Linux C函數Kill
你是程序中調用kill函數,還是在命令行調用kill命令?
int kill(pid_t pid, int sig); 函數有兩個參數,一個是進程號,一個是信號
如果你輸入的進程號是正確的,而進程還在,則信號有可能被該進程忽略了,不知道你發送的信號是幾號? 只有SIGKILL SIGSTOP不能被忽略,其它都可以忽略或捕捉。
7. linux中sprintf函數怎麼用
sprintf函數的作用是格式化一個字元串,和printf函數有些類似,不同的是printf函數是格式化輸出流,而sprintf是格式化字元串。sprintf函數的第一個參數就是指向一個用於存放結果的字元串,第二個參數就和printf函數一樣,由普通字元串和格式轉換控制符組成。轉換控制符就是:%d對應整型、%c對應一個字元、%f對應一個單精度浮點數、%s對應一個字元串。sprintf會把按照第二個參數格式化好的字元串放到第一個參數中,所以第一個參數要有足夠的長度容納。
8. 關於linux中的pause()函數
這個函數是讓程序暫停,直到等到有信號到來為止。
你這段程序實際就是一直等信號。
9. 誰能解釋一下linux下execle函數的用法嗎最好能給一個程序例子!
如果你理解execv, 那麼execle和他的區別就是, 前者的調用參數是以數組形式給的,而後者則是以列表方式給,也就是execle(path, arg1, arg2, ..., envp), 並且提供了環境變數參數;
#include<unistd.h>
#include<stdio.h>
#include<stdlib.h>
int main()
{
char *envp[]={"PATH=/tmp","USER=shan",NULL};
if(fork()==0)
{
if(execle("/bin/dir","dir",NULL,envp)<0)
perror("execle error!");
}
return 0;
}
10. 如何查詢Linux內核函數
如果要看這兩個函數在標准庫中的定義用ctags或cscope生成索引.h,cscope,可以跳轉到函數定義,man malloc,聲明見stdlib。
如果仍然找不到,可以用ctags,si或grep。
windows下用source insight也可,然後查找函數定義,用grep -r 搜索關鍵字,atoi和malloc在C的標准庫中有定義。
1.安裝ctags
在源代碼目錄下運行
ctags -R
這樣,會遞歸生成當前目錄下及其子目錄的tags文件。
2.使用VIM根據tags文件查找函數或結構定義。
1.在源碼目錄下查找
vi -t tagname
2.如果要在任意位置使用,則需要把該tags文件添加到~/.vimrc文件中
set tags=/home/money/sda8/2.6232/tags
3.如果要在代碼中實時跟蹤,則游標移動到函數名上,使用CTRL+]鍵,按CTRL+t可以返回。
如果要跟蹤系統函數,使用shift+K可以自動跳轉道游標所在函數的手冊。