libjpeg是一个非常古老的代码,但居然是c/c++世界里面唯一读写jpg格式的代码。古老的jpeg竟然用到一个叫setjmp的非结构动态跳转语句。
问题描述:
在ubuntu中交叉编译QNX上运行的opencv的imgcodecs库。imgcodecs会调用libjpeg这个库,所以同时交叉编译了libjpeg。
在本地编译libjpeg都能正常工作,但交叉编译放到target平台后,相同的图片就读不出来了。如果你是连带opencv的imgcodecs编译的话,具体的现象是:
- JpegDecoder::readHeader()中jpeg_create_decompress( &state->cinfo );函数进去就不执行下面的语句了。
if( setjmp( state->jerr.setjmp_buffer ) == 0 )
{
...
jpeg_create_decompress( &state->cinfo );
...
}else{
}
- 其实函数的逻辑是第一次setjmp的时候,返回值非零,所以进入if。然后进入jpeg_create_decompress后,竟然程序就直接跳过jpeg_create_decompress后的代码,开始执行else里面的代码。这个就是setjmp的作用。
- setjmp相当于设置了一个跳转的目标,另外还有一个配对的行数叫longjmp,longjmp的作用是跳转到setjmp被调用的地方。jpeg_create_decompress中遇到错误后,调用了longjmp返回if语句。然后因为jpeg_create_decompress同时撤销了跳转标示(state->jerr.s