Рассмотрим следующий пример кода:
#include <iostream>
#include <inttypes.h>
using namespace std;
int f(uint32_t i)
{
return 1;
}
int f(uint64_t i)
{
return 2;
}
int main ()
{
cout << sizeof(long unsigned) << '\n';
cout << sizeof(size_t) << '\n';
cout << sizeof(uint32_t) << '\n';
cout << sizeof(uint64_t) << '\n';
//long unsigned x = 3;
size_t x = 3;
cout << f(x) << '\n';
return 0;
}
В Mac OSX это не работает:
$ g++ --version
i686-apple-darwin10-g++-4.2.1 (GCC) 4.2.1 (Apple Inc. build 5664)
$ make test
g++ test.cc -o test
test.cc: In function 'int main()':
test.cc:23: error: call of overloaded 'f(size_t&)' is ambiguous
test.cc:6: note: candidates are: int f(uint32_t)
test.cc:10: note: int f(uint64_t)
make: *** [test] Error 1
Почему? Потому что 'size_t' должен быть неподписанным и 32-битным или 64-битным. Где тогда двусмысленность?
Попытка того же с "unsigned long x" вместо "size_t x" приводит к аналогичное сообщение об ошибке двусмысленности.
В системах Linux/Solaris, тестировании с разными версиями GCC, разных архитектурах и т.д. нет двусмысленности (и правильная перегрузка используется для каждой архитектуры).
Является ли это ошибкой Mac OS X или функцией?