Когда DLL подключена к процессу, она использует те же адреса памяти, что и процесс. Предположим, у нас есть следующая функция в DLL:
Код: Выделить всё
int * data = 0;
int foo()
{
if (!data) data = new int(random());
return *data;
}
Но теперь процесс B присоединяет эту DLL. Он вызывает foo(), но я не понимаю, как это будет работать, потому что данные находятся в процессе. Пространство памяти. Как B сможет использовать его напрямую?
Подробнее здесь: https://stackoverflow.com/questions/770 ... ry-in-dlls
Мобильная версия