我只是想知道STL容器的范围。
例如。 //有一个创建unordered_map的函数,并传递给set_map来填充其中的值。
int foo() {
unorderd_map<char,int>mymap;
set_map(mymap);
}
set_map (unorderd_map<char,int> mmap){
//...setting values of map
}
在这种情况下,foo中mymap的范围是仅限于函数foo()还是通过引用set_map()传递mymap,并且在set_map中完成的任何更改都将反映到foo()中的mymap?
我还想知道仍然将容器作为函数参数传递,即它们是按值传递还是通过引用传递。
谢谢
答案 0 :(得分:2)
mymap
已将作为副本传递给set_map
,因此set_map
只会看到自己的地图副本,而不是原始的mymap
。 set_map
中所做的更改仅适用于副本,不会影响原始mymap
。
要通过引用传递地图,您需要明确声明它:
set_map (unordered_map<char,int>& mmap)
// ^ will be passed by reference now.
现在set_map
中的更改将改变作为参数传递的原始对象。
答案 1 :(得分:1)
您已将set_map()
的参数定义为按值传递。所以这个函数将在它自己的副本上工作。对于调用者(mymap
未更改),将在其中执行的操作将丢失。
评论:容器使用动态分配,原则如下:
unordered_map
之类的容器时,它是该函数的本地。 unordered_map
也是如此。 在C ++中,您不应该担心标准容器的实现方式,而应该关注它们实现的语义。因此,无论分配的实现如何,本地对象仍然是本地的。但正如Zenith已经表明的那样,你可以轻松地复制它,或通过引用传递它。