2

我正在学习 C++ 并且我们正在讨论预处理器,但我正在尝试解决一个让我有点或很多困惑的测验问题。在运行程序之前,我尝试自己解决。和我的输出曾是..

系统启动...
2 处的数据为:27 28 29 30
1 处的数据为:23 24 25 26
数据为:19

我检查了 Xcode 中的程序,看看我的输出是否正确,但正确的输出是下一个:

系统启动...
1 处的数据为:0 0 0 19 0处的数据
为:7 0 0 0
数据为:19 0 0 0

这是代码...

#include <iostream>

namespace test{
#define COMPILE_FAST
#define PRINT_SPLIT(v) std::cout << (int)*((char*)(v)) << ' ' << \
(int)*((char*)(v) + 1) << ' ' << (int)*((char*)(v) +2) << ' ' << \
(int)*((char*)(v) + 3) << std::endl

    typedef unsigned long long uint;
    namespace er{
        typedef unsigned int uint;
    }
    void debug(void* data, int size = 0){
        if(size==0){
            std::cout << "The data is: ";
            PRINT_SPLIT(data);
        } else {
             while(size--){
                std::cout << "Data at " << size << " is: ";
                char* a = (char*)data;
                PRINT_SPLIT((a + (4+size)));
            }
        }
    }
}// End of Test namespace...

int main(){
    test::uint a = 19;
    test::er::uint b[] = {256,7};
    std::cout << "System started..." << std::endl;
    test::debug(b,2);
    test::debug(&a);
    std::cout << "Test complete";
    return 0;
}

我最大的疑问或我实际上不明白的是在这个预处理器中发生了什么,因为显然我所做的完全错了......

#define PRINT_SPLIT(v) std::cout << (int)*((char*)(v)) << ' ' << \
(int)*((char*)(v) + 1) << ' ' << (int)*((char*)(v) +2) << ' ' << \
(int)*((char*)(v) + 3) << std::endl

如果有人能这么好,给我一个简短的解释,我将非常感激。

4

1 回答 1

1

宏打印 4 个连续字节的值(作为整数)。它允许您查看 4 字节 int 在内存中的布局。

内存内容,按字节,如下所示(base10):

0x22abf0:       0       1       0       0       7       0       0       0
0x22abf8:       19      0       0       0       0       0       0       0
  • 0 1 0 0 为 256,即 b[0]
  • 7 0 0 0 为 7,即 b[1]
  • 19 0 0 0 0 0 0 0 是 19,即一个

sizeof(a)不同于 ,因为sizeof(b[0])有 2 种不同的 typedef uint。即,test:uinttest::er::uint

即使在 b 之后声明了地址,地址a也大于地址,因为堆栈在内存中向下增长。b[]a

最后,我会说输出代表有缺陷的程序,因为输出更合理的是:

System started...
Data at 1 is: 7 0 0 0
Data at 0 is: 0 1 0 0
The data is: 19 0 0 0

要获得该输出,需要按如下方式更改程序:

         while(size--){
            std::cout << "Data at " << size << " is: ";
            int* a = (int*)data;
            PRINT_SPLIT((a + (size)));
于 2013-10-28T23:34:22.320 回答