我的程序人生_杂谈 X86,WINDOWS,ARM,ANDROID

               好久没有动过博客了,自从两年前,动过,中间也不是没有时间,只是,一些这样那样的原因,或者明确的说,就是自己懒的原因,在这两年的时间里面,正好接触了ARM平台的ANDROID,以及X86平台的ANDROID,加上之前的ARM的WINDOWS,以及很久之前就接触了的,X86平台的WINDOWS,正好,将两个平台,两个系统都接触了一下,今天,闲来无事,就随便说点吧。


               众所周知,ARM是移动平台的芯片霸者,现在其他的厂家,或多或少,在技术上还是和它有些差距的,这个不可否认的事实。X86是PC平台的芯片霸者,完全的垄断地位。ARM也支持WINDOWS,只是去扩展其移动领域平台,巩固其移动芯片的霸主地位,也作为唯一的Windows Phone平台的ARM芯片唯一支持商。而X86去追随ANDROID,则是,无可奈何的办法,虽然,PC平台,还没有像担心的那样,销量的大规模下滑,但是也需要未雨绸缪,可能某一天,移动产品可以代替PC,也不是不可能的事。


                X86和ARM,X86是CISC的代表,ARM是RISC,采用的指令集方向的不同,支持的指令集方向的不同,也注定了芯片研发的侧重点不一样。CISC有大量的指令,可以让CPU的性能发挥到极致。而RISC,是精简指令,使其更加容易,更加小,调用方便,没有那么多的限制条件,可以更好的扩展,没有那么强调CPU的能力,扩展性较好。微软之前是不屑于移动平台的,但看到移动平台的高速发展,也放下身段,提出,统一平台的策略,即,将所有WINDOWS支持的设备,统一为一个系统,这个的前提是KERNEL要一致,所以微软从WIN8开始,将所有的操作系统的内核全部统一,也在其内核中,增加了I2C控制器驱动,GPIO控制器驱动,SPI控制器驱动,SDIO控制器驱动,作为对移动领域的支持。然后,大张旗鼓的,开始开发支持基于ANDROID的OFFICE,以及基于APPLE的OFFICE等。然后,这一切,消费者都没有买账,这个社会就是这样的,晚一点,错过了,就无法去追赶,微软也是,INTEL也是。


              再从平台来看一下:


              ARM支持了WINDOWS的嵌入式系统,PBL + SBL + UEFI + WINEFI + WINDOWS


              X86支持ANDROID系统,PSI + EBL+SLB+LINUX + ANROID


               WINDOW设备驱动,是需要ACP来支持的,是需要这些表格的,我们需要这些DSDT,SSDT这些表格来声明驱动,来设置电源管理的。而之前ARM平台是没有的,所以在ARM支持WINDOWS上,就必须需要UEFI,也就是BIOS来支持。


              而ANDROID是需要,BOOTLOADER,不需要BIOS的,所以X86必须增加BOOTLOADER的支持,现在ANDROID引入了LINUX3.0,所以INTEL就需要对DTS的支持,


              后面有机会,再跟大家详述下,他们支持的原理,以及一些还未完全支持而做的妥协。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Java中,可以使用NI-VISA库来进行GPIB接口控制,下面是一个简单的示例代码。 ```java import com.sun.jna.Native; import com.sun.jna.Pointer; import com.sun.jna.ptr.IntByReference; import visa32.*; public class GPIBControl { private static final int GPIB_ADDRESS = 1; // GPIB地址 private static final int BUFFER_SIZE = 1024; // 缓冲区大小 public static void main(String[] args) { // 初始化NI-VISA库 VisaLibrary visaLibrary = (VisaLibrary) Native.loadLibrary("visa32", VisaLibrary.class); visaLibrary.viOpenDefaultRM(); // 打开GPIB设备 String deviceName = "GPIB0::" + GPIB_ADDRESS + "::INSTR"; Pointer instrument = new Memory(GpibLibrary.ViUInt32.SIZE); visaLibrary.viOpen(visaLibrary.getResourceManager(), deviceName, new GpibLibrary.ViAccessMode(GpibLibrary.VI_NO_LOCK), new GpibLibrary.ViUInt32(0), instrument); Pointer session = instrument.getPointer(0); // 设置超时时间 visaLibrary.viSetAttribute(new GpibLibrary.ViSession(session), new GpibLibrary.ViAttrState(GpibLibrary.VI_TMO_VALUE), new GpibLibrary.ViUInt32(5000)); // 写入命令 String command = "*IDN?"; visaLibrary.viWrite(new GpibLibrary.ViSession(session), command.getBytes(), new GpibLibrary.ViUInt32(command.length()), new IntByReference()); // 读取响应 byte[] buffer = new byte[BUFFER_SIZE]; visaLibrary.viRead(new GpibLibrary.ViSession(session), buffer, new GpibLibrary.ViUInt32(BUFFER_SIZE), new IntByReference()); String response = new String(buffer).trim(); System.out.println("Instrument response: " + response); // 关闭设备 visaLibrary.viClose(new GpibLibrary.ViSession(session)); visaLibrary.viClose(visaLibrary.getResourceManager()); } } ``` 这个示例代码使用NI-VISA库来打开GPIB设备,设置超时时间,写入命令并读取响应。需要注意的是,GPIB_ADDRESS变量需要设置为实际的GPIB地址,BUFFER_SIZE变量可以根据需要进行调整。 在实际应用中,需要根据仪器的通信协议进行编写代码,例如使用SCPI命令进行控制。希望这个示例代码能够对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值