2009-05-06 92 views
0

我在混合托管代码和非托管代码时遇到问题。我在Vista x64 SP1下的Visual Studio 2008中的单个解决方案下创建了两个项目。其中一个没有CLR支持,并且是一个静态库。我的第二个项目被编译为启用了CLR的可执行文件。它依赖于第一个静态库,并将WinForms事件传递给它。托管可执行文件中的非托管库导致托管异常

当我在没有调试的情况下启动应用程序时,出现异常,我把这些异常信息从http://pastebin.com/f46ad1211中取出。

这里是运行的非托管的lib代码:

void manager::init() // <-- Called from the .exe project 
{ 
    this->log.open("C:\\development\\log.txt"); 
    this->storage = storage_manager(&(this->log), &(this->settings)); 
    this->storage.load_settings(); 
} 

&

void storage_manager::load_settings() 
{ 
    this->error_check(sqlite3_open("settings.db", &(this->db_settings_p))); 
    sqlite3_stmt* read_settings; 
    this->error_check(sqlite3_prepare_v2(this->db_settings_p, "SELECT name, value FROM settings", 1024, &read_settings, NULL)); 

    int step_code; 
    std::string name; 
    std::string value; 
    while(true) 
    { 
     step_code = sqlite3_step(read_settings); 
     if(step_code == SQLITE_DONE) 
     { 
      break; 
     } 
     else if(step_code == SQLITE_ROW) 
     { 
      name = std::string(reinterpret_cast<const char*>(sqlite3_column_text(read_settings, 0))); 
      value = std::string(reinterpret_cast<const char*>(sqlite3_column_text(read_settings, 1))); 
      (*(this->settings))[name] = value; 

     } 
     else 
     { 
      this->error(); 
     } 
    } 
    sqlite3_reset(read_settings); 
    sqlite3_finalize(read_settings); 
} 

&

void storage_manager::error_check(int rc) 
{ 
    if(rc) 
    { 
     this->error(); 
    } 
} 
void storage_manager::error() //Sure of error 
{ 
    std::string error_msg; 
    error_msg = "Storage Manager: SQLite Error ("; 
    error_msg += sqlite3_errcode(this->db_p); 
    error_msg += ") - "; 
    error_msg += sqlite3_errmsg(this->db_p); 
    this->log->write(error_msg.c_str(), error_msg.length()); 
    this->log->flush(); 
} 

我不明白为什么我得到一个在非托管库中管理(System.BlahBlahBlah)异常。有什么办法让两者完全分开吗?

回答

1

底层的异常实际上是一个Windows异常,CLR显然已经变成了CLR异常。您有访问冲突。你应该能够做的是,在Visual Studio中,前往调试>例外,并打破访问违规。这应该让你放下来,看看它的本地代码中哪里出了所有可怕的错误,并开始诊断问题。

+0

感谢您的信息!我的sqlite.c文件的第18706行引发了异常,我会试着弄清楚如何解决这个问题。 – 2009-05-06 02:26:19