在这段代码中使用 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 (将#修改为@)