今天碰到了一个非常奇怪的现象,求高人指点。
用的海思的linux内核,版本3.10
情况分为以下三个时间段:
1. 定义了一个全局结构体变量 A ,开机读配置文件,把文件里的参数读到 A 里,然后把该参数全部打印出来。
2. 然后开启了一个线程,根据 A 里存的服务器地址,连接服务器,并打印该地址,结果发现服务器地址不对,跟开机时读的参数不一致。
3. 发现不一致之后,我在主线程里调用打印参数的函数查看服务器地址,看是否有改动,结果发现此时打印的服务器地址与开机显示的一致
也就是在不同线程里,读出来的值不一样,为什么会出现这样的情况呢?
如果说是变量被修改了,那么我在2里发现变量变化了,在3里打印的时候,应该也是被修改的,但是在3里打印的时候却是和1里的值是一样的