满意答案
hebi333
2013.08.31
采纳率:56% 等级:12
已帮助:12208人
如果说你的困难是处理二进制,这个例子或许可以对你有帮助:
#include
#include
long findHexTar(short tar, FILE *fp)
{
long lSize;
char* buffer;
size_t result;
// 获取文件大小
fseek(fp, 0, SEEK_END);
lSize = ftell(fp);
rewind(fp);
// 分配内存存储文件内容
buffer = (char*)malloc(sizeof(char) * lSize);
// 将文件拷贝到内存
result = fread(buffer, 1, lSize, fp);
long nPos = 0;
while ( nPos < sizeof(char) * lSize - 1) // 文件最后一个字节位置不可取
{
if ( *(short*)(buffer + nPos) == tar )
break;
else
nPos++; // 查找位置每次只偏移一个byte
}
free(buffer);
return nPos;
}
int main()
{
FILE* fp = fopen("my.bin", "rb");
short tar = 0x5A4D; // 你想要找的一个十六进制数,可以是一个Unicode字符编码值
long nPos = findHexTar(tar, fp);
printf("Found 0x%.04X at offset %d bytes",tar, nPos);
getchar();
return 0;
}
这段代码演示的是在二进制文件中查找一个对应的short值,当然你应该知道Unicode编码就是一个short值,你将字符串转化为16进制,看到的也是一串数字,你只是要找数字而已。
如果short不能满足要求,上面代码稍加修改可以查找long型、char型(即单个byte)数值。
字符串的查找问题,你会点算法应该不难实现,跟查找文本一样,只是有时不能用char*去解决。
00分享举报