运行:
编辑一个bat批处理脚本文件,如下所示,双击该bat文件即可
python bin2c.py test.bin
pause
这个要看文件是什么样的格式保存数据的,是字符串方的二进制数据,还是二进制数,每个数据怎么样保存的,比如字符串数据,数据之间是什么符号分割的。访问文件的函数是这些:
首先打开文件:fopen
读文件数据:fread
读完关闭文件:fclose
如果读入的是字符串类型,要把字符串数值转为int类型,再保存到数组。
这个问题你要说清楚,最好把你现有的代码贴出来,别人才好帮你。
使用read()函数以下为百度百科的介绍函数名:read
功 能:从文件中读
函数原型 :int read(int handle, void *buf, int nbyte)
表头文件:#include <unistd.h>
函数说明:read()会把参数handle所指的文件传送nbyte个字节到buf指针所指的内存中。若参数nbyte为0,则read()不会有作用并返回0。返回值为实际读取到的字节数,如果返回0,表示已到达文件尾或无可读取的数据。
程序例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
#include <stdio.h>
#include <io.h>
#include <alloc.h>
#include <fcntl.h>
#include <process.h>
#include <sys\stat.h>
int main(void)
{
void *buf
int handle, bytes
buf = malloc(10)
/*
Looks for a file in the current directory named TEST.$$$ and attempts
to read 10 bytes from it. To use this example you should create the
file TEST.$$$
*/
if ((handle =
open("TEST.$$$", O_RDONLY | O_BINARY, S_IWRITE | S_IREAD)) == -1)
{
printf("Error Opening File\n")
exit(1)
}
if ((bytes = read(handle, buf, 10)) == -1) {
printf("Read Failed.\n")
exit(1)
}
else {
printf("Read: %d bytes read.\n", bytes)
}
return 0
}
2Linux C
编辑
定义函数
ssize_t read(int fd, void *buf, size_t count)
返回值
成功返回读取的字节数,出错返回-1并设置errno,如果在调read之前已到达文件末尾,则这次read返回0。
参数
参数count是请求读取的字节数,读上来的数据保存在缓冲区buf中,同时文件的当前读写位置向后移。注意这个读写位置和使用C标准I/O库时的读写位置有可能不同,这个读写位置是记在内核中的,而使用C标准I/O库时的读写位置是用户空间I/O缓冲区中的位置。比如用fgetc读一个字节,fgetc有可能从内核中预读1024个字节到I/O缓冲区中,再返回第一个字节,这时该文件在内核中记录的读写位置是1024,而在FILE结构体中记录的读写位置是1。注意返回值类型是ssize_t,表示有符号的size_t,这样既可以返回正的字节数、0(表示到达文件末尾)也可以返回负值-1(表示出错)。
read函数返回时,返回值说明了buf中前多少个字节是刚读上来的。有些情况下,实际读到的字节数(返回值)会小于请求读的字节数count,例如:读常规文件时,在读到count个字节之前已到达文件末尾。例如,距文件末尾还有30个字节而请求读100个字节,则read返回30,下次read将返回0。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)