在C語(yǔ)言中對(duì)utmp文件進(jìn)行查找和寫(xiě)入操作的函數(shù)小結(jié)
C語(yǔ)言pututline()函數(shù):將utmp記錄寫(xiě)入文件
頭文件:
#include <utmp.h>
定義函數(shù):
void pututline(struct utmp *ut);
函數(shù)說(shuō)明:pututline()用來(lái)將參數(shù)ut 的utmp 結(jié)構(gòu)記錄到utmp 文件中. 此函數(shù)會(huì)先用getutid()來(lái)取得正確的寫(xiě)入位置, 如果沒(méi)有找到相符的記錄則會(huì)加入到utmp 文件尾.
附加說(shuō)明:需要有寫(xiě)入/var/run/utmp 的權(quán)限
范例
#include <utmp.h> main() { struct utmp ut; ut.ut_type = USER_PROCESS; ut.ut_pid = getpid(); strcpy(ut.ut_user, "kids"); strcpy(ut.ut_line, "pts/1"); strcpy(ut.ut_host, "www.gnu.org"); pututline(&ut); }
執(zhí)行:
//執(zhí)行范例后用指令who -l 觀察 root pts/0 dec9 19:20 kids pts/1 dec12 10:31(www.gnu.org) root pts/2 dec12 13:33
C語(yǔ)言getutline()函數(shù):文件查找函數(shù)(從utmp文件中查找特定的)
頭文件:
#include <utmp.h>
定義函數(shù):
struct utmp * getutline(struct utmp *ut);
函數(shù)說(shuō)明:getutline()用來(lái)從目前utmp 文件的讀寫(xiě)位置逐一往后搜索ut_type 為USER_PROCESS 或LOGIN_PROCESS 的記錄, 而且ut_line 和ut->ut_line 相符. 找到相符的記錄便將該數(shù)據(jù)以u(píng)tmp 結(jié)構(gòu)返回。
返回值:返回 utmp 結(jié)構(gòu)數(shù)據(jù), 如果返回NULL 則表示已無(wú)數(shù)據(jù), 或有錯(cuò)誤發(fā)生.
范例
#include <utmp.h> main() { struct utmp ut, *u; strcpy(ut.ut_line, "pts/1"); while((u = getutline(&ut))) { printf("%d %s %s %s \n", u->ut_type, u->ut_user, u->ut_line, u->ut_host); } }
執(zhí)行:
7 root pts/1
C語(yǔ)言getutid()函數(shù):從utmp文件中查找特定的記錄
頭文件:
#include <utmp.h>
定義函數(shù):
strcut utmp *getutid(strcut utmp *ut);
函數(shù)說(shuō)明:
getutid()用來(lái)從目前utmp 文件的讀寫(xiě)位置逐一往后搜索參數(shù)ut 指定的記錄。
1、如果ut->ut_type 為RUN_LVL, BOOT_TIME, NEW_TIME, OLD_TIME 其中之一則查找與ut->ut_type 相符的記錄;
2、若ut->ut_type為INIT_PROCESS, LOGIN_PROCESS, USER_PROCESS 或DEAD_PROCESS 其中之一, 則查找與ut->ut_id相符的記錄. 找到相符的記錄便將該數(shù)據(jù)以u(píng)tmp 結(jié)構(gòu)返回.
返回值:返回 utmp 結(jié)構(gòu)數(shù)據(jù), 如果返回NULL 則表示已無(wú)數(shù)據(jù), 或有錯(cuò)誤發(fā)生.
范例
#include <utmp.h> main() { struct utmp ut, *u; ut.ut_type=RUN_LVL; while((u = getutid(&ut))) { printf("%d %s %s %s\n", u->ut_type, u->ut_user, u->ut_line, u->ut_host); } }
執(zhí)行:
1 runlevel -
相關(guān)文章
C++結(jié)構(gòu)體與類(lèi)的區(qū)別詳情
這篇文章主要介紹了C++結(jié)構(gòu)體與類(lèi)的區(qū)別,C++中的struct對(duì)C中的struct進(jìn)行了擴(kuò)充,它已經(jīng)不再只是一個(gè)包含不同數(shù)據(jù)類(lèi)型的數(shù)據(jù)結(jié)構(gòu)了,它已經(jīng)獲取了太多的功能。下面我們一起進(jìn)入文章倆姐具體內(nèi)容,需要的朋友也可以參考一下2021-11-11C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之棧和隊(duì)列的實(shí)現(xiàn)及應(yīng)用
棧和隊(duì)列是一種數(shù)據(jù)結(jié)構(gòu),只規(guī)定了性質(zhì),并沒(méi)有規(guī)定實(shí)現(xiàn)方式。本文將以順序結(jié)構(gòu)實(shí)現(xiàn)棧,鏈表方式實(shí)現(xiàn)隊(duì)列,感興趣的小伙伴快跟隨小編一起學(xué)習(xí)一下吧2022-08-08C++中的string類(lèi)(C++字符串)入門(mén)完全攻略
這篇文章主要給大家介紹了關(guān)于C++中string類(lèi)(C++字符串)入門(mén)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用C++具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11C++實(shí)現(xiàn)快速排序(Quicksort)算法
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)快速排序(Quicksort)算法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-04-04詳解C++中typedef 和 #define 的區(qū)別
這篇文章主要介紹了C++中typedef 與 #define 的區(qū)別,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09C/C++ Qt 自定義Dialog對(duì)話(huà)框組件應(yīng)用案例詳解
有時(shí)候我們需要一次性修改多個(gè)數(shù)據(jù),使用默認(rèn)的模態(tài)對(duì)話(huà)框似乎不太夠用,此時(shí)我們需要自己創(chuàng)建一個(gè)自定義對(duì)話(huà)框。這篇文章主要介紹了Qt自定義Dialog對(duì)話(huà)框組件的應(yīng)用,感興趣的同學(xué)可以學(xué)習(xí)一下2021-11-11