相关疑难解决方法(0)

当我们引用非静态数据成员时,分段错误是否是实际未定义的行为

我已经阅读了以下规则,并且我一直在尝试编写一个反映一个例子的例子.规则来自3.8/5 N3797:

在对象的生命周期开始之前但是在对象将占用的存储之后,或者在对象的生命周期结束之后以及在重用或释放对象占用的存储之前,任何指向存储的指针之前可以使用对象将位于或位于的位置,但仅限于有限的方式.对于正在建造或销毁的物体,见12.7.否则,这样的指针指的是已分配的存储(3.7.4.2),并且使用指针就像指针的类型一样void*是明确定义的.允许通过这样的指针的间接,但是得到的左值可以仅以有限的方式使用,如下所述.如果出现以下情况,该程

[...]

- 指针用于访问非静态数据成员或调用对象的非静态成员函数,或

[...]

我写的例子:

#include <iostream>
#include <typeinfo>

using std::cout;
using std::endl;

struct A
{
    int b = 5;
    static const int a = 5;
};

int main()
{
    A *p = (A*)0xa31a3442;
    cout << p -> a; //1, Well-fromed, there is no compile-time error
    cout << p -> b; //2, Segmentation fault is producing
}
Run Code Online (Sandbox Code Playgroud)

这是真的,在的情况下//1很好地形成的,不会造成任何UB的,但//2产生的段错误,这是UB

c++ pointers undefined-behavior

9
推荐指数
1
解决办法
1937
查看次数

获取进程段的开始和结束 C/C++

我需要获取以下流程段的开始和结束地址:代码、数据、堆栈、环境。我了解它如何位于内存中,但不知道如何使用 api 调用或其他方式获取它。我找到了如何使用此代码开始某些段

#include <stdio.h>

int temp_data = 100;
static int temp_bss;

void print_addr ( void )
{
        int local_var = 100;
        int *code_segment_address = ( int* ) &print_addr;
        int *data_segment_address = &temp_data;
        int *bss_address = &temp_bss;
        int *stack_segment_address = &local_var;

        printf ( "\nAddress of various segments:" );
        printf ( "\n\tCode Segment : %p" , code_segment_address );
        printf ( "\n\tData Segment : %p" , data_segment_address );
        printf ( "\n\tBSS : %p" , bss_address );
        printf ( "\n\tStack Segment : %p\n" …
Run Code Online (Sandbox Code Playgroud)

c unix linux memory-management system

6
推荐指数
1
解决办法
7838
查看次数

标签 统计

c ×1

c++ ×1

linux ×1

memory-management ×1

pointers ×1

system ×1

undefined-behavior ×1

unix ×1