首页 > 其他分享 >离奇的std::map、std::set崩溃

离奇的std::map、std::set崩溃

时间:2023-07-10 18:26:24浏览次数:40  
标签:std map set so sm find

离奇的std::map、std::set崩溃

现象描述

在一个动态库里使用了std::map和std::set,在windows上用VS2010调试一切正常。但在linux下,用的是Ubuntu64位虚拟机调试,编译链接都OK,但只要调到这个so库里的使用std::map和std::set的地方,这些变量在qt调试里都是**<无法访问>,而且只要调用这些变量的非size()接口,比如find()、insert()等接口都会导致程序崩溃**。
郁闷之间。。。。。。

定位之路

1、和windows调用比较,没发现任何问题

2、修改cmakelists.txt,发现也没有什么可以改的,能改的怎么改结果都一样

3、最笨的办法之一用上,写一段这样的代码:

typedef map<string, void*> STRMAP;
STRMAP sm;
string str = “sdfasf”;
STRMAP::iterator it = sm.find(str);
sm.insert(std::make_pair(“fasf”, &sm));
it = sm.find(str);
放到可执行程序里调用,没有任何问题;放到so里的接口里的开始,按说单步到string str = “sdfasf”;时,sm应该被初始化,变量里能看到sm的值,但实际上sm的值就是<无法访问>,再往下执行find()这一句,就崩溃了。

4、面向互联网大法编程,百度、微软必应(不FQ,不能狗狗),发现一个帖子,缩小有问题代码的范围,于是

5、最笨的办法之二用上,缩小so代码范围

so之保留一个接口,接口里之保留上面的那一段代码,sm值可见了,find()、insert()接口可以正常调用;
再一点一点把代码还原,终于定位到了问题

std::map、std::set崩溃的终极原因

经过上述各种定位,耗时106060秒,终于定位到令人吐血的原因:
so里#include了一个某标准头文件,该头文件里在结构体定义的前面有一句#pragma pack(x),但后面并没有还原,于是前后分别加上#pragma pack(push)、#pragma pack(pop),单步时变量变得可见,调用std::map和std::set的find()、insert()等方法恢复正常,不再崩溃!
为了确认问题,把加的#pragma pack(push)、#pragma pack(pop)注掉,问题立马复现,加上立马变好。
为什么会这样?so里有很多代码文件,有的没有引用这个头文件,但直接#include < map >
#include < set >,有一个cpp文件是先引用了这个标准头文件,而后再#include < map >
#include < set >,导致同一个so里map、set字节对齐不一致。但为什么windows下正确,但linux下却异常崩溃?

标签:std,map,set,so,sm,find
From: https://www.cnblogs.com/lidabo/p/17541899.html

相关文章

  • LWC 50:677. Map Sum Pairs
    LWC50:677.MapSumPairs传送门:677.MapSumPairsProblem:ImplementaMapSumclasswithinsert,andsummethods.Forthemethodinsert,you’llbegivenapairof(string,integer).Thestringrepresentsthekeyandtheintegerrepresentsthevalue.Ifthekey......
  • UE5 Set Show Mouse Cursor进入游戏显示鼠标
    前言默认情况下进入游戏不点击情况下,鼠标是默认不显示的。为了显示鼠标,可以调用SetShowMouseCursor节点操作默认情况下如果勾选ContextSensitive(情景关联),是无法搜索到相关函数,必须去掉勾选,如下......
  • globalmapper加载DOM显示无法确定投影和datum
    Theprojection/datumofthisGeoTIFFfilecouldnotbedeterminedautomatically.Pleaseconfirmtheprojection/datumforthisfile.Checkwithyourdatasupplierforthisinformationifyoudonothaveit.选择loadfromfile,选择arcgis导出的某个矢量文件的.prj文......
  • mapbox_master
    1.项目描述根据奔跑吧面条的**vue-big-screen**开源框架基础上进行修改。项目需要全屏展示(按F11)。项目部分区域使用了全局注册方式,增加了打包体积,在实际运用中请使用按需引入。项目环境:Vue-cli、DataV、Echarts、Webpack、Npm、Node,axios,mock。请拉取master分支的代码,其......
  • AssetBundle.Unload(true)无法卸载图集
    1)AssetBundle.Unload(true)无法卸载图集​2)关于Unity2D游戏地图预加载的问题3)Addressables能否支持某些资源不打Bundle直接加载源文件这是第342篇UWA技术知识分享的推送,精选了UWA社区的热门话题,涵盖了UWA问答、社区帖子等技术知识点,助力大家更全面地掌握和学习。UWA社区主页:co......
  • js/ts文件中,导入i18n报错:Must be called at the top of a `setup` function
    import{useI18n}from'vue-i18n';const{t}=useI18n(); 会在非组件情况下报错: 此时我们需要将上述导入方式改为:importi18nfrom'@/lang/i18n';//@/lang/i18n为语言包位置const{t}=i18n.global;......
  • HashMap 源码阅读
    HashMap源码阅读HashMap是线程不安全的,若需要考虑线程安全则需要用HashTable属性//默认大小1<<4为16staticfinalintDEFAULT_INITIAL_CAPACITY=1<<4;//最大2的30次方staticfinalintMAXIMUM_CAPACITY=1<<30;//默认负载因子0.75staticfinal......
  • Mapbox、GeoServer离线部署矢量地图
    Mapbox、GeoServer离线部署矢量地图关键词:Mapbox、GeoServer、Tomcat、PostgreSQL、PostGis一、地图数据获取使用OpenStreetMap获取中国的矢量地图数据二、安装GeoServer及VectorTiles扩展将下载好的GeoServer.war放入Tomcat,启动Tomcat后将VectorTiles扩展中的四个jar包放入GeoSe......
  • 【cs50】lab7 & problem set7
    (1)lab7songssqlite3songs.db1)listthenamesofallsongsinthedatabaseSELECTnameFROMsongs;2)listnamesofallsongsinincreasingorderoftempoSELECTnameFROMsongsORDERBYtempo;3) listthenamesofthetop5longests......
  • bitmap
    bitmap使用情景用户签到,打卡,电影广告是否被点击过docker进入redisdockerexec-it<container_name>redis-cli常用指令setbit键值offset(从0开始)0|1getbit键值offsetstrlen键值(统计的是字节数占用多少:例如我们只SETBITa101和SETBITa111,strlena1......