如何解决在这段代码中使用 size_t 比 int 有什么优势吗?
#include <iostream>
#include <array>
int main()
{
std::array myArray { 7,3,1,9,5 };
// Iterate through the array and print the value of the elements
for (int i{ 0 }; i < myArray.size(); ++i)
std::cout << myArray[i] << ' ';
std::cout << '\n';
return 0;
}
据说 存在有符号/无符号不匹配。运算符 [] 的 size() 函数和数组索引参数使用称为 size_type 的类型。我们的循环计数器/索引(变量 i)是一个有符号整数。因此,比较 i
我理解这句话,但这种不匹配的后果是什么? 我的 IDE (VS2019) 既没有给出错误也没有警告。在此代码中使用 std::size_t 代替 int 是否有任何性能优势?
#include <array>
#include <cstddef> // std::size_t
#include <iostream>
int main()
{
std::array myArray { 7,5 };
for (std::size_t i{ 0 }; i < myArray.size(); ++i)
std::cout << myArray[i] << ' ';
std::cout << '\n';
return 0;
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。