什么时候使用size_t作为模板函数的参数是个坏主意
When is it a bad idea to use size_t as a parameter for a template function?
什么时候使用size_t作为模板函数的参数是个坏主意?我知道size_t是一个无符号的int,但我的教授在课堂上提到,将size_t用作模板类的参数是不好的。有什么想法吗?
使用size_t
作为模板参数没有错。
使用任何类型作为模板参数都没有错。
按您的意愿进行解释,但在Win32 API中为ReadFile()
和许多其他函数编码时,TCC和GCC不会悄悄接受size_t
或unsigned int
。如果被指示,它必须是DWORD
。没有例外。API refs非常明确地指出了这一点,否则编码很快就会告诉你他们是认真的。做任何不同的事情,你也会留下各种丑陋的铸造。
我觉得奇怪的是,我接受了那些我认为比我更了解size_t的人的支持。(大多数人都这样做,在一般的程序员中!)他们出于"可移植性"的原因支持size_t。奇怪的是,他们在决定什么是"可移植的"时没有考虑与Win32 API的兼容性。
事后看来,我自己的观点是,不允许这样的人对你说教。正如上面给出的"问题C"的简短回答所示,任何类型都可能有效。当然,重点是定义,意思是,我们应该知道我们选择了什么,以及为什么。通常有更大的理由来确定与某个主机匹配的代码的适当方法,例如程序的目的。没有任何类型,没有任何编译器能够为做出这些决定做好充分的准备。这是我们的工作。上下文就是一切,认为仅仅根据一个不知道我们在做什么的人的建议选择一种变量类型就可以实现最终的兼容性或可移植性是愚蠢的。网络越是破坏越来越多的浏览器和网站,这一点就越明显。
出于"可移植性"的原因,发明另一种"类型"最终与订购"一个环来绑定它们"一样有意义。
我能想到的唯一原因是size_t在32位和64位中的大小不同。如果您在某种序列化模板函数中使用它,那么在32位代码中序列化的数据将与64位代码不兼容。这更像是序列化size_t的问题,而不是模板特有的问题。如果你问你的教授,我很想听听他说什么!
- 将可变参数函数的参数封装在类实例中
- QML 使用带有参数C++函数
- 使用可变参数函数作为模板参数
- 如何在C++中伪造虚拟可变参数函数模板?
- 为什么可变参数函数不适用于模板
- C++ std::functional 中的可变参数函数模板
- 可变参数函数指针的定义对于VxWorks spyLib来说不清楚
- 使用可变参数函数覆盖具有不同函数签名的虚函数
- 考虑引用和常量的可变参数函数包装器
- 使用可变参数函数将整数和/或整数数组放入单个 int 数组中
- 在可变参数函数中转发特定范围的参数
- 通过引用传递参数;函数返回类型是否必须为 VOID?
- 使用带有一个参数函数的递归找到数字的平方
- 可变参数函数模板不能很好地使用 std::function 作为参数
- 多个可变参数函数的单个模板参数包?
- 参数数据类型未知的可变参数函数
- 可变参数函数参数包扩展
- 使用模板可变参数函数将多个参数传递给另一个函数
- 对可变参数函数的递归调用的链接器错误
- 通过像printf这样的可变参数函数传递一个带有常量字符*转换函数的类