C8051单片机和安捷伦IO的viRead读回参数

C8051F040单片机使用中断发送数据时,发现程序总是进中断,编写的函数如下

void main()
{
while(1)
{
if(sequence == 1)
{
TI0 = 1;
}
}
}

void UART0_Interrupt (void) interrupt 4
{
if(RI0 == 1)
{
RI0 = 0;
}

if(TI0 == 1)
{
	TI0 = 0;
	SBUF0 = 0X55;
}

}

这么处理是总进入中断的原因,因为main函数中TI0设置为1的时候就会进入中断,中断中将TI0设置为0后,等发送完数据后还会进入中断,这个才是真正发送完成的中断,而第一次的中断是主函数中将TI0设置为1的中断,不是真正的发送完成中断。从而导致不断的进入中断。处理方法为:在中断函数中可以加入某个判断条件,来完成发送,比如要发送个数组,就用数组的长度len,每次发送完len-1。

安捷伦的viRead函数是读到\n结束,因此收到*IDN?类似的命令后,串口或者网口需要发送\n作为结尾字符,这样才可以读到数据
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用VC6.0读取安捷伦6052两个通道的传输延迟的示例代码: ```c++ #include <stdio.h> #include <stdlib.h> #include <conio.h> #include <windows.h> #include "visa.h" #define BUFFER_SIZE 1024 int main() { ViSession vi; // 声明visa会话 ViStatus status; // 声明visa状态 ViUInt32 retCount; // 声明返回值 ViChar desc[BUFFER_SIZE]; // 声明设备描述符 ViChar resultBuffer[BUFFER_SIZE]; // 声明读取缓冲区 ViReal64 delay; // 声明延迟值 // 初始化visa status = viOpenDefaultRM(&vi); if (status != VI_SUCCESS) { printf("无法初始化VISA!\n"); return -1; } // 打开设备 status = viOpen(vi, "USB0::0x0957::0x1734::MY57501650::INSTR", VI_NULL, VI_NULL, &vi); if (status != VI_SUCCESS) { printf("无法打开设备!\n"); return -1; } // 发送命令,获取描述符 status = viWrite(vi, "*IDN?\n", 6, &retCount); status = viRead(vi, desc, BUFFER_SIZE, &retCount); printf("设备描述符: %s\n", desc); // 设置通道 status = viWrite(vi, "ROUT:CHAN:SEL 1,2\n", 19, &retCount); // 获取传输延迟 status = viWrite(vi, "MEASure:DELay?\n", 16, &retCount); status = viRead(vi, resultBuffer, BUFFER_SIZE, &retCount); delay = atof(resultBuffer); printf("传输延迟: %lf\n", delay); // 关闭设备 status = viClose(vi); // 关闭visa status = viClose(vi); return 0; } ``` 请注意,此示例代码仅供参考,并且需要根据您的实际应用程序进行更改。同时,请确保已安装正确的visa驱动程序,并且已正确连接安捷伦6052设备。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值