给作为线程初始函数的函数传递传递参数时,为了解决不适用在主线程中传递进来的参数的原来的内存,希望使用一个新的内存来进行保存变量的值
的时候,使用了隐式转换,如把char的数组转换为了string,你可以直接使用shift+f9
进行debug的内存查看,也可以这样进行
class A
{
public:
int AInnerValue;
//构造函数,这个构造函数,可以隐式地把int转换为A对象
A(int num) :AInnerValue(num) { cout << "A的!!!构造!!!函数执行,A为:" << this << endl; }
//拷贝函数
A(const A &a):AInnerValue(a.AInnerValue){ cout << "A的!!!拷贝!!!函数执行,A为:" << this << endl; }
//析构函数
~A(){ cout << "A的!!!析构!!!函数执行,A为:" << this << endl; }
};
void finalTest(A& a)
{
cout << &a << endl;
}
int main()
{
int MainValue = 1;
//这里,传进去的是一个int,但是A类的构造函数可以把它转化为A类
//这就是隐式转换,通过A的生命周其有关的函数,我们可以看到
thread myThread(MainValue);
myThread.detach();
}
可以看到,这里出现了,根本没有进行隐式转换时,主线就已经结束了的情况,因为没有打印任何A类的信息,这样,程序就出现安全隐患了
那么如何解决呢?
来创建临时变量吧,少年,这样就安全了
把main函数改造成如下
int main()
{
int MainValue = 1;
//这里创建了一个A的临时变量
thread myThread(finalTest,A(MainValue));
myThread.detach();
}
你会问你会为这样就安全了吗?,这样能保证主线程中的变量销毁之前,一定能创建出来新的临时变量吗?
答案是一定能,少年,神不神奇?
可以看到,实际上传递进去的是用拷贝函数拷贝进去的对象,临时变量很快就执行了析构函数,销毁了