BSc*_*ker 1 c++ debugging if-statement
我开发了一个'自定义'cout,这样我就可以将文本显示到控制台并将其打印到日志文件中.这个cout类在初始化时传递一个不同的整数,整数表示消息的详细级别.如果当前详细级别大于或等于消息的详细级别,则应打印该消息.
问题是,即使当前的详细程度太低,我也会打印消息.我继续调试它,期待找到问题.相反,我发现我的if语句没有按预期工作的多个场景.
即使ilralevel_set为LESS然后ilralevel_passed,if(ilralevel_passed <= ilralevel_set)语句有时也会继续.你可以在下面的图片中看到这种行为(我为使用Twitpic道歉)http://twitpic.com/1xtx4g/full.注意ilralevel_set如何等于零,ilralevel_passed等于1.然而,if语句已经返回true并且现在正在向前传递给cout.
我以前从未见过这种类型的行为,我不确定如何继续调试它.我无法隔离行为 - 它只发生在我程序的某些部分.任何建议一如既往地受到赞赏.
// Here is an example use of the function:
// ilra_status << setfill('0') << setw(2) << dispatchtime.tm_sec << endl;
// ilra_warning << "Dispatch time (seconds): " << mktime(&dispatchtime) << endl;
// Here is the 'custom' cout function:
#ifndef ILRA_H_
#define ILRA_H_
// System libraries
#include <iostream>
#include <ostream>
#include <sstream>
#include <iomanip>
// Definitions
#define ilra_talk ilra(__FUNCTION__,0)
#define ilra_update ilra(__FUNCTION__,0)
#define ilra_error ilra(__FUNCTION__,1)
#define ilra_warning ilra(__FUNCTION__,2)
#define ilra_status ilra(__FUNCTION__,3)
// Statics
static int ilralevel_set = 0;
static int ilralevel_passed;
// Classes
class ilra
{
public:
// constructor / destructor
ilra(const std::string &funcName, int toset)
{
ilralevel_passed = toset;
}
~ilra(){};
// enable / disable irla functions
static void ilra_verbose_level(int toset){
ilralevel_set = toset;
}
// output
template <class T>
ilra &operator<<(const T &v)
{
if(ilralevel_passed <= ilralevel_set)
std::cout << v;
return *this;
}
ilra &operator<<(std::ostream&(*f)(std::ostream&))
{
if(ilralevel_passed <= ilralevel_set)
std::cout << *f;
return *this;
}
}; // end of the class
#endif /* ILRA_H_ */
Run Code Online (Sandbox Code Playgroud)
在类外部定义静态变量时,您要为包含标题的每个源文件定义一个单独的变量 - 将值更改为一个不会影响另一个文件中具有相同名称的变量的值.
你几乎肯定想要的是拥有
int ilralevel_set = 0;
int ilralevel_passed;
Run Code Online (Sandbox Code Playgroud)
在一个文件,其中你定义你的对象,并且:
extern int ilralevel_set;
extern int ilralevel_passed;
Run Code Online (Sandbox Code Playgroud)
在标题中.或者,看起来你可以在课堂内全部移动它:
class ilra {
int passed_level;
int set_level;
public:
ilra(int toset) : passed_level(toset), set_level(0) {}
verbose_level(int toset) { set_level = toset; }
// ...
};
Run Code Online (Sandbox Code Playgroud)
小智 5
您不应该在头文件中定义静态变量,如下所示:
static int ilralevel_set = 0;
static int ilralevel_passed;
Run Code Online (Sandbox Code Playgroud)
我不知道你认为这些定义是做什么的,但它们可能不会做你想要的.
要在课堂上申报:
struct A {
static int ilralevel;
};
Run Code Online (Sandbox Code Playgroud)
然后,您需要在一个 .cpp源文件中定义:
int A::ilralevel = 0;
Run Code Online (Sandbox Code Playgroud)