- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的程序中有一个奇怪的错误,归结为(对我而言)在 int 和 vector::size_type 之间进行减法时的意外行为。这是一个简单的例子:
#include <iostream>
#include <vector>
typedef std::vector<double> state_type;
int n = 1;
int main() {
state_type::size_type i = 0;
std::cout << i - n << std::endl;
}
我希望这个程序打印-1,但它打印了(在 64 位 Linux 下用 icc 14.0.1 编译):
18446744073709551615
我目前的解释是 size_type 是无符号的,这会导致一些奇怪的(?)转换?很长一段时间后我才发现这个错误,我很惊讶会发生这种情况。现在我的问题是如何避免这些类型的错误,假设在一些 for 循环中迭代 std::vector:
int n = 2;
for(state_type::size_type i = 0; i < my_vec.size(); ++i) {
if(i - n >= 0)
my_vec[i - n] += 3;
}
当然我可以把 i 当作一个 int,但是不建议对这种循环使用 size_type 吗?什么是更好的方法呢?还是我是唯一对这种转变感到惊讶的人?
最佳答案
这是 C++ 标准库中的一个设计缺陷。未签名的C++ 中的类型有点特殊,不应该用于算术量。有符号和无符号混合的方式是均匀的更特殊,更应该避免。解决办法是不使用 size_t
或 size_type
类型定义,除了极其有限的情况下,显式转换的返回值container::size()
等为有符号整数类型。 (多数情况应用程序,int
是安全的;如有疑问,ptrdiff_t
可以是用于避免溢出。)
关于c++ - 在 C++ 中使用 size_type 时,推荐使用 for 循环索引进行算术运算的方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20700224/
在我的 for 循环中声明迭代器时研究无符号整数与有符号整数比较警告时,I read this : Whenever possible, use the exact type you will be
我有一个 std::map, float>这占用了太多内存,为了使用更少的内存,我决定将唯一字符串映射到整数(例如 std::map ,其中每个新的唯一字符串都映射到 map 的当前 size() )
文档说,std::vector 的 size_type 是/usually/size_t,这是合理的,因为实现可以选择使用不同的。 但是为什么 size_type = size_t 位于 std::a
以下代码片段编译失败: #include #include #include #include using namespace std; vector list1{1,3,5,7,11}; s
我正在编写自定义算法,有时它需要获取两个迭代器之间的距离。如果我假设 it1
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求提供代码的问题必须表现出对所解决问题的最低限度理解。包括尝试过的解决方案、为什么它们不起作用,以及预
std::vector的成员类型为size_type。它的printf格式说明符是什么? 请注意,size_type与size_t不同。 https://en.cppreference.com/w/c
我在这里浏览了一些关于 string::size_type 的线程,根据 C++ 标准,我确实理解这个 size_type 保证了所有字符串使用的足够分配。 我只是觉得很难相信。如果我将 C++ Pr
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
我有一个类,它有一个类型为 vector 的私有(private)数据成员. 该类有两个实际使用vector::size_type 的公共(public)方法: 返回 vector 中元素个数的方法
在 C++ 模板中,我很难用正确的 size_type 定义变量。基本上,这将是容器中的索引类型。我知道 int 可以工作,但希望以干净的形式使用它。 template void test(Forwa
假设我有两种类型,Class1和 Class2 .然后我创建两个 vector : vector vec1; vector vec2; //create vec1 and vec2, such tha
我在一些非常有名的 C++ 书籍中看到 -- vector ivec; for (vector::size_type i = 0; i != 10; ++i) { ivec.push_back
我想以一种简单的方式编写基于索引的 for 循环。由于我的代码必须在 32 位和 64 位中运行,我收到很多关于隐式转换的警告,因为我通常使用 32 位整数,但 STL 在 64 位中使用 64 位整
我的背景主要是 R、SAS 和 VBA,我正在尝试学习一些 C++。我选择了“Accelerated C++”(Koenig,Moo)作为我关于该主题的第一本书。我在 comp 的理论背景。科学。诚然
下面的类不编译: template, class Allocator = std::allocator> class MyContainer { public: std::vector d
我经常有一些类,它们大多只是一些 STL 容器的包装器,如下所示: class Foo { public: typedef std::vector Vec; typedef Vec::size
显然,unordered_set::erase和 unordered_set::count返回一些不是严格 bool 值的东西(从逻辑上讲,也就是说,我不是在谈论实际类型)。 链接页面读取第三个版本的
#include #include using namespace std; int main() { vector student_marks(20); for (vector:
我一直在通过在不同平台上编译我的应用程序来对其进行一些测试,从 64 位系统到 32 位系统的转变暴露出许多问题。 我大量使用 vector 、字符串等,因此需要对它们进行计数。但是,我的函数也使用
我是一名优秀的程序员,十分优秀!