Help and Support

Artikel-ID: 115828 - Geändert am: Dienstag, 21. November 2006 - Version: 3.2

Welche Verfahrensweise zu Information Diskettenlaufwerk Information abzurufen

Auf dieser Seite

Alles erweitern | Alles schließen

Zusammenfassung

Das Aufrufen des CreateFile() zu dem Abrufen eines Punkts auf Laufwerk und dann von DeviceIoControl(), die Information zu erhalten, ist erforderlich, der Medium-Typ von einem Diskettenlaufwerk unterstützt, zu erhalten. Wird möglicherweise das folgende Nachrichtenfelder angezeigt, wenn sich keine Diskette in dem Diskettenlaufwerk befindet, jedoch, wenn CreateFile() für Laufwerk A aufgerufen wird ( \\.\a :): )
Keine Diskette befindet sich in dem Laufwerk. Legen Sie in dem Laufwerk A: einen Datenträger ein
Seien Sie Sie sicher, dass Sie 0 für den Freigabe-Modus für den Zugriffsmodus und FILE_SHARE_READ verwenden sollen, damit der Benutzer nicht aufgefordert wird, eine Diskette einzulegen, wenn Sie CreateFile() aufrufen:
   CreateFile(
      szFileName,
      0,
      FILE_SHARE_READ,
      NULL,
      OPEN_ALWAYS,
      0,
      NULL
   );
				
Das Ablegen ist eine weitere die Nachrichtenfeldeingabeaufforderung vermeidende Art
SetErrorMode( SEM_FAILCRITICALERRORS );
Vor dem Aufruf von CreateFile().

Weitere Informationen

Der folgende Beispielcode basiert auf dem Code in dem Beispiel FLOPPY SDK aber es zeigt den Medium-Typen, der von Diskettenlaufwerk A unterstützt wird, einfach an. Der Code demonstriert eine Möglichkeit, das unterstützte Medium Ihnen von dem Sein ohne dass erforderlichen eine Diskette in dem Laufwerk einzulegen, abzurufen.

Beispielcod

   #include <windows.h>
   #include <stdio.h>
   #include <winioctl.h>

   DISK_GEOMETRY SupportedGeometry[20];
   DWORD SupportedGeometryCount;

   VOID
   GetSupportedGeometrys( HANDLE hDisk )
   {
      DWORD ReturnedByteCount;

      if( DeviceIoControl(
             hDisk,
             IOCTL_DISK_GET_MEDIA_TYPES,
             NULL,
             0,
             SupportedGeometry,
             sizeof(SupportedGeometry),
             &ReturnedByteCount,
             NULL
         ))
         SupportedGeometryCount = ReturnedByteCount / 
                                  sizeof(DISK_GEOMETRY);

      else SupportedGeometryCount = 0;
   }

   VOID
   PrintGeometry( PDISK_GEOMETRY lpGeometry )
   {
      LPSTR MediaType;

      switch ( lpGeometry->MediaType ) {
         case F5_1Pt2_512:
            MediaType = "5.25, 1.2MB,  512 bytes/sector";
            break;
         case F3_1Pt44_512:
            MediaType = "3.5,  1.44MB, 512 bytes/sector";
            break;
         case F3_2Pt88_512:
            MediaType = "3.5,  2.88MB, 512 bytes/sector";
            break;
         case F3_20Pt8_512:
            MediaType = "3.5,  20.8MB, 512   bytes/sector";
            break;
         case F3_720_512:
            MediaType = "3.5,  720KB,  512 bytes/sector";
            break;
         case F5_360_512:
            MediaType = "5.25, 360KB,  512 bytes/sector";
            break;
         case F5_320_512:
            MediaType = "5.25, 320KB,  512 bytes/sector";
            break;
         case F5_320_1024:
            MediaType = "5.25, 320KB,  1024 bytes/sector";
            break;
         case F5_180_512:
            MediaType = "5.25, 180KB,  512 bytes/sector";
            break;
         case F5_160_512:
            MediaType = "5.25, 160KB,  512  bytes/sector";
            break;
         case RemovableMedia:
            MediaType = "Removable media other than floppy";
            break;
         case FixedMedia:
            MediaType = "Fixed hard disk media";
            break;
         default:
            MediaType = "Unknown";
            break;
      }
      printf("    Media Type %s\n", MediaType );
      printf("    Cylinders %d, Tracks/Cylinder %d, Sectors/Track %d\n",
             lpGeometry->Cylinders.LowPart, lpGeometry->TracksPerCylinder,
             lpGeometry->SectorsPerTrack
            );
   }

   void main( int argc, char *argv[], char *envp[] )
   {
      HANDLE hDrive;
      UINT i;

      hDrive = CreateFile(
                      "\\\\.\\a:",
                      0,
                      FILE_SHARE_READ,
                      NULL,
                      OPEN_ALWAYS,
                      0,
                      NULL
                      );
      if ( hDrive == INVALID_HANDLE_VALUE )
      {
         printf( "Open failed: %d\n", GetLastError() );
         ExitProcess(1);
      }

      GetSupportedGeometrys( hDrive );

      printf( "\nDrive A supports the following disk geometries\n" );
      for( i=0; i<SupportedGeometryCount; i++ )
      {
          printf("\n");
          PrintGeometry( &SupportedGeometry[i] );
      }
      printf("\n");
   }
				

