文件监视器
受人所托,寫了個(gè)文件監(jiān)視器小程序,總共300+行,實(shí)現(xiàn)對(duì)指定文件的監(jiān)視功能,當(dāng)文件新增,刪除,或被修改,程序予以記錄并報(bào)告。
?? 實(shí)現(xiàn)是通過不斷掃描指定的文件,通過比較兩次掃描的狀態(tài)來判斷文件的變化。
文件狀態(tài)數(shù)據(jù)結(jié)構(gòu):
/* filestat struct for monitoring */
typedef struct filestat
{
??? char f_name[FNAME_MAX];
??? struct stat f_stat;
??? int f_flag;??? /* 0 for del,
????????????????? 1 for add, 2 for modified , 3 for unchanged */
??? struct filestat *next;
}filestat;
?? 設(shè)計(jì)思路:對(duì)指定的文件,文件夾進(jìn)行掃描,獲取文件狀態(tài)并記錄在statlist鏈表中,沒掃描一個(gè)文件,在statlist中查找,如果沒有找到,則為新增文件,插入到鏈表,并置f_flag為1;如果找到,比較mtime和ctime,如果相同,則說明,文件內(nèi)容,Inode都沒有發(fā)生變化,則文件未發(fā)生變化,置f_flag為3,如果不同,則說明文件被修改過,置f_flag為2。
??? 掃描完成后對(duì)鏈表執(zhí)行check操作,如果為1(而且不是第一次掃描),打印添加日志,如果為2打印修改日志,為3則為變化,check后置f_flag為0,所以當(dāng)check中的f_flag為0時(shí),說明文件被刪除。。。。
?? 調(diào)試中遇到段錯(cuò)誤,雖然后來改過來了,但還是不知道錯(cuò)誤處在哪里。第一次使用gdb發(fā)現(xiàn)程序問題,對(duì)執(zhí)行過程進(jìn)行跟蹤。并使用宏來決定是否打印調(diào)試日志(這點(diǎn)很重要,跟一個(gè)師兄學(xué)的,在程序里用了下)。
//#define MONITOR_DEBUG?? /* for debug, comment it to run in non debug mod */
?
#ifdef MONITOR_DEBUG
??? #define PDEBUG(format, arg...) fprintf(stderr, format, ##arg)
#else
??? #define PDEBUG(format, arg...)
#endif
總的感覺,自己的基本功還不夠扎實(shí),linux c 里面很多東西沒用過。。。加油
?? 實(shí)現(xiàn)是通過不斷掃描指定的文件,通過比較兩次掃描的狀態(tài)來判斷文件的變化。
文件狀態(tài)數(shù)據(jù)結(jié)構(gòu):
/* filestat struct for monitoring */
typedef struct filestat
{
??? char f_name[FNAME_MAX];
??? struct stat f_stat;
??? int f_flag;??? /* 0 for del,
????????????????? 1 for add, 2 for modified , 3 for unchanged */
??? struct filestat *next;
}filestat;
?? 設(shè)計(jì)思路:對(duì)指定的文件,文件夾進(jìn)行掃描,獲取文件狀態(tài)并記錄在statlist鏈表中,沒掃描一個(gè)文件,在statlist中查找,如果沒有找到,則為新增文件,插入到鏈表,并置f_flag為1;如果找到,比較mtime和ctime,如果相同,則說明,文件內(nèi)容,Inode都沒有發(fā)生變化,則文件未發(fā)生變化,置f_flag為3,如果不同,則說明文件被修改過,置f_flag為2。
??? 掃描完成后對(duì)鏈表執(zhí)行check操作,如果為1(而且不是第一次掃描),打印添加日志,如果為2打印修改日志,為3則為變化,check后置f_flag為0,所以當(dāng)check中的f_flag為0時(shí),說明文件被刪除。。。。
?? 調(diào)試中遇到段錯(cuò)誤,雖然后來改過來了,但還是不知道錯(cuò)誤處在哪里。第一次使用gdb發(fā)現(xiàn)程序問題,對(duì)執(zhí)行過程進(jìn)行跟蹤。并使用宏來決定是否打印調(diào)試日志(這點(diǎn)很重要,跟一個(gè)師兄學(xué)的,在程序里用了下)。
//#define MONITOR_DEBUG?? /* for debug, comment it to run in non debug mod */
?
#ifdef MONITOR_DEBUG
??? #define PDEBUG(format, arg...) fprintf(stderr, format, ##arg)
#else
??? #define PDEBUG(format, arg...)
#endif
總的感覺,自己的基本功還不夠扎實(shí),linux c 里面很多東西沒用過。。。加油
|
轉(zhuǎn)載于:https://www.cnblogs.com/yunnotes/archive/2013/04/19/3032538.html
總結(jié)