//File A.h containing class A
//DLL or dylib code.
class A {
//Class methods
A ()
{
count = 5;
}
//Append is running fine as it is tested
A& Append (const A& a)
{
//Append operation.
str = str + a.str;
return *this;
}
//this is running fine in all other cases except for this static object.
A& operator= (const A& a)
{
//Statement 1
str = a.str;
//Problem is faced in the statement 1 on the assignment of str to a.str
//I forget to add this code.
count = a.count;
return *this;
}
private:
std::string str;
int count;
};
//File B.cpp in some other layer
//When these variables in dylib.
static A obj1;
static A obj2;
static void f ();
static void g ();
//This Initialize is called whenver DLL or dylib is being loaded.
Initialize ()
{
f();
g();
}
//Problem faced in a function f
void f ()
{
A a;
//Some operation performed on a
a.Append (GetA("String"));
//Here I am facing problem of Bad memory access possibly over statement 1.
obj1 = a;
//Debugger on Windows showing the member of obj1 initialized, but not on Mac OS X.
}
void g ()
{
A a;
//Some operation performed on a
//Here I am facing problem of Bad memory access possibly over statement 1.
obj2 = a;
//Debugger on Windows showing the member of obj1 initialized, but not on Mac OS X.
}
//The application An exe or .app on Mac OS X
int main ()
{
InitializeApplication ();
void * handle;
//Dynamic library is being loaded.
handle = dlopen("mylib.dylib", RTLD_LAZY);
//Functions are being loaded.
f1 = dlsym(handle, "MyFunction");
//Rest of the code.
}
Когда я запускаю аналогичную программу в Windows (скомпилированную с помощью компилятора cl), значения obj1.count и obj2.count равны 5 (как инициализировано конструктором по умолчанию).
Однако, когда я запускаю эту программу в Mac OS X (скомпилированную с помощью компилятора clang), значения obj1.count и obj2.count равны 0.
Я что-то упустил для инициализации статического объекта класса? Какие шаги необходимы, если есть массив?
В моей программе есть приложение, загружающее dylib (в Mac OS X) или DLL (в Windows). Этот код является частью разделяемой библиотеки или DLL.
Статические объекты obj1 и obj2 находятся в DLL. Эта DLL загружается, а затем вызывается.
Следующее поведение наблюдается в Windows
- Точки останова, помещенные в объявление статического класса obj1 и obj2, срабатывают.
- Объекты obj1 и obj2 инициализированы правильно.
- Точка останова, установленная в конструкторе, также срабатывает.
В Mac OS X
- Точка останова при объявлении и в конструкторе не срабатывает из-за этого статического объявления.
- Объекты obj1 и obj2 не инициализированы.
В Mac OS X все в объекте инициализируется нулем. Каждый адрес NULL.
Однако, когда я переместил эти переменные в статическую библиотеку (которая связана с этой dylib), все работает в соответствии с ожиданиями.
Есть ли проблема с глобальными/статическими объектами в dylib?
obj1 = a;
оба объекта должны были быть инициализированы. - person Eric Z   schedule 06.05.2013