gpt4 book ai didi

objective-c - 使用 getBytes 扫描文件 :range:?

转载 作者:行者123 更新时间:2023-12-03 17:52:19 25 4
gpt4 key购买 nike

我当前正在使用以下代码扫描二进制文件:

 while (offset < headerLength) {
memset(buffer, 0, sizeof(buffer));
[bookData getBytes:buffer range:NSMakeRange(0 + offset, 4)];
NSString *output = [NSString stringWithCString:buffer encoding:NSUTF8StringEncoding];

if ([output isEqualToString:@"EXTH"]) {
...
}
offset++;
}

但是,我怀疑这不是正确的方法,因为它非常慢。那么如何搜索特定的字符串呢?

好但慢:

while (offset < headerLength) {
memset(buffer, 0, sizeof(buffer));
[bookData getBytes:buffer range:NSMakeRange(0 + offset, 4)];

if (buffer[0] == 'E' && buffer[1] == 'X' && buffer[2] == 'T' && buffer[3] == 'H') {
//run my stuff
break;
}
offset++;
}
memset(buffer, 0, sizeof(buffer));

不运行我的东西

FILE * handle = fopen ([path UTF8String], "r");
while (1) {
fseek(handle, ++offset, SEEK_SET);
if (fgets(buffer, 4, handle)) {
if (buffer[0] == 'E' && buffer[1] == 'X' && buffer[2] == 'T' && buffer[3] == 'H') {
//doesn't run my stuff
break;
}
}
}
fclose(handle);

最佳答案

IO 很慢,因此我会读取大块并避免从循环内的流中读取小块。 getBytes:将 NSData 对象的字节复制到缓冲区中,因此您也希望避免频繁这样做。这是一些未经测试的伪代码,假设您有 NSData 对象开始:

const char *bytes = [bookData bytes];
while (offset < headerLengh - 4)
{
if (bytes[offset] == 'E' && bytes[offset + 1] == 'X' && bytes[offset + 2] == 'T' && bytes[offset + 3] == 'H')
{
//...
}
offset++;
}

我会注意到,对于这种类型的搜索,存在更快/更复杂的算法,例如 boyer-moore,但目前应该可以。

我还建议不要在循环内创建许多 NSString 对象。如果需要,您可以从 NSData 对象创建一个 NSString,并适本地检索循环内的子字符串。

关于objective-c - 使用 getBytes 扫描文件 :range:?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22813138/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com