访问结构中的数组会导致发出叮当声警告
struct test{
char c_arr[1];
};
test array[1] = {{1}};
test get(int index){
return array[index];
}
int main(){
char* a = get(0).c_arr;
return 0;
}
编译它g++没有警告但clang++打印以下内容:
warning: temporary whose address is used as value of local variable 'a' will be destroyed at the end of the full-expression
这不正确吗?不get(0).c_arr返回指向全局数组的指针?
还是get(0)返回一个临时变量并且编译器错误地认为c_arr它只是它的一个实例,而不是全局变量?
编辑
为什么将此临时变量传递给函数可以在没有警告的情况下工作?
void call(char* in){}
int main(){
call(get(0).c_arr);
return 0;
}
回答
get按值返回,然后get(0)确实返回一个临时对象,该临时对象在完整表达式之后被销毁,留下a一个悬空指针。
请注意,返回的临时对象test是从 复制的array[index],包括数组数据成员c_arr。a应该指向c_arr临时数据成员数组的第一个元素test,在完整表达式(即;in char* a = get(0).c_arr;)之后,整个临时test(及其数据成员c_arr)被销毁,然后a变成悬空。
如果get按引用返回,那就没问题了。
test& get(int index){
return array[index];
}
编辑
你添加的代码没问题。临时在完整表达式之后被销毁,即在;in之后call(get(0).c_arr);。传递给的指针call在 内保持有效call。