参考下面的文章:
利用利用CPUID 汇编指令(机器码:0FH A2H, 如果你的编译器不支持CPUID 指令,只有emit 机器码了), 该指令可以被如下CPU识别:
Intel 486 以上的CPU,
Cyrix M1 以上的CPU,
AMD Am486 以上的CPU
(1) 取CPU OEM 字符串, 判断CPU 厂商
先让EAX=0, 再调用CPUID
Inel的CPU将返回:
EBX:756E6547H 'Genu'
EDX:49656E69H 'ineI'
ECX:6C65746EH 'ntel'
EBX,EDX,ECX 将连成"GenuineIntel", 真正的Intel。
Cyrix 的CPU 将返回:
EBX:43797269H
EDX:78496E73H
ECX:74656164H
"CyrixInstead","Cyrix 来代替"。
AMD 的CPU 将返回:
EBX:41757468H
EDX:656E7469H
ECX:63414D44H
"AuthenticAMD", 可信的AMD。
在Windows98中,用右键单击"我的电脑",选择" 属性- 常规"在计算机描述 处就可看见CPU OEM 字符串。
(2)CPU 到底是几86, 是否支持MMX
先让EAX=1,再调用CPUID
EAX的8到11位就表明是几86
3 - 386
4 - i486
5 - Pentium
6 - Pentium Pro Pentium II
2 - Dual Processors
EDX 的第0位:有无FPU
EDX的第23位:CPU是否支持IA MMX,很重要啊 !如果你想用那57条新增的指 令,先检查这一位吧,否则就等着看Windows 的"该程序执行了非法指令,将被关 闭" 吧。
(3) 专门检测是否P6架构
先让EAX=1,再调用CPUID
如果AL=1,就是Pentium Pro 或Pentium II
(4) 专门检测AMD的CPU信息
先让EAX=80000001H,再调用CPUID
如果EAX=51H, 是AMD K5
如 果EAX=66H, 是K6
EDX第0 位: 是否有FPU( 多余的 !谁用过没FPU的K5,K6)
EDX 第23 位,CPU是否支持MMX,
程序如下:
//------CPUID Instruction Demo Program------------
#include
#include
#pragma hdrstop
//------------------------------------------------
#pragma inline
#pragma argsused
int main(int argc, char argv)
{
char OEMString[13];
int iEAXValue,iEBXValue,iECXValue,iEDXValue;
_asm {
mov eax,0
cpuid
mov DWORD PTR OEMString,ebx
mov DWORD PTR OEMString+4,edx
mov DWORD PTR OEMString+8,ecx
mov BYTE PTR OEMString+12,0
}
cout< < "This CPU 's OEM String is:"< < OEMString< < endl;
_asm {
mov eax,1
cpuid
mov iEAXValue,eax
mov iEBXValue,ebx
mov iECXValue,ecx
mov iEDXValue,edx
}
if(iEDXValue&0x800000)
cout < < "This is MMX CPU"< < endl;
else
cout < < "None MMX Support"< < endl;
int iCPUFamily=(0xf00 & iEAXValue) > >8;
cout < < "CPU Family is:"< < iCPUFamily< < endl;
_asm{
mov eax,2
CPUID
}
if(_AL==1)
cout < < "Pentium Pro or Pentium II Found";
getch();
return 0;
}
最后,最好学会自己去搜索你需要的信息,
我上面的答案也是搜索来的。
关键字“C语言 CPU 信息”
自由口通讯使用 SMB30(口 0)和 SMB130(口 1)来定义通讯口的工作模式。SMB30/SMB130 各位的定义如下:(使用自有口通讯,SM300 和 SM301(SM1300 和 SM1301=0)必须分别为 1 和 0。)

02
发送指令 ( XMT )
使用 XMT 发送指令可以把存于缓冲区中的数据,一次发送一个或多个字节的数据,最多为 255 个。发送完最后一个字符后还可以连接到一个发送完中断(端口 0 为 9,端口 1 位 26,见下表)。和 XMT 有关的寄存器:SMB4 的 SM45 和 SM46。SM45=1 时,口0 发送完毕;SM46=1 时,口 1 发送完毕。
由以上可以看出,有两种方法可以检测端口 0 或 1 的数据发送
状态:一种是利用中断,一种是利用寄存器 SMB4 的第 5 位(口 0)和第 6 位(口 1)。
说明:
T+0:发送信息的字节个数需要提前定义。
T+1~T+255:要发送的数据字节


03
接收指令 ( RCV )
使用接收指令(RCV)可以从端口 0 或 1 接收一个或多个字节的数据(最多 255 个),并存于数据缓冲区。接收完择自由口通讯模式,并选
定自由口通讯的波特率,数据位数和校验方式。
● 定义通讯口接收格式 SMB87(口 0)或 SMB187(口 1)。包括启动
信息接收(第 7 位=1),是否有起始位(第 6 位),是否有结束位(第
5 位)以及是否检测空闲状态(第 4 位)等。
● 设定起始位(SMB88 或 SMB188)或结束位(SMB89 或 SMB189)、空
闲时间信息(SMB90 或 SMB190)及接收的最大字符数(SMB94 或
SMB194)。
● 如利用中断,连接接收完(事件 23)和发送完(事件 9)中断到
中断程序,并且开中断(ENI)。
● 一般还要利用 SMB34 定义一个定时中断,来定时发送数据(一般
为 50ms,即间隔发送数据的时间)。
人应该是通过I/O(输入/输出)系统进行沟通的。 比如键盘、鼠标、话筒等,这些硬件将人类输入的信息,通过I/O系统传递给 *** 作系统, *** 作系统再 *** 作其它硬件用来执行或反馈人类的硬件 *** 作。
计算机的CPU不能直接运行visual Basic编写的程序,CPU只能运行机器二进制码。visual Basic编绎的非二进制,还需要进行一个底层翻译成二进制,所以执行效率比不上C语言这些,比如像驱动程序要求高的程序,绝没有用visual Basic编写的。
应用程序错误解决方法:
1检查电脑是否存在病毒,请使用百度卫士进行木马查杀。
2系统文件损坏或丢失,盗版系统或Ghost版本系统,很容易出现该问题。建议:使用完整版或正版系统。
3安装的软件与系统或其它软件发生冲突,找到发生冲突的软件,卸载它。如果更新下载补丁不是该软件的错误补丁,也会引起软件异常,解决办法:卸载该软件,重新下载重新安装试试。顺便检查开机启动项,把没必要启动的启动项禁止开机启动。
4如果检查上面的都没问题,可以试试下面的方法。
打开开始菜单→运行→输入cmd→回车,在命令提示符下输入下面命令 for %1 in (%windir%\system32\dll) do regsvr32exe /s %1回车。
完成后,在输入下面
for %i in (%windir%\system32\ocx) do regsvr32exe /s %i 回车。
如果怕输入错误,可以复制这两条指令,然后在命令提示符后击鼠标右键,打“粘贴”,回车,耐心等待,直到屏幕滚动停止为止(重启电脑)。
以上就是关于如何用C语言编写探测cpu的程序全部的内容,包括:如何用C语言编写探测cpu的程序、西门子200,cpu低版本1.22,不支持软件自带的modbus 通讯库指令,怎么编写程序、人类与计算机是如何交流的计算机的CPU能不能直接运行visual Basic编写是程序等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)