首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > C++ >

求boost序列化库对于磁盘空间不足的处置方案

2013-03-29 
求boost序列化库对于磁盘空间不足的处理方案 使用boost序列化库实现数据对象的存储,如果在未完全写入的时

求boost序列化库对于磁盘空间不足的处理方案
 使用boost序列化库实现数据对象的存储,如果在未完全写入的时候由于磁盘空间不足而导致出现异常,而此时的文件已经写入一部分,即造成了文件的不完整。请问有没有什么解决方案来处理这个问题? boost序列化?磁盘空间不足
[解决办法]
这恐怕不是boost库能解决的。
建议你是序列化到内存,然后由内存一起写文件。

[解决办法]
原子操作:按整个对象序列化,而不是对象的字段逐个序列化。 要么全完成,要么删除部分写入的内容。
[解决办法]

引用:
引用:引用:
引用:原子操作:按整个对象序列化,而不是对象的字段逐个序列化。 要么全完成,要么删除部分写入的内容。
部分对象写入成功,部分不成功,那整个文件还是破坏了,还是不能在出错时恢复到写入之前的状态。要是有一种类似于数据库中事务处理的办法就好了。
……

流对象都有缓冲,确保不把部分序列号的对象提交到物理文件就可以了。
[解决办法]
写盘前判断磁盘剩余空间。
Linux:
system("df >df.txt");
//然后读文件df.txt的内容。
Windows:
GetDiskFreeSpace
The GetDiskFreeSpace function retrieves information about the specified disk, including the amount of free space on the disk. 

This function has been superseded by the GetDiskFreeSpaceEx function. New Win32-based applications should use GetDiskFreeSpaceEx. 

BOOL GetDiskFreeSpace(
  LPCTSTR lpRootPathName,    // pointer to root path
  LPDWORD lpSectorsPerCluster,  // pointer to sectors per cluster
  LPDWORD lpBytesPerSector,  // pointer to bytes per sector
  LPDWORD lpNumberOfFreeClusters,
                             // pointer to number of free clusters
  LPDWORD lpTotalNumberOfClusters 
                             // pointer to total number of clusters
);
 
Parameters
lpRootPathName 
Pointer to a null-terminated string that specifies the root directory of the disk to return information about. If lpRootPathName is NULL, the function uses the root of the current directory. If this parameter is a UNC name, you must follow it with an additional backslash. For example, you would specify \\MyServer\MyShare as \\MyServer\MyShare\. 
Windows 95: The initial release of Windows 95 does not support UNC paths for the lpszRootPathName parameter. To query the free disk space using a UNC path, temporarily map the UNC path to a drive letter, query the free disk space on the drive, then remove the temporary mapping. Windows 95 OSR2 and later: UNC paths are supported. 

lpSectorsPerCluster 
Pointer to a variable for the number of sectors per cluster. 
lpBytesPerSector 
Pointer to a variable for the number of bytes per sector. 


lpNumberOfFreeClusters 
Pointer to a variable for the total number of free clusters on the disk that are available to the user associated with the calling thread. 
Windows NT 5.0 and later: If per-user disk quotas are in use, this value may be less than the total number of free clusters on the disk. 

lpTotalNumberOfClusters 
Pointer to a variable for the total number of clusters on the disk that are available to the user associated with the calling thread. 
Windows NT 5.0 and later: If per-user disk quotas are in use, this value may be less than the total number of clusters on the disk. 

Return Values
If the function succeeds, the return value is nonzero.

If the function fails, the return value is zero. To get extended error information, call GetLastError. 

Remarks
The GetDiskFreeSpaceEx function lets you avoid the arithmetic required by the GetDiskFreeSpace function. 

Windows 95: 
The GetDiskFreeSpace function returns incorrect values for volumes that are larger than 2 gigabytes. The function caps the values stored into *lpNumberOfFreeClusters and *lpTotalNumberOfClusters so as to never report volume sizes that are greater than 2 gigabytes. 
Even on volumes that are smaller than 2 gigabytes, the values stored into *lpSectorsPerCluster, *lpNumberOfFreeClusters, and *lpTotalNumberOfClusters values may be incorrect. That is because the operating system manipulates the values so that computations with them yield the correct volume size. 

Windows 95 OSR2 and later: 
The GetDiskFreeSpaceEx function is available on Windows 95 systems beginning with OEM Service Release 2 (OSR2). The GetDiskFreeSpaceEx function returns correct values for all volumes, including those that are greater than 2 gigabytes. 
QuickInfo
  Windows NT: Requires version 3.1 or later.
  Windows: Requires Windows 95 or later.
  Windows CE: Unsupported.
  Header: Declared in winbase.h.
  Import Library: Use kernel32.lib.
  Unicode: Implemented as Unicode and ANSI versions on Windows NT.

See Also
File I/O Overview, File Functions, GetDiskFreeSpaceEx, GetDriveType 

 

[解决办法]
写入前先备份文件,成功则删除备份,失败则恢复备份,这才是成功之道!

以冗余保证数据安全,是赵老师一直以来苦口婆心的教导!

少年啊,要时刻以牢记赵老师的话而感到自豪!


[解决办法]
先写log,后写库,数据库都是这么干的
[解决办法]
写到内存先,然后判断大小,看disk空间还够。

热点排行