我在C++中有一小段代码:
#include <iostream>
#include <iterator>
#include <string>
using namespace std;
int main() {
int i=0;
istream_iterator<string> EOS;
double x;
return 0;
}
Run Code Online (Sandbox Code Playgroud)
现在我用我的g ++(GCC)4.4.4编译它
g++ -W -Wall -pedantic test.cc -o test
Run Code Online (Sandbox Code Playgroud)
得到:
test.cc: In function 'int main()':
test.cc:9: warning: unused variable 'i'
test.cc:11: warning: unused variable 'x'
Run Code Online (Sandbox Code Playgroud)
为什么没有未使用的EOS警告?
Tho*_*mas 34
它不是原始值,因此其构造函数和/或析构函数可能具有所需的副作用.
为了说明这种情况在实践中发生:我使用一个类来计算代码的各个部分,看起来大致如下:
class Timed {
double start;
public:
Timed() { start = now(); }
~Timed() { std::cout << (now() - start) << '\n'; }
}
Run Code Online (Sandbox Code Playgroud)
因此,为了衡量一个函数需要多长时间,我只需:
void slow() {
Timed t;
// heavy operation here...
}
Run Code Online (Sandbox Code Playgroud)
变量t永远不会被使用,但它对代码的行为仍然很重要.
istream_iterator<string>有一个构造函数,所以声明EOS并不是真正的无操作声明i和x.
通常你想声明一个类类型的对象,然后不做任何事情.例如,考虑std::lock_guard在C++ 0x(boost::scoped_lock在Boost中)或任何其他类型的范围保护类.您通常不想对这种对象执行任何操作,您只需要创建对象,以便在块的末尾运行析构函数以执行需要执行的任何清理.
| 归档时间: |
|
| 查看次数: |
1772 次 |
| 最近记录: |