20240823 system()读取io口状态 popen()接收io操作的返回信息

2024-08-26 16:52

本文主要是介绍20240823 system()读取io口状态 popen()接收io操作的返回信息,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

读取工控机io system 与 popen

  • io操作API
  • c++ system()
  • popen
  • open

os.system()、os.popen()和subprocess的区别(一)

函数system

直接读文件最快![Linux] Ubuntu实机下控制GPIO

io操作API

工控机的io口操作的函数
需要通过命令行执行
在这里插入图片描述
具体指令内容:
在这里插入图片描述

c++ system()

返回数据为字符串
c++程序中通过sytem(cmd)可以执行该操作,但无法接收到返回值
system()操作成功的返回值是0
io信息只打印在终端中
执行过程平均15ms
在这里插入图片描述

popen

通过popen可以开启管道接收system返回的字符串到程序中
在这里插入图片描述
但是耗时更久了,平均55ms
在这里插入图片描述

open

通过文件直接读取DIO电平

#include "stdio.h"
#include "fcntl.h"
#include "unistd.h"//引用需要的头文件int main(void)
{int fd;char value=0;fd = open("/sys/class/gpio/export",O_RDWR);     //fd作为可读可写的/sys/class/gpio/exportwrite(fd,"36",2);                               //启用36号ID引脚,返回的期望值为2个字符close(fd);                                      //释放FDfd = open("/sys/class/gpio/gpio36/direction",O_RDWR);write(fd,"in",3);                               //36号ID设为输入close(fd);fd = open("/sys/class/gpio/gpio36/value",O_RDWR); //fd作为IO口的电平状态valuewhile(1){read(fd,&value,1);                          //读入电平printf("Value =%c \r\n",value);             //打印电平状态sleep(1);                                   //延时1S}return 0;
}

类似地

	char tmp[1024];memset(tmp, 0 , 1024);std::string result;int fd ;fd = open("/sys/kernel/debug/asus-nb-wmi/call", O_RDWR);// cout << " open call res : " << fd  << endl;int rest =   read(fd, tmp, 100 );result += tmp;close(fd);// 从返回字符串中截取倒数第二个字符为电平状态fd= result.size();string res = result.substr(fd-2,1);fd = atoi(res.c_str());// cout << " res : " << x << endl;return fd;

时间测试,1.3ms读取一次
在这里插入图片描述

这篇关于20240823 system()读取io口状态 popen()接收io操作的返回信息的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1109139

相关文章

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

hdu1565(状态压缩)

本人第一道ac的状态压缩dp,这题的数据非常水,很容易过 题意:在n*n的矩阵中选数字使得不存在任意两个数字相邻,求最大值 解题思路: 一、因为在1<<20中有很多状态是无效的,所以第一步是选择有效状态,存到cnt[]数组中 二、dp[i][j]表示到第i行的状态cnt[j]所能得到的最大值,状态转移方程dp[i][j] = max(dp[i][j],dp[i-1][k]) ,其中k满足c

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

【北交大信息所AI-Max2】使用方法

BJTU信息所集群AI_MAX2使用方法 使用的前提是预约到相应的算力卡,拥有登录权限的账号密码,一般为导师组共用一个。 有浏览器、ssh工具就可以。 1.新建集群Terminal 浏览器登陆10.126.62.75 (如果是1集群把75改成66) 交互式开发 执行器选Terminal 密码随便设一个(需记住) 工作空间:私有数据、全部文件 加速器选GeForce_RTX_2080_Ti

状态dp总结

zoj 3631  N 个数中选若干数和(只能选一次)<=M 的最大值 const int Max_N = 38 ;int a[1<<16] , b[1<<16] , x[Max_N] , e[Max_N] ;void GetNum(int g[] , int n , int s[] , int &m){ int i , j , t ;m = 0 ;for(i = 0 ;

hdu3006状态dp

给你n个集合。集合中均为数字且数字的范围在[1,m]内。m<=14。现在问用这些集合能组成多少个集合自己本身也算。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.Inp

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

实例:如何统计当前主机的连接状态和连接数

统计当前主机的连接状态和连接数 在 Linux 中,可使用 ss 命令来查看主机的网络连接状态。以下是统计当前主机连接状态和连接主机数量的具体操作。 1. 统计当前主机的连接状态 使用 ss 命令结合 grep、cut、sort 和 uniq 命令来统计当前主机的 TCP 连接状态。 ss -nta | grep -v '^State' | cut -d " " -f 1 | sort |

matlab读取NC文件(含group)

matlab读取NC文件(含group): NC文件数据结构: 代码: % 打开 NetCDF 文件filename = 'your_file.nc'; % 替换为你的文件名% 使用 netcdf.open 函数打开文件ncid = netcdf.open(filename, 'NC_NOWRITE');% 查看文件中的组% 假设我们想读取名为 "group1" 的组groupName

动手学深度学习【数据操作+数据预处理】

import osos.makedirs(os.path.join('.', 'data'), exist_ok=True)data_file = os.path.join('.', 'data', 'house_tiny.csv')with open(data_file, 'w') as f:f.write('NumRooms,Alley,Price\n') # 列名f.write('NA