下面代码大家帮测试下。是不是都能获得值。有错误弹出没??function GetCpuInfo(): string;
var
  R: array[0..19] of Char;
  CID: Integer;
begin
  FillChar(R, 20, 0);
  asm
    push ebx
    push ecx
    push edx
    mov eax, 0
    cpuid
    mov dword ptr R[0], ebx
    mov dword ptr R[4], edx
    mov dword ptr R[8], ecx
    mov eax, 1
    cpuid
    mov CID, edx
    pop edx
    pop ecx
    pop ebx
  end;
  Result := R + inttostr(CID);
end;

解决方案 »

  1.   

    运行showmessage(GetCpuInfo);能获得cpu号,没错误提示。
      

  2.   

    没错误,但乱码(win7 64 + delphi 2010)
      

  3.   

    另一方法,用WMI,你可得到你所有想要的,且兼容所有windows系统implementation
     uses ActiveX, ComObj;
    {$R *.dfm}
    function GetWMIProperty(WMIType, WMIProperty:String):String;
    var
      Wmi, Objs, Obj:OleVariant;
      Enum:IEnumVariant;
      C:Cardinal;
    begin
      try
        Wmi:= CreateOleObject('WbemScripting.SWbemLocator');
        Objs := Wmi.ConnectServer('.','root\cimv2').ExecQuery('Select * from Win32_'+ WMIType);
        Enum:=IEnumVariant(IUnknown(Objs._NewEnum));
        Enum.Reset;
        Enum.Next(1,Obj,C);    
        Obj:=Obj.Properties_.Item(WMIProperty,0).Value;
        if VarIsArray(Obj) then Result:=Obj[0]
        else Result:=Obj;
        except
         Result:='error';
      end;
    end;procedure TForm1.Button1Click(Sender: TObject);
    begin
      ShowMessage(GetWMIProperty('BIOS','BIOSVersion'));          //获得BIOS版本
      ShowMessage(GetWMIProperty('DiskDrive','SerialNumber'));     //获得第一块硬盘的设备标示
      ShowMessage(GetWMIProperty('Processor','ProcessorId'));     //获得CPUID。
    end;
      

  4.   

    delphi7 + win2003GetCpuInfo没有出错误,不知道结果对不对出错误
    ShowMessage(GetWMIProperty('DiskDrive','SerialNumber'));     //获得第一块硬盘的设备标示
      

  5.   

    keiy
    我也是 d7 + win2003 读硬盘出错。
    cpuid 是 16进制吧。跟我的函数不同(10进制?).
      

  6.   

    我试过很多,只有这代码能读硬盘序列号。对比windows优化大师是对的.
    function GetIdeSerialNumber: pchar;
    const IDENTIFY_BUFFER_SIZE = 512;
    type
    TIDERegs = packed record
    bFeaturesReg: BYTE; // Used for specifying SMART "commands".
    bSectorCountReg: BYTE; // IDE sector count register
    bSectorNumberReg: BYTE; // IDE sector number register
    bCylLowReg: BYTE; // IDE low order cylinder value
    bCylHighReg: BYTE; // IDE high order cylinder value
    bDriveHeadReg: BYTE; // IDE drive/head register
    bCommandReg: BYTE; // Actual IDE command.
    bReserved: BYTE; // reserved for future use. Must be zero.
    end;
    TSendCmdInParams = packed record
    // Buffer size in bytes
    cBufferSize: DWORD;
    // Structure with drive register values.
    irDriveRegs: TIDERegs;
    // Physical drive number to send command to (0,1,2,3).
    bDriveNumber: BYTE;
    bReserved: array[0..2] of Byte;
    dwReserved: array[0..3] of DWORD;
    bBuffer: array[0..0] of Byte; // Input buffer.
    end;
    TIdSector = packed record
    wGenConfig: Word;
    wNumCyls: Word;
    wReserved: Word;
    wNumHeads: Word;
    wBytesPerTrack: Word;
    wBytesPerSector: Word;
    wSectorsPerTrack: Word;
    wVendorUnique: array[0..2] of Word;
    sSerialNumber: array[0..19] of CHAR;
    wBufferType: Word;
    wBufferSize: Word;
    wECCSize: Word;
    sFirmwareRev: array[0..7] of Char;
    sModelNumber: array[0..39] of Char;
    wMoreVendorUnique: Word;
    wDoubleWordIO: Word;
    wCapabilities: Word;
    wReserved1: Word;
    wPIOTiming: Word;
    wDMATiming: Word;
    wBS: Word;
    wNumCurrentCyls: Word;
    wNumCurrentHeads: Word;
    wNumCurrentSectorsPerTrack: Word;
    ulCurrentSectorCapacity: DWORD;
    wMultSectorStuff: Word;
    ulTotalAddressableSectors: DWORD;
    wSingleWordDMA: Word;
    wMultiWordDMA: Word;
    bReserved: array[0..127] of BYTE;
    end;
    PIdSector = ^TIdSector;
    TDriverStatus = packed record
    // 驱动器返回的错误代码,无错则返回0
    bDriverError: Byte;
    // IDE出错寄存器的内容,只有当bDriverError 为 SMART_IDE_ERROR 时有效
    bIDEStatus: Byte;
    bReserved: array[0..1] of Byte;
    dwReserved: array[0..1] of DWORD;
    end;
    TSendCmdOutParams = packed record
    // bBuffer的大小
    cBufferSize: DWORD;
    // 驱动器状态
    DriverStatus: TDriverStatus;
    // 用于保存从驱动器读出的数据的缓冲区,实际长度由cBufferSize决定
    bBuffer: array[0..0] of BYTE;
    end;
    var
    hDevice: Thandle;
    cbBytesReturned: DWORD;
    SCIP: TSendCmdInParams;
    aIdOutCmd: array[0..(SizeOf(TSendCmdOutParams) + IDENTIFY_BUFFER_SIZE - 1) - 1] of Byte;
    IdOutCmd: TSendCmdOutParams absolute aIdOutCmd;
    procedure ChangeByteOrder(var Data; Size: Integer);
    var
    ptr: Pchar;
    i: Integer;
    c: Char;
    begin
    ptr := @Data;
    for I := 0 to (Size shr 1) - 1 do begin
    c := ptr^;
    ptr^ := (ptr + 1)^;
    (ptr + 1)^ := c;
    Inc(ptr, 2);
    end;
    end;
    begin
    Result := ''; // 如果出错则返回空串
    if SysUtils.Win32Platform = VER_PLATFORM_WIN32_NT then begin // Windows NT, Windows 2000
    // 提示! 改变名称可适用于其它驱动器,如第二个驱动器: '\\.\PhysicalDrive1\'
    hDevice := CreateFile('\\.\PhysicalDrive0', GENERIC_READ or GENERIC_WRITE,
    FILE_SHARE_READ or FILE_SHARE_WRITE, nil, OPEN_EXISTING, 0, 0);
    end else // Version Windows 95 OSR2, Windows 98
    hDevice := CreateFile('\\.\SMARTVSD', 0, 0, nil, CREATE_NEW, 0, 0);
    if hDevice = INVALID_HANDLE_VALUE then Exit;
    try
    FillChar(SCIP, SizeOf(TSendCmdInParams) - 1, #0);
    FillChar(aIdOutCmd, SizeOf(aIdOutCmd), #0);
    cbBytesReturned := 0;
    // Set up data structures for IDENTIFY command.
    with SCIP do begin
    cBufferSize := IDENTIFY_BUFFER_SIZE;
    // bDriveNumber := 0;
    with irDriveRegs do begin
    bSectorCountReg := 1;
    bSectorNumberReg := 1;
    // if Win32Platform=VER_PLATFORM_WIN32_NT then bDriveHeadReg := $A0
    // else bDriveHeadReg := $A0 or ((bDriveNum and 1) shl 4);
    bDriveHeadReg := $A0;
    bCommandReg := $EC;
    end;
    end;
    if not DeviceIoControl(hDevice, $0007C088, @SCIP, SizeOf(TSendCmdInParams) - 1,
    @aIdOutCmd, SizeOf(aIdOutCmd), cbBytesReturned, nil) then Exit;
    finally
    CloseHandle(hDevice);
    end;
    with PIdSector(@IdOutCmd.bBuffer)^ do begin
    ChangeByteOrder(sSerialNumber, SizeOf(sSerialNumber));
    (Pchar(@sSerialNumber) + SizeOf(sSerialNumber))^ := #0;
    Result := Pchar(@sSerialNumber);
    end;
    end;
      

  7.   

    to:jianye112 你这个程序,在我BDS2010下编译运行,结果为乱码
    toall:我的程序.包括jianye112的两个程序,在winxp+bcb6下编译运行都没问题
    将它们的exe文件copy到win7 64位下也都没问题
    可能还是bds2010下unicode的问题,研究下先
      

  8.   

    果然是String的问题
    改进后的,可在2010版本编译通过 function GetWMIProperty(WMIType, WMIProperty:AnsiString):String;
    var
      Wmi, Objs, Obj:OleVariant;
      Enum:IEnumVariant;
      C:Cardinal;begin
      try
        Wmi:= CreateOleObject(AnsiString('WbemScripting.SWbemLocator'));
        Objs := Wmi.ConnectServer(AnsiString('.'),AnsiString('root\cimv2')).ExecQuery(AnsiString('Select * from Win32_'+WMIType));   Enum:=IEnumVariant(IUnknown(Objs._NewEnum));
        Enum.Reset;
        Enum.Next(1,Obj,C);
        Obj:=Obj.Properties_.Item(WMIProperty,0).Value;
        if VarIsArray(Obj) then Result:=Obj[0]
        else Result:=Obj;
        except
         Result:='error';
      end;
    end;
    WMI可得到所有系统信息,硬件/软件/服务(包括远程机上的)
    参考:
    http://msdn.microsoft.com/en-us/library/aa394554(VS.85).aspx
    在关硬件的WMI 类
    http://msdn.microsoft.com/en-us/library/aa389273(v=VS.85).aspx
      

  9.   

    应该是 delphi 版本问题吧。
    ---------------------------
    Debugger Exception Notification
    ---------------------------
    Project Project1.exe raised exception class EOleException with message '找不到'. Process stopped. Use Step or Run to continue.
    ---------------------------
    OK   Help   
    ---------------------------
    就是 wmi读cpuid的速度在d7+win2003要1-3秒左右