A small function for debug

xiaoxiao2021-03-05  27

Although the debugger of VC 7 (.NET 2003) is already very good, it is still a bit inadequate place.

We usually use the containers in some standard libraries to store data, such as Vector, we want to see data in container in the process of debugging, so that there are bugs in those places.

However, the debugger still does not smart to view the data in the standard library container when commissioning. Of course, this requirement of the debugger to identify the data structure of the standard library, and this requirement seems to be more excessive, and some time us will also Use other libraries or write containers, such as Matrix matrices, there is no in the standard library.

So the only possible way is to implement a stream output (Operator <<) for the class of the container, and then insert some debug statements in the program, output the value of the container to std :: cout or other output stream (text stream, etc.) . After the quotation is completed, then remove it or comment. You can also pack it with a pair of preprocessing statements, then the Release version will be automatically removed.

#ifdef _debug std :: cout << var_name << std :: endl; #endif

Because every time you write such a statement, you have written a small function and a macro to replace such a job, and you can add more debug information.

The following function adds the function name, variable type (requires support for RTTI runtime type identification), and the name of the variable.

static std :: ofstream __ry_debug ( "../ ry_debug.log"); template inline void debug_out (const char * method_name, const char * var_name, const T & value) {#ifdef _DEBUG __ry_debug << "Method: / t "< LuM5 53.2557E 004 2.9906E 004 2.4100E 004 2.3320E 004 1.2912E 004 5.2830E-003 2.2262E 004 -1.2232E 002 5.8688E 003 5.6998E 003 1.8079 E-001 9.7616E-001 2.3817E 004 2.5751E 003 2.1021E 004 2.7499E-001 -1.4913E 001 1.6481E-001 2.6103E 004 1.7518E 003 9.294E-001 -7.4329E-001 - 3.2831E-001 8.144E-002 2.6349E 004

转载请注明原文地址:https://www.9cbs.com/read-34819.html

New Post(0)