11.08-efi shell

11.08-efi shell11.08任务目标//进度:将DOS下的SPD读取工具移植到EFIShell环境下,并将读取的SPD内容保存至DIMM_SPD.txt工作结果:学习笔记:fopen()打开文件perror()错误判断处理fread()读取,写入fseek()重定向流ftell()返回当前文件位置fgets()读取fclose()关闭文件流FILE*fopen(constchar*path,constchar*mode);//打开一个文件 参数pa

大家好,又见面了,我是你们的朋友全栈君。

11.08

任务目标 // 进度:

  • 将DOS下的SPD读取工具移植到EFI Shell环境下,并将读取的SPD内容保存至DIMM_SPD.txt

工作结果:

学习笔记:

fopen()打开文件
perror()错误判断处理
fread()读取,写入
fseek()重定向流
ftell()返回当前文件位置
fgets()读取
fclose()关闭文件流

FILE * fopen(const char * path,const char * mode);      //打开一个文件
	参数path字符串包含欲打开的文件路径及文件名,参数mode字符串则代表着流形态。
	mode有下列几种形态字符串:
	r 以只读方式打开文件,该文件必须存在。
	r+ 以可读写方式打开文件,该文件必须存在。
	rb+ 读写打开一个二进制文件,允许读写数据。
	rw+ 读写打开一个文本文件,允许读和写。
	w 打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。若文件不存在则建立该文件。
	w+ 打开可读写文件,若文件存在则文件长度清为零,即该文件内容会消失。若文件不存在则建立该文件。
	a 以附加的方式打开只写文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保留。(EOF符保留)
	a+ 以附加方式打开可读写的文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾后,即文件原先的内容会被保留。 (原来的EOF符不保留)
	wb 只写打开或新建一个二进制文件;只允许写数据。
	wb+ 读写打开或建立一个二进制文件,允许读和写。
	ab+ 读写打开一个二进制文件,允许读或在文件末追加数据。
	at+ 打开一个叫string的文件,a表示append,就是说写入处理的时候是接着原来文件已有内容写入,不是从头写入覆盖掉,t表示打开文件的类型是文本文件,+号表示对文件既可以读也可以写。
	上述的形态字符串都可以再加一个b字符,如rb、w+b或ab+等组合,加入b 字符用来告诉函数库以二进制模式打开文件。如果不加b,表示默认加了t,即rt,wt,其中t表示以文本模式打开文件。由fopen()所建立的新文件会具有S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH(0666)权限,此文件权限也会参考umask 值。
	有些C编译系统可能不完全提供所有这些功能,有的C版本不用"r+","w+","a+",而用"rw","wr","ar"等,读者注意所用系统的规定。
二进制和文本模式的区别
	1.在windows系统中,文本模式下,文件以""代表换行。若以文本模式打开文件,并用fputs等函数写入换行符"\n"时,函数会自动在"\n"前面加上"\r"。即实际写入文件的是"" 。
	2.在类Unix/Linux系统中文本模式下,文件以"\n"代表换行。所以Linux系统中在文本模式和二进制模式下并无区别。

errno          //宏。当程序运行时,errno宏被设置为0,一旦程序发生了系统级的错误,errno宏就会被设置为其它值。
strerror()     //函数。获取该错误索引号对应的错误信息。
perror()       //函数。显示标准错误输出流stderr中的错误信息

size_t fread (void *buffer, size_t size, size_t count, FILE *stream);     //从一个文件流中读数据
	buffer 用于接收数据的内存地址,大小至少是size*count字节.
	size 单个元素的大小,单位是字节
	count 元素的个数,每个元素是size字节.
	stream 输入流
	返回值:实际读取的元素个数.如果返回值与count不相同,则可能文件结尾或发生错误.从ferror和feof获取错误信息或检测是否到达文件结尾.

