将struct写入映射的内存文件时遇到问题。
我有两个文件,即mmap.write.c和mmap.read.c,在这些文件中,我将一个整数写入文件并从文件中读取。
当我想编写struct并阅读它时,我无法想到这一点,因为在mmap.write.c的第32行
sprintf((char*) file_memory, "%d\n", i);
和mmap.read.c的第25行
sscanf (file_memory, "%d", &integer);
写入和读取整数/双/浮点数/字符等没有区别,因为我可以将模式作为第二个参数"%d"对于整数。但是我会在这里写下来表示结构?这是我的主要问题。
我想写和读的结构:
#define CHANNELS 20
typedef dataholder struct {
int value[CHANNELS];
time_t time;
int hash;
}dataholder;
mmap.read.c
#include <stdlib.h>
#include <stdio.h>
#include <fcntl.h>
#include <sys/mman.h>
#include <sys/stat.h>
#include <unistd.h>
#include "mmap.h"
#define FILE_LENGTH 0x10000
int main (int argc, char* const argv[])
{
int fd;
void* file_memory;
int integer;
/* Open the file. */
fd = open (argv[1], O_RDWR, S_IRUSR | S_IWUSR);
printf("file opened\n");
/* Create the memory mapping. */
file_memory = mmap (0, FILE_LENGTH, PROT_READ | PROT_WRITE,
MAP_SHARED, fd, 0);
printf("memfile opened\n");
close (fd);
printf("file closed\n");
/* Read the integer, print it out, and double it. */
while(1) {
sscanf (file_memory, "%d", &integer);
printf ("value: %d\n", integer);
usleep(100000);
}
//sprintf ((char*) file_memory, "%d\n", 2 * integer);
/* Release the memory (unnecessary because the program exits). */
munmap (file_memory, FILE_LENGTH);
return 0;
}
mmap.write.c
#include <stdlib.h>
#include <stdio.h>
#include <fcntl.h>
#include <sys/mman.h>
#include <sys/stat.h>
#include <time.h>
#include <unistd.h>
#include "mmap.h"
#define FILE_LENGTH 0x10000
/* Return a uniformly random number in the range [low,high]. */
int random_range (unsigned const low, unsigned const high)
{
unsigned const range = high - low + 1;
return low + (int) (((double) range) * rand () / (RAND_MAX + 1.0));
}
int main (int argc, char* const argv[])
{
int fd, i;
void* file_memory;
/* Seed the random number generator. */
srand (time (NULL));
/* Prepare a file large enough to hold an unsigned integer. */
fd = open (argv[1], O_RDWR | O_CREAT | O_APPEND, S_IRUSR | S_IWUSR);
//lseek (fd, FILE_LENGTH+1, SEEK_SET);
write (fd, "", 1);
//lseek (fd, 0, SEEK_SET);
/* Create the memory mapping. */
file_memory = mmap (0, FILE_LENGTH, PROT_WRITE, MAP_SHARED, fd, 0);
close (fd);
/* Write a random integer to memory-mapped area. */
for(i=0; i<10000; i++) {
sprintf((char*) file_memory, "%d\n", i);
//goto a;
usleep(100000);
}
a:
/* Release the memory (unnecessary because the program exits). */
munmap (file_memory, FILE_LENGTH);
return 0;
}
提前多多感谢。
答案 0 :(得分:11)
首先,您必须跟踪要写入的内存中的 where ,其次,您必须记住映射的内存就像任何其他指向内存的指针一样。最后一点很重要,因为这意味着您可以使用普通数组索引来访问内存,或使用memcpy
等函数将其复制到内存中。
要编写结构,您有三种选择:
按原样编写结构,就像在二进制文件中一样。这意味着您必须memcpy
结构到指定位置。
使用例如文本逐字段地编写结构。 sprintf
到正确的位置。
将内存视为一个大字符串,并执行以下操作:每个字段sprintf
放入一个临时缓冲区,然后strcat
将其添加到内存中。
答案 1 :(得分:2)
最简单的方法是使用指针:
dataholder *dh = file_memory;
/* now you can access dh->value, dh->time, dh->hash */
由于此结构不包含任何指针,如果您需要将其复制或输出,您只需指定它,例如:
dataholder dh_other = *dh;
或
*dh = dh_other;