C語言對組文件處理的相關(guān)函數(shù)小結(jié)
C語言getgrent()函數(shù):從組文件中取得賬號的數(shù)據(jù)
頭文件:
#include <grp.h> #include <sys/types.h>
定義函數(shù):
struct group * getgrent(void);
函數(shù)說明:getgrent()用來從組文件(/etc/group)中讀取一項(xiàng)組數(shù)據(jù), 該數(shù)據(jù)以group 結(jié)構(gòu)返回. 第一次調(diào)用時(shí)會取得第一項(xiàng)組數(shù)據(jù), 之后每調(diào)用一次就會返回下一項(xiàng)數(shù)據(jù), 直到已無任何數(shù)據(jù)時(shí)返回NULL.
struct group { char *gr_name; //組名稱 char *gr_passwd; //組密碼 gid_t gr_gid; //組識別碼 char **gr_mem; //組成員賬號 }
返回值:返回 group 結(jié)構(gòu)數(shù)據(jù), 如果返回NULL 則表示已無數(shù)據(jù), 或有錯(cuò)誤發(fā)生.
附加說明:getgrent()在第一次調(diào)用時(shí)會打開組文件, 讀取數(shù)據(jù)完畢后可使用endgrent()來關(guān)閉該組文件.
錯(cuò)誤代碼:
ENOMEM:內(nèi)存不足, 無法配置group 結(jié)構(gòu)。
范例
#include <grp.h> #include <sys/types.h> main() { struct group *data; int i; while((data = getgrent()) != 0) { i = 0; printf("%s:%s:%d:", data->gr_name, data->gr_passwd, data->gr_gid); while(data->gr_mem[i]) printf("%s, ", data->gr_mem[i++]); printf("\n"); } endgrent(); }
執(zhí)行:
root:x:0:root, bin:x:1:root, bin, daemon, daemon:x:2:root, bin, daemon, sys:x:3:root, bin, adm, adm:x:4:root, adm, daemon tty:x:5 disk:x:6:root lp:x:7:daemon, lp mem:x:8 kmem:x:9: wheel:x:10:root mail:x:12:mail news:x:13:news uucp:x:14:uucp man:x:15: games:x:20 gopher:x:30 dip:x:40 ftp:x:50 nobody:x:99
C語言setgrent()函數(shù):從頭讀取組文件中的組數(shù)據(jù)
頭文件:
#include <grp.h> #include <sys/types.h>
定義函數(shù):
void setgrent(void);
函數(shù)說明:setgrent()用來將getgrent()的讀寫地址指回組文件開頭。
用法參考 setpwent().
C語言endgrent()函數(shù):關(guān)閉文件(關(guān)閉組文件)
相關(guān)函數(shù):
getgrent, setgrent
頭文件:
#include <grp.h> #include <sys/types.h>
定義函數(shù):
void endgrent(void);
函數(shù)說明:endgrent()用來關(guān)閉由getgrent()所打開的密碼文件。
范例請參考setgrent().
相關(guān)文章
C++實(shí)現(xiàn)簡單職工管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++職工管理系統(tǒng)實(shí)訓(xùn)代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-04-04VC通過托盤圖標(biāo)得到該所屬進(jìn)程的實(shí)現(xiàn)代碼
這篇文章主要介紹了VC通過托盤圖標(biāo)得到該所屬進(jìn)程的實(shí)現(xiàn)代碼,為了方便大家使用特將多個(gè)代碼分享給大家,需要的朋友可以參考下2021-10-10C語言實(shí)現(xiàn)動態(tài)順序表的示例代碼
順序表是用一段物理地址連續(xù)的存儲單元依次存儲數(shù)據(jù)元素的線性結(jié)構(gòu)。順序表一般分為靜態(tài)順序表和動態(tài)順序表,本文主要和大家介紹的是動態(tài)順序表的實(shí)現(xiàn),需要的可以參考一下2022-10-10VC實(shí)現(xiàn)A進(jìn)程窗口嵌入到B進(jìn)程窗口中顯示的方法
這篇文章主要介紹了VC實(shí)現(xiàn)A進(jìn)程窗口嵌入到B進(jìn)程窗口中顯示的方法,對于理解windows程序運(yùn)行原理的進(jìn)程問題有一定的幫助,需要的朋友可以參考下2014-07-07如何用C語言、Python實(shí)現(xiàn)棧及典型應(yīng)用
本文先通過實(shí)例分別介紹了如何用C語言、Python實(shí)現(xiàn)棧,后又介紹棧的典型應(yīng)用,對大家學(xué)習(xí)棧很有借鑒參考價(jià)值,下面一起來看看吧。2016-08-08Java C++算法題解leetcode1592重新排列單詞間的空格
這篇文章主要為大家介紹了Java C++算法題解leetcode1592重新排列單詞間的空格示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09