FIX: La funzione CDialog::Create() restituisce un valore non corretto quando si crea una finestra di dialogo in Visual c ++

Il presente articolo è stato tradotto tramite il software di traduzione automatica di Microsoft e non da una persona. Microsoft offre sia articoli tradotti da persone fisiche sia articoli tradotti automaticamente da un software, in modo da rendere disponibili tutti gli articoli presenti nella nostra Knowledge Base nella lingua madre dell’utente. Tuttavia, un articolo tradotto in modo automatico non è sempre perfetto. Potrebbe contenere errori di sintassi, di grammatica o di utilizzo dei vocaboli, più o meno allo stesso modo di come una persona straniera potrebbe commettere degli errori parlando una lingua che non è la sua. Microsoft non è responsabile di alcuna imprecisione, errore o danno cagionato da qualsiasi traduzione non corretta dei contenuti o dell’utilizzo degli stessi fatto dai propri clienti. Microsoft, inoltre, aggiorna frequentemente il software di traduzione automatica.

Clicca qui per visualizzare la versione originale in inglese dell’articolo: 193099
Questo articolo è stato archiviato. L’articolo, quindi, viene offerto “così come è” e non verrà più aggiornato.
Sintomi
Se una finestra di dialogo viene creata tramite la chiamata CDialog::Create() e OnInitDialog(), in risposta al messaggio WM_INITDIALOG, termina della finestra di dialogo la finestra di dialogo tramite EndDialog(), la funzione di CDialog::Create() restituisce un valore diverso da zero. In questo caso, il CDialog::Create() deve restituire zero.

Poiché la finestra di dialogo è stata eliminata a causa a una chiamata EndDialog() in OnInitDialog() della finestra di dialogo, CDialog::m_hWnd è NULL in questo caso.
Cause
Un test è stato effettuato nel codice WM_INITDIALOG (riga 365 di dlgcore.cpp), che conduce a Create() ha avuto esito negativo anche se l'handle di finestra è NULL.

Codice MFC per Visual c ++ 5.0:
BOOL CWnd::CreateDlgIndirect(LPCDLGTEMPLATE lpDialogTemplate,      CWnd* pParentWnd, HINSTANCE hInst)   {      // ...      if (hWnd == NULL)      {         // ...         // .. dump some debug information         return FALSE;      }      ASSERT(hWnd == m_hWnd);      return TRUE;   }				
Codice MFC per Visual c ++ 6.0:
BOOL CWnd::CreateDlgIndirect(LPCDLGTEMPLATE lpDialogTemplate,      CWnd* pParentWnd, HINSTANCE hInst)   {      // ...      // Help with error diagnosis (only if WM_INITDIALOG didn't      // EndDialog())      if (hWnd == NULL && (m_nFlags &amp; WF_CONTINUEMODAL)) // <--- PROBLEM!!!{         // ... dump some debug information.         return FALSE;      }      ASSERT(hWnd == m_hWnd);      return TRUE;   }				
Risoluzione
Chiamata CDialog::Create controllare quando il valore restituito di CDialog::Create() sia il valore di CDialog::m_hWnd. Se CDialog::m_hWnd è NULL, la creazione della finestra di dialogo ha esito negativo.
Status
Microsoft ha confermato che si tratta di un problema che riguarda solo i prodotti elencati all'inizio di questo articolo. Questo bug è stato risolto in Visual Studio 6.0 Service Pack 1.

Per ottenere il service pack, vedere: Per ulteriori informazioni su Visual Studio 6.0 Service Pack 1, vedere i seguenti articoli della Microsoft Knowledge Base riportato di seguito:
Informazioni
Modificare il codice per la visualizzazione della finestra di dialogo in modo verifica inoltre con la variabile CDialog::m_hWnd. Ad esempio:
    // Create a modeless dialog box. In this example, m_pModeless is a   // member variable of type CModeless where CModeless is a CDialog-   // derived class. IDD_MODELESS is the ID number of a dialog-box template   // resource.   m_pModeless = new CModeless;   if (m_pModeless->Create(IDD_MODELESS, this) &&      ::IsWindow(m_pModeless->m_hWnd))   {      // ... succeeded in dialog-box creation.   }   else   {      // ... failed in dialog-box creation.   }				

Procedura per riprodurre il problema

  1. Copiare l'esempio MFC MODELESS dai CD di MSDN.
  2. Utilizzare Creazione guidata classe per aggiungere un gestore di messaggi OnInitDialog(), in risposta al messaggio WM_INITDIALOG, alla classe CAdderDialog. CAdderDialog è una classe derivata da CDialog.
  3. Chiamare di EndDialog() nel CAdderDialog::OnInitDialog() come segue:
       BOOL CAdderDialog::OnInitDialog()   {      CDialog::OnInitDialog();      // TODO: Add extra initialization here      EndDialog(-1);      return TRUE;  // return TRUE unless you set the focus to a control               // EXCEPTION: OCX Property Pages should return FALSE   }					
  4. Selezionare la build di rilascio Win32 VC ++ del comando di menu configurazione attiva Build\Set.
  5. Generare ed eseguire quindi l'esempio MODELESS.
  6. Fare clic su Aggiungi nella finestra di dialogo. La chiamata di m_pModeless->Create() nel file di Modeldlg.cpp (alla riga 178) restituisce TRUE, causando in questo caso il pulsante Aggiungi (per la visualizzazione la finestra di dialogo non modale CAdderDialog) da disattivare.
(c) 1999 Microsoft Corporation, tutti i diritti riservati. Contributo di Yeong-Kah Tam, Microsoft Corporation.

Avviso: questo articolo è stato tradotto automaticamente

Proprietà

ID articolo: 193099 - Ultima revisione: 02/22/2014 20:09:56 - Revisione: 6.2

Microsoft Foundation Class Library 4.2

  • kbnosurvey kbarchive kbmt kbfunctions kbqfe kbbug kbdlg kbfix kbnoupdate kbvc600sp1fix kbvs600sp1fix KB193099 KbMtit
Feedback