>我正在尝试计算ALAsset的CRC校验和。我的目标是保存所有CRC,并在以后比较它们以查看资产是否已更改,但是每次为同一资产生成CRC时,都会得到不同的结果。
要生成 CRC,请执行以下操作:
#import "CRC32.h"
#import <zlib.h>
@implementation CRC32
+ (uint32_t)CRC32Value:(NSData*)data
{
uLong crc = crc32(0L, Z_NULL, 0);
crc = crc32(crc, [data bytes], [data length]);
return crc;
}
@end
如何使用:
void(^assetEnumerator)(ALAsset *, NSUInteger, BOOL *) = ^(ALAsset *result, NSUInteger index, BOOL *stop)
{
if(result == nil)
{
return;
}
CrawlAssetData *assetData = [[CrawlAssetData alloc] init];
[assetData setCrc:[CRC32 CRC32Value:[NSData dataWithBytes:&(result)
length:sizeof(result)]]];
以下是我在不同场合为同一资产生成CRC时的结果:
编号: 17575
url: assets-library://asset/asset.JPG?id=BB282CBD-F5B1-4771-B48B-E021224C7384&ext=JPG
文件大小: 1394332
CRC:3605102491
创建时间: 2456085.397025
编号: 17826
url: assets-library://asset/asset.JPG?id=BB282CBD-F5B1-4771-B48B-E021224C7384&ext=JPG
文件大小: 1394332
CRC:1383370697
创建时间: 2456085.397025
如您所见,文件大小和网址相同,但CRC不同。
我计算CRC是不是错了?还是我应该使用 ALAsset 的不同部分来生成 CRC?也许每次检索 ALAsset 时某些数据都不同?
提前感谢!
这一行:
[assetData setCrc:[CRC32 CRC32Value:[NSData dataWithBytes:&(result)
length:sizeof(result)]]];
。正在计算您的 ALAsset 实例地址的 CRC,而不是其数据。
您可以通过拆分行来验证这一点:
NSData *crcData = [NSData dataWithBytes:&(result)
length:sizeof(result)];
NSLog( @"crcData length: %d", [crcData length]);
[assetData setCrc:[CRC32 CRC32Value:crcData]];
我的猜测是,在输出中,您将看到crcData length: 4
.
根据提问者的后续评论(带有更正),执行此操作的代码是:
ALAssetRepresentation *rep = [result defaultRepresentation];
uint8_t *buffer = malloc(rep.size);
NSUInteger buffered = [rep getBytes:buffer
fromOffset:0
length:rep.size
error:nil];
NSData *data = [NSData dataWithBytesNoCopy:buffer
length:buffered
freeWhenDone:YES];
uint32_t CRC32 = [CRC32 CRC32Value:data];
[assetData setCrc:CRC32];
特别要注意的是,sizeof(NSData*)
(或NSData *a; sizeof(A)
)始终是指针的大小(在iPhone等32位系统上为4,对于64位Mac OS X为8),而不是存储在NSData
中的字节数据的长度。没有正常的理由将sizeof()
NSObject 指针获取。