【Linux】嵌入式开发,在Linux中使用C语言对标准I/O库文件的替换Copy

简介: <p><span style="white-space:pre"></span><span style="font-size:24px"><span style="white-space:pre"></span>首先,我专业是是电子工程专业,C语言每年都在用,可实际上,我大多数时间都用在网站开发上,没多少时间用于本专业,以及了解C语言更多的基础,所以,我C语言很差,真的很差。</span>

首先,我专业是是电子工程专业,C语言每年都在用,可实际上,我大多数时间都用在网站开发上,没多少时间用于本专业,以及了解C语言更多的基础,所以,我C语言很差,真的很差。

就本例,我在懵懵懂懂下,竟然错了差不多200+次的代码修改,操作近一千五次!仅仅47行的代码(包含注释!)!


如此,对于别人来说,真是感到不屑,不过,对于本人有着非常重要的心得体会!


题目要求:从源文件字符的中间起,5位开始显示!(我这里做了2位!)


案例是书本上的:

#define	BUFFER_SIZE	1024		/* 每次读写缓存大小 */
#define SRC_FILE_NAME	"src_file"	/* 源文件名 */
#define DEST_FILE_NAME	"dest_file"	/* 目标文件名文件名 */
#define OFFSET		10240		/* 拷贝的数据大小 */
int main()
{	FILE *src_file, *dest_file;
	unsigned char buff[BUFFER_SIZE];
	int real_read_len;	
	/* 以只读方式打开源文件 */
	src_file = fopen(SRC_FILE_NAME, "r");	
	/* 以只写方式打开目标文件,若此文件不存在则创建 */
	dest_file = fopen(DEST_FILE_NAME, "w");	
	if (!src_file || !dest_file)
	{	printf("Open file error\n");
		exit(1);	}	
	/* 将源文件的读写指针移到最后10KB的起始位置*/
	fseek(src_file, -OFFSET, SEEK_END);	
	/* 读取源文件的最后10KB数据并写到目标文件中,每次读写1KB */
	while ((real_read_len = fread(buff, 1, sizeof(buff), src_file)) > 0)
	{fwrite(buff, 1, real_read_len, dest_file);}	
	fclose(dest_file);
	fclose(src_file);
	return 0;	}


——————————————————————————————————————

我的源文件:

file.c

//by叶箫大人
//新浪微博 @叶箫大人 
//2015.6.12 
#include"unistd.h"
#include"sys/types.h"
#include"sys/stat.h"
#include"fcntl.h"
#include"stdlib.h"
#include"string.h"
#include"stdio.h"

#define buffersize 1024  //每次读写缓存大小
#define srcfiles "srcfile"//源文件名字
#define destfiles "destfile"//目标文件名
#define OFFSET 1024 //拷贝数据大小

int main()
{
	FILE *srcfile,*destfile;//定义指针 
	unsigned  char buff[buffersize];//定义数组buff 
	int realreadlen;				//定义字符长度 

//以只读方式打开源文件
srcfile = fopen(srcfiles, "r");
//以只写方式打开目标文件,若不存在则创建
destfile = fopen(destfiles, "w");
	if(!srcfile||!destfile)
	{
		printf("Oh,Sorry File Open Error!\n");
		exit(1);
	}
//读取源文件的最后10k的数据并写到目标文件中,每次读写1k

while((realreadlen = (fread(buff,1,sizeof(buff),srcfile)/2))>0)		
	{
		fseek(srcfile,-(realreadlen), SEEK_END);
		//14=总字符长度的减去中间要写的数值 
		realreadlen = (fread(buff,1,sizeof(buff),srcfile)+realreadlen-14);
		{   
			fwrite(buff,1,realreadlen,destfile);//写入destfile		
		}
	}
	fclose(destfile);//关闭destfile 
	fclose(srcfile);//关闭srcfile 
	return 0;
}

srcfile(源文件)

0123456789ABCDEF



目录
相关文章
|
1月前
|
Linux API 开发工具
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
ijkplayer是由B站研发的移动端播放器,基于FFmpeg 3.4,支持Android和iOS。其源码托管于GitHub,截至2024年9月15日,获得了3.24万星标和0.81万分支,尽管已停止更新6年。本文档介绍了如何在Linux环境下编译ijkplayer的so库,以便在较新的开发环境中使用。首先需安装编译工具并调整/tmp分区大小,接着下载并安装Android SDK和NDK,最后下载ijkplayer源码并编译。详细步骤包括环境准备、工具安装及库编译等。更多FFmpeg开发知识可参考相关书籍。
82 0
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
|
2月前
|
存储 Linux 开发工具
如何进行Linux内核开发【ChatGPT】
如何进行Linux内核开发【ChatGPT】
|
3月前
|
Java Linux API
Linux设备驱动开发详解2
Linux设备驱动开发详解
43 6
|
3月前
|
消息中间件 算法 Unix
Linux设备驱动开发详解1
Linux设备驱动开发详解
49 5
|
3月前
|
NoSQL Linux C语言
嵌入式GDB调试Linux C程序或交叉编译(开发板)
【8月更文挑战第24天】本文档介绍了如何在嵌入式环境下使用GDB调试Linux C程序及进行交叉编译。调试步骤包括:编译程序时加入`-g`选项以生成调试信息;启动GDB并加载程序;设置断点;运行程序至断点;单步执行代码;查看变量值;继续执行或退出GDB。对于交叉编译,需安装对应架构的交叉编译工具链,配置编译环境,使用工具链编译程序,并将程序传输到开发板进行调试。过程中可能遇到工具链不匹配等问题,需针对性解决。
|
3月前
|
编解码 安全 Linux
基于arm64架构国产操作系统|Linux下的RTMP|RTSP低延时直播播放器开发探究
这段内容讲述了国产操作系统背景下,大牛直播SDK针对国产操作系统与Linux平台发布的RTMP/RTSP直播播放SDK。此SDK支持arm64架构,基于X协议输出视频,采用PulseAudio和Alsa Lib处理音频,具备实时静音、快照、缓冲时间设定等功能,并支持H.265编码格式。此外,提供了示例代码展示如何实现多实例播放器的创建与管理,包括窗口布局调整、事件监听、视频分辨率变化和实时快照回调等关键功能。这一技术实现有助于提高直播服务的稳定性和响应速度,适应国产操作系统在各行业中的应用需求。
109 3
|
3月前
|
传感器 人工智能 网络协议
:嵌入式 Linux 及其用途
【8月更文挑战第24天】
169 0
|
3月前
|
算法 IDE 程序员
C语言与嵌入式系统:嵌入式C编程基础。
C语言与嵌入式系统:嵌入式C编程基础。
72 0
|
4月前
|
Ubuntu 算法 Linux
嵌入式Linux的学习误区
**嵌入式Linux学习误区摘要** 1. **过度聚焦桌面Linux** - 许多学习者误将大量时间用于精通桌面Linux系统(如RedHat、Fedora、Ubuntu),认为这是嵌入式Linux开发的基石。 - 实际上,桌面Linux仅作为开发工具和环境,目标不应是成为Linux服务器专家,而应专注于嵌入式开发工具和流程。 2. **盲目阅读Linux内核源码** - 初学者在不了解Linux基本知识时试图直接研读内核源码,这往往导致困惑和挫败感。 - 在具备一定嵌入式Linux开发经验后再有针对性地阅读源码,才能有效提升技能。
|
4月前
|
Ubuntu Linux Docker
Java演进问题之Alpine Linux创建更小的Docker镜像如何解决
Java演进问题之Alpine Linux创建更小的Docker镜像如何解决