Доступ к члену через указатель на объект

В стеке компилятор может выполнять множество оптимизаций, потому что контекст статичен и известен во время компиляции, но когда он имеет дело с доступом к динамически размещенным объектам и, как правило, с доступом "по ссылке", контекст неизвестен, поэтому логически в таких случаях доступ к элементу сводится к разыменованию адреса памяти, полученного путем добавления базового адреса объекта и смещения для этого элемента. Или это? Я довольно новичок в этом, поэтому на данный момент я только догадываюсь и, возможно, упускаю много деталей.

Например, я заметил, что если я реализую + оператор как void add(int * a, int * b, int * r); при работе с элементами стека (и с использованием & оператор) код сборки идентичен тому, что обычный + оператор создает, поэтому кажется, что указатели, которые, как известно, указывают на компиляцию известных значений времени, оптимизируются для исключения дополнительной разыменования (и копирования) и косвенных указателей внутри add() Функция указана как прямой доступ к объектам стека. Означает ли это, что компилятор "достаточно хорош", чтобы иметь возможность оптимизировать, например, средства доступа, реализованные с косвенным изменением от смещений постоянных значений от базового адреса объекта в стеке, как если бы он использовал доступ к элементу структуры для получения этого значения?

1 ответ

Я не знаю, как вы реализовали тело функции, поэтому этот ответ может быть полностью отключен:).

Если вы добавляете внутри своей функции r = a + b, код будет выглядеть так же, но не будет таким же.

для прототипа (int *, int *, int *) вы добавите указатели, что неправильно. Чтобы получить целочисленное значение внутри вашей функции, тело должно быть:

*r = *a + *b ; 

ИЛИ ЖЕ

r[0] = a[0] + b[0];

для того, чтобы получить значение, которое вы хотите. Это тело не должно иметь тот же код сборки, что и оператор +, поскольку указанные значения не известны во время компиляции.

для прототипа (int &, int &, int &) и тела

r = a + b;

компилятор встроит эту функцию, так что да, сборка должна быть идентична.

Другие вопросы по тегам