//C库函数读取文件的代码
I/O缓冲机制 C语言库函数写文件都是写在内存中,然后一次写入磁盘。提高了效率。
读写文件,不对系统进行操作,一般采用C语言库函数。移植可以在任何可以对C支持的操作系统,而不用修改。
FILE *fopen(const char *path, const char *mode);
mode 参数:
r Open text file for reading. The stream is positioned at the beginning of the file.
r+ Open for reading and writing. The stream is positioned at the beginning of the file.
w Truncate file to zero length or create text file for writing. The stream is positioned at the beginning of the file.
w+ Open for reading and writing. The file is created if it does not exist, otherwiseit is truncated. The stream is positioned at the beginning of the file.
a Open for appending (writing at end of file). The file is created if it does notexist. The stream is positioned at the end of the file.
a+ Open for reading and appending (writing at end of file). The file is created if itdoes not exist. The initial file position for reading is at the beginning of the
file, but output is always appended to the end of the file.
r 读的方法打开文件,文件的开始开始读
r+ 读和写,位置也是在文件的开始
w 截断文件(清空)并创建文件 写入,位置也是文件开始
w+ 读写文件,如果文件不存在就创建文件,存在就截断文件,位置也是文件开始。
a 追加写入的方式打开文件,如果文件不存在就创建文件,位置在文件尾部
a+ 打开追加文件读写。如果文件不存在,则创建文件。
int fclose(FILE *fp);
size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream);
size 表示读的大小,nmemb表示读记录次数。
如100个字符的buff 可以读size =100, nmemb =1
也可以size =1 ,nmemb =100
每次读满size的时候才有返回,否则为0
size_t fwrite(const void *ptr, size_t size, size_t nmemb,FILE *stream);
size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream);
返回的是记录数或者字节数,通过改变参数size 和nmemb来确定。
int main(int arg, char *args[])
{
FILE *p = fopen(args[1], "r+");
if (p == NULL)
{
printf("error is %s
", strerror(errno));
}
else
{
printf("success
");
char buf[100];
size_t rc = 0;
while(1)
{
size_t tmp = fread(buf, 1, sizeof(buf), p);//原则是第二个参数乘以第三个参数的大小不能超过缓冲区
rc += tmp;
if (tmp == 0)
break;
}
printf("rc = %d
", rc);
fclose(p);
}
return 0;
}
int fprintf(FILE *stream, const char *format, ...);
int main(int argc ,char* argv[])
{
FILE* p= fopen(argv[1] , "r+");
if(p==NULL)
{
return 0;
}
else
{
char buf[100];
memset(buf, 0,100);
sprintf(buf, "hello world!");
printf("%s
" , buf);
fprintf(p , "%s
", buf);
fclose(p);
}
}
int fputs(const char *s, FILE *stream);
char *gets(char *s);
int fscanf(FILE *stream, const char *format, ...);
//写log的代码
void writelog(const char *log)
{
time_t tDate;
struct tm *eventTime;
time(&tDate);//得到系统当前时间
eventTime = localtime(&tDate);//将time_t数据类型转化为struct tm结构
int iYear = eventTime->tm_year + 1900;//以1900年开始
int iMon = eventTime->tm_mon + 1;//从0开始--11 ,所有+1
int iDay = eventTime->tm_mday;
int iHour = eventTime->tm_hour;
int iMin = eventTime->tm_min;
int iSec = eventTime->tm_sec;
printf("tm_isdst = %d ", eventTime->tm_isdst);
char sDate[16];
sprintf(sDate, "%04d-%02d-%02d", iYear, iMon, iDay);
char sTime[16];
sprintf(sTime, "%02d:%02d:%02d", iHour, iMin, iSec);
char s[1024];
sprintf(s, "%s %s %s
", sDate, sTime, log);
FILE *p = fopen("my.log", "a+");
if (p == NULL)
{
printf("write log my.log error:%s
", strerror(errno));
}else
{
fputs(s, p);
fclose(p);
}
return;
}
//读目录的代码
int main(int arg, char *args[])
{
if (arg <2)
return 0;
DIR *dp;
struct dirent *dirp;
dp = opendir(args[1]);//打开目录文件
if (dp == NULL)
{
printf("error is %s
", strerror(errno));
return 0;
}
while((dirp = readdir(dp)) != NULL)//用readdir循环读取目录内容,读到目录尾,循环break
{
printf("%s
", dirp->d_name);//将目录下的文件名打印到屏幕
}
closedir(dp);//关闭目录
return 0;
}