我在这行中遇到了段错误:
if(memcmp(datap, 0x38 , 1) == 0)
这是来自gdb的跟踪,你可以在这里看到datap:
Program received signal SIGSEGV, Segmentation fault.
0x00000000004010f1 in processMTMHeader (
datap=0x2aaaab0b001c "1\34\66\63\36\65\34\66.\36\70\34AAAA1.ETR\36\67\64\34U\35\36\61\60\63\34\61\36\62\65\70\34\60\71:00:00\36\62\70\61\34\60\71:00:00\36\64\62\67\34\63\60\60\60\36\65\63\34\63\36\66\63\34\63\36\66\67\34\63\36\70\60\34\63\36\70\61\34\61\60\60\60\36\70\62\34\60\71:00:00\36\70\63\34\61\60\60\60\3Ea", h=0x7fffffffb960,
endmmsgp=0x2aaaab0b0090 "\3Ea") at unzipper.c:91
91 if(memcmp(datap, 0x38 , 1) == 0)
答案 0 :(得分:4)
您使用整数值0x38
作为指针,这很可能不是一个好主意。
你可能应该:
const uint8_t data[] = { 0x38 };
if(memcmp(datap, data, sizeof data) == 0)
或者,当然,因为它只是一个字节:
if(((uint8_t *) datap)[0] == 0x38)
更新假设datap
被声明为unsigned char *datap
,我们可以放弃演员而只是这样做:
if(*datap == 0x38)