这是我的问题:
/**
* Example of the book:
* C++ Templates page 17/18
*/
#include <iostream>
#include <cstring>
#include <string>
// max of two values of any type (call by reference)
template <typename T>
inline T const& max (T const& a, T const& b) {
return a < b ? b : a;
}
// max of two C-strings (call by value)
inline char const* max (char const* a, char const* b) {
// ??? Creates this a new temporary local value that may be returned?
// I can't see where the temporary value is created!
return std::strcmp(a,b) < 0 ? b : a;
}
// max of three values of any type (call by reference)
template <typename T>
inline T const& max (T const& a, T const& b, T const& c) {
return max (max(a,b),c); // warning "error", if max(a,b) uses call-by-value
// warning: reference of temp value will be returned
int main() {
// call by reference
std::cout << ::max(7, 42, 68) << std::endl;
const char* s1 = "Tim";
const char* s2 = "Tom";
const char* s3 = "Toni";
// call the function with call by value
// ??? Is this right?
std::cout << ::max(s1,s2) << std::endl;
std::cout << ::max(s1, s2, s3) << std::endl;
}
C-strings函数max中的临时局部值在哪里?
该函数有两个指针,为什么它是按值调用?
抱歉,我认为这是一个非常愚蠢的问题,但我不明白。
谢谢。
答案 0 :(得分:2)
C-strings函数max中的临时局部值在哪里?
以下内容:
return std::strcmp(a,b) < 0 ? b : a;
相当于:
const char *ret = std::strcmp(a,b) < 0 ? b : a;
return ret;
我预计相关的“临时本地值”是ret
的未命名等效值。
该函数有两个指针,为什么它是按值调用?
每个C字符串由const char*
表示,const char*
按值传递。这意味着如果函数要修改a
或b
(即指针本身),则调用者将无法看到修改。