Die Informationen in diesem Artikel beziehen sich auf:
  • Microsoft Win32 Application Programming Interface, wenn verwendet mit:
    • Microsoft Windows NT Advanced Server 3.1
    • Microsoft Windows NT 4.0
    • Microsoft Windows NT 4.0
    • Microsoft Windows 2000 Standard Edition
    • the operating system: Microsoft Windows XP
Keywords: 
kbhowto kbkernbase kbfileio KB115828 KbMtde kbmt
Maschinell übersetzter ArtikelMaschinell übersetzter Artikel
Wichtig: Dieser Artikel wurde maschinell und nicht von einem Menschen übersetzt. Die Microsoft Knowledge Base ist sehr umfangreich und ihre Inhalte werden ständig ergänzt beziehungsweise überarbeitet. Um Ihnen dennoch alle Inhalte auf Deutsch anbieten zu können, werden viele Artikel nicht von Menschen, sondern von Übersetzungsprogrammen übersetzt, die kontinuierlich optimiert werden. Doch noch sind maschinell übersetzte Texte in der Regel nicht perfekt, insbesondere hinsichtlich Grammatik und des Einsatzes von Fremdwörtern sowie Fachbegriffen. Microsoft übernimmt keine Gewähr für die sprachliche Qualität oder die technische Richtigkeit der Übersetzungen und ist nicht für Probleme haftbar, die direkt oder indirekt durch Übersetzungsfehler oder die Verwendung der übersetzten Inhalte durch Kunden entstehen könnten.
Den englischen Originalartikel können Sie über folgenden Link abrufen: 115828  (http://support.microsoft.com/kb/115828/en-us/ )
Microsoft stellt Ihnen die in der Knowledge Base angebotenen Artikel und Informationen als Service-Leistung zur Verfügung. Microsoft übernimmt keinerlei Gewährleistung dafür, dass die angebotenen Artikel und Informationen auch in Ihrer Einsatzumgebung die erwünschten Ergebnisse erzielen. Die Entscheidung darüber, ob und in welcher Form Sie die angebotenen Artikel und Informationen nutzen, liegt daher allein bei Ihnen. Mit Ausnahme der gesetzlichen Haftung für Vorsatz ist jede Haftung von Microsoft im Zusammenhang mit Ihrer Nutzung dieser Artikel oder Informationen ausgeschlossen.

SPRACHE AUSWÄHLEN