客户问题
曾经有个客户报了个一级的问题,一级意味着support5*24小时支持直到解决,因为我们全球各地都有分公司,所以24小时很容易,基本是中国、澳大利亚->英国->美国。不过这种情况support往往会向开发求助。
我们看了一下,有个deamon hang在那不动了,原因是有条数据的flag字段是0,这是不应该的。要找到怎么产生的可能要花费一阵子功夫,不过直接修改他们的内存把flag置为有效值还是很容易的,先让客户程序正常往下运行为当务之急。
模拟程序
原始问题和代码肯定不能公开了,但为了使问题容易描述,我写了一个模拟程序。
[mzhai demo_gdb_skills]$ cat changeLiveData.c
#include<stdio.h>
#include<stdlib.h>
typedef struct {
int i3;
int i4;
} Ctl_internal;
typedef struct Ctl{
int i1;
int i2;
Ctl_internal *ci;
} Ctl;
Ctl *ctl_ptr;
void main(){
Ctl ctl = {1,2,0};
ctl_ptr = &ctl;
ctl_ptr->ci = malloc(sizeof(Ctl_internal));
ctl_ptr->ci->i3=3;
ctl_ptr->ci->i4=0;
while(!ctl_ptr->ci->i4){
sleep(1);
}
printf("exit