int fseek( FILE *stream, long offset, int origin );     //重定位流(数据流/文件)上的文件内部位置指针
	第一个参数stream为文件指针
  	第二个参数offset为偏移量,整数表示正向偏移,负数表示负向偏移
  	第三个参数origin设定从文件的哪里开始偏移,可能取值为:SEEK_CUR、 SEEK_END 或 SEEK_SET
  	SEEK_SET: 文件开头
 	SEEK_CUR: 当前位置
  	SEEK_END: 文件结尾
  	其中SEEK_SET,SEEK_CUR和SEEK_END和依次为0,1和2.
	简言之:
  	fseek(fp,100L,0);把fp指针移动到离文件开头100字节处;
  	fseek(fp,100L,1);把fp指针移动到离文件当前位置100字节处;
  	fseek(fp,100L,2);把fp指针退回到离文件结尾100字节处。(根据评论来看,应该是 fseek(fp,-100L,2) )

long ftell(FILE *stream);       //返回当前文件位置,也就是说返回FILE指针当前位置。

char *fgets(char *str, int n, FILE *stream);  //从指定的流stream读取一行,并把它存储在str所指向的字符串内。

int fclose(FILE *stream);       //关闭一个文件流
#include<malloc.h>
extern void *malloc(unsigned int num_bytes);     //分配长度为num_bytes字节的内存块
free();

UEFI应用与编程–ReadSpd

心情感悟:

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/162000.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • windows route命令[通俗易懂]

    windows route命令[通俗易懂]命令:routeprint:打印当前的路由表routedelete:删除一条路由routeadd:增加一条路由,如果最后加上–p选项,表示永久增加静态路由,重启后不会失效routechange:更改一条路由例:routeCHANGE157.0.0.0MASK255.0.0.0157.55.80.5METRIC2IF2CHANGE只用于修改网关和/或跃点数。具体场景:一台电脑通过双网卡,同时连接内网与外网.内网地址10.0.

  • XSRF 的攻击与防范

    XSRF 的攻击与防范官方定义CSRF(Cross-siterequestforgery跨站请求伪造,也被称成为“oneclickattack”或者sessionriding,通常缩写为CSRF或者XSRF,是一种对网站的恶意利用。尽管听起来像跨站脚本(XSS),但它与XSS非常不同,并且攻击方式几乎相左。XSS利用站点内的信任用户,而XSRF则通过伪装来自受信任用户的请求来利用受信任的网站。与XSS

  • 几种常见的损失函数「建议收藏」

    几种常见的损失函数「建议收藏」1.损失函数、代价函数与目标函数  损失函数(LossFunction):是定义在单个样本上的,是指一个样本的误差。  代价函数(CostFun

  • vue js Object转String,String转Object,本地存储「建议收藏」

    vue js Object转String,String转Object,本地存储「建议收藏」将对象转换为json字符串并存储到本地window.localStorage.setItem(‘info’,JSON.stringify(this.form));从本地存储获取json字符串并转换为对象varobj=JSON.parse(window.localStorage.getItem(‘info’));

  • java jasypt_Jasypt「建议收藏」

    java jasypt_Jasypt「建议收藏」软件简介Jasypt这个Java类包为开发人员提供一种简单的方式来为项目增加加密功能,包括:密码Digest认证,文本和对象加密,集成hibernate,SpringSecurity(Acegi)来增强密码管理。Jasypt开发团队推出了Java加密工具Jasypt1.4,它可与SpringFramework、Hibernate和AcegiSecurity集成。与项目有关的一位开发者表示,Ja…

  • quartus II 过期怎么办?

    quartus II 过期怎么办?转自:http://computersren.com/blogs/blogsDetails.aspx?id=20140303205736&id2=new博客内容: quartusII过期怎么办?把电脑的日期改到过期之前的日期就可以啦。因为单位的电脑上装有瑞星杀毒软件,激活成功教程的工具不能用,所以从网上找到这个答案,在网上试一试,还真行,把日期调过了,quartusII就可以用

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号