嵌入式学习项目实战 --- 构建标准IO函数库

1、mstdio.h头文件

#ifndef __MSTDIO_H__
#define __MSTDIO_H__
#include <sys/types.h>

#define MEOF -1

enum mode{READ, WRITE, APPEND};

typedef struct
{
	int _fd;		//文件描述符
	char *_buffer;	//指向文件数据缓冲区
	char *_nextc;	//指向文件数据缓冲区中的任意一个字符
	int _mode;		//文件打开的模式
	off_t _left;	//读模式时:缓存中剩余可读的大小,初始时为0
					//写模式时:缓存中剩余可写的大小,初始时为BUFFER_LEN
}MFILE;

extern MFILE *mfdopen(int fd, const char * const mode);
extern MFILE* mfopen(const char * const pathname, const char * const mode);
extern int mfclose(MFILE *fp);
extern void mfflush(MFILE *fp);

extern int mfgetc(MFILE *fp);
extern int mfputc(int character, MFILE *fp);
extern int mungetc(int character, MFILE *fp);
extern char * mfgets(char *buff, int size, MFILE *fp);
extern int mfputs(char *buff, MFILE *fp);
extern size_t mfread(void *buff, size_t size, size_t counter, MFILE *fp);
extern size_t mfwrite(void *buff, size_t size, size_t counter, MFILE *fp);

#endif

2、mstdio.c源文件

#include "mstdio.h"
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <memory.h>
#include <malloc.h>
#include <assert.h>
#include <sys/types.h>
#include <unistd.h>
#include <fcntl.h>

#define BUFFER_LEN 4096

MFILE *mfdopen(int fd, const char * const mode)
{
	MFILE *fp = (MFILE*)malloc(sizeof(MFILE));
	assert(fp != NULL);
	
	fp->_buffer = (char*)malloc(BUFFER_LEN);
	assert(fp->_buffer != NULL);
	fp->_fd = fd;
	fp->_nextc = fp->_buffer;
	
	if(!strcmp(mode, "r"))
	{
		fp->_mode = READ;
		fp->_left = 0;
	} 
	else if(!strcmp(mode, "w"))
	{
		fp->_mode = WRITE;
		fp->_left = BUFFER_LEN;
	}
	else if(!strcmp(mode, "a"))
	{
		fp->_mode = APPEND;
		fp->_left = BUFFER_LEN;
	}
	
	return fp;
}

MFILE* mfopen(const char * const pathname, const char * const mode)
{
	int fd;
	
	if (!strcmp(mode, "r")) //读模式
	{
		fd = open(pathname, O_RDONLY);
	} 
	else if (!strcmp(mode, "w")) //写模式
	{
		fd = open(pathname, O_WRONLY | O_CREAT | O_TRUNC, 0777);
	} 
	else if (!strcmp(mode, "a")) //追加模式
	{
		fd = open(pathname, O_WRONLY | O_CREAT | O_APPEND, 0777);
	} 
	else 
	{
		return NULL;
	}
	
	if (fd < 0) return NULL;
	
	return mfdopen(fd, mode);
}

int mfclose(MFILE *fp)
{
	mfflush(fp);
	int res = close(fp->_fd);
	free(fp->_buffer);
	free(fp);
	return res;
}

/*刷新缓存*/
void mfflush(MFILE *fp)
{
	if (fp->_mode == READ)
	{
		fp->_nextc = fp->_buffer;
		fp->_left = 0;
	}
	else //WRITR or APPEND
	{
		write(fp->_fd, fp->_buffer, BUFFER_LEN - fp->_left);
		fp->_nextc = fp->_buffer;
		fp->_left = BUFFER_LEN;
	}
}

/*从文件中读取一个字节*/
int mfgetc(MFILE *fp)
{
	char c;
	
	assert(fp->_mode == READ);
	
	/*当缓存中的数据已读取完毕,再从文件中读取一批新的数据放入到缓存中*/
	if(fp->_left == 0)
	{
		ssize_t size = read(fp->_fd, fp->_buffer, BUFFER_LEN);
		assert(size >= 0);
		if(size == 0) return MEOF;
		fp->_nextc = fp->_buffer;
		fp->_left = size;
	}
	
	c = *(fp->_nextc);
	fp->_nextc++;
	fp->_left--;
	
	return c;
}

int mfputc(int character, MFILE *fp)
{
	assert(fp->_mode == WRITE || fp->_mode == APPEND);
	
	/*若缓存满,将缓存中的数据写入到文件中*/
	if(fp->_left == 0)
	{
		if(write(fp->_fd, fp->_buffer, BUFFER_LEN) != BUFFER_LEN)
			return 0;
		
		fp->_nextc = fp->_buffer;
		fp->_left = BUFFER_LEN;
	}
	
	*(fp->_nextc) = (char)character;
	fp->_nextc++;
	fp->_left--;
	
	return 1;
}

int mungetc(int character, MFILE *fp)
{
	
}

char * mfgets(char *buff, int size, MFILE *fp)
{
	char c;
	char *ptr = buff;
	
	assert(fp->_mode == READ);
	
	for(int i=0; i<size; buff++,i++)
	{
		c = mfgetc(fp);
		if(c == MEOF) return NULL;
		*buff = c;
	}
	
	return ptr;
}

int mfputs(char *buff, MFILE *fp)
{
	assert(fp->_mode == WRITE || fp->_mode == APPEND);
	
	for(; *buff!='\0'; buff++)
	{
		mfputc(*buff, fp);
		
		if(*buff == '\n')
		{
			mfflush(fp);
		}
	}
	
	return 1;
}

size_t mfread(void *buff, size_t size, size_t counter, MFILE *fp)
{
	char c;
	int i,j;
	char *ptr = (char*)buff;
	assert(fp->_mode == READ);
	
	for(i=0; i<counter; i++)
	{
		for (j=0; j<size; j++,ptr++)
		{
			c = mfgetc(fp);
			if(c == MEOF) return counter;
			*ptr = c;
		}
	}
	
	return counter;
}

size_t mfwrite(void *buff, size_t size, size_t counter, MFILE *fp)
{
	int i,j;
	char *ptr = (char*)buff;
	assert(fp->_mode == WRITE || fp->_mode == APPEND);
	
	for(i=0; i<counter; i++)
	{
		for (j=0; j<size; j++,ptr++)
		{
			mfputc(*ptr, fp);
			
			if(*ptr == '\n')
			{
				mfflush(fp);
			}
		}
	}
	
	return counter;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值