process.start("cmd.exe",args); process.waitForStarted(); process.write("echo 98 > /sys/class/gpio/export;echo high > /sys/class/gpio/gpio98/direction;echo 99 > /sys/class/gpio/export;cat /sys/class/gpio/gpio99/value\n");代码中没有多次调用 process.write 方法的情况下process.write为什么会执行两遍,如何制止
时间: 2023-08-02 19:11:41 浏览: 99
根据你提供的代码,我猜测可能出现了缓冲区的问题。当调用 `process.write()` 方法时,写入的数据并不会立即发送到子进程,而是先暂存在缓冲区中,直到缓冲区满或者手动调用 `process.flush()` 方法才会将数据发送到子进程中。因此,在你的代码中,由于缓冲区满或者其他原因,第一个 `process.write()` 写入的数据没有被发送到子进程中,当程序执行到第二个 `process.write()` 时,之前的数据也被一起发送了,导致实际执行的命令是两个 `process.write()` 写入的命令的组合。
要解决这个问题,可以在每次调用 `process.write()` 方法后手动调用 `process.flush()` 方法将数据立即发送到子进程中,如下所示:
```
process.start("cmd.exe",args);
process.waitForStarted();
process.write("echo 98 > /sys/class/gpio/export;echo high > /sys/class/gpio/gpio98/direction;echo 99 > /sys/class/gpio/export;cat /sys/class/gpio/gpio99/value\n");
process.flush(); // 手动将数据发送到子进程中
```
这样就可以确保每次写入的数据都会立即发送到子进程中,避免多次命令的组合。
相关问题
process.start("cmd.exe",args); process.waitForStarted(); process.write("echo 98 > /sys/class/gpio/export;echo high > /sys/class/gpio/gpio98/direction;echo 99 > /sys/class/gpio/export;cat /sys/class/gpio/gpio99/value\n");代码中process.write为什么会执行两遍,如何制止
根据你提供的信息,我看到这段代码是在 Qt 中使用 QProcess 类执行的,其中 process 是 QProcess 类的一个实例对象。如果你多次调用 process.write 方法,那么每次调用都会向子进程的标准输入写入数据。因此,如果你执行了多次 process.write 方法,那么子进程就会接收到多个相同的命令并执行多次。如果你只想执行一次命令,可以将这段代码放在一个函数中,然后只调用一次该函数。
另外,如果你想要确保 process.write 方法只会执行一次,可以使用信号与槽机制。例如,在调用 process.waitForStarted 方法之前,可以连接 QProcess 类的 finished 信号到一个槽函数上,在槽函数中调用 process.write 方法,这样就可以确保 process.write 方法只会在子进程执行完成后执行一次。
int WorkThread::adb_shell_uart_test(QString temp) { QProcess process; QStringList args; args << "/c" << "adb shell"; process.start("cmd.exe",args); process.waitForStarted(); QString command1 = QString("stty -F /dev/tty%1 -echo\n").arg(temp); QString command2 = QString("cat dev/tty%1 &\n").arg(temp); QString command3 = QString("echo 1234 > dev/tty%1\r\n").arg(temp); QByteArray byteArray1 = command1.toUtf8(); // 将字符串编码为 UTF-8 格式的字节数组 QByteArray byteArray2 = command2.toUtf8(); QByteArray byteArray3 = command3.toUtf8(); process.write( byteArray1); process.write( byteArray2); process.write( byteArray3); process.waitForBytesWritten(); process.closeWriteChannel(); process.waitForFinished(5000); // 等待进程执行完毕 QString output = process.readAllStandardOutput(); qDebug() << "TEST:"; qDebug() << output; QString result = output.right(5); if(result == " 1234"){ return 0; }else{ return -1; } }
这段代码是一个在 Qt 中调用 adb 命令行工具执行串口测试的函数。具体实现如下:
1. 创建一个 `QProcess` 对象 `process`。
2. 创建一个 `QStringList` 对象 `args`,并向其添加两个参数:`/c` 和 `adb shell`。这两个参数会被传递给 `cmd.exe`,并告诉它执行 `adb shell` 命令。
3. 调用 `process.start()` 启动 `cmd.exe` 进程,并将 `args` 作为参数传递给它。这样就可以启动一个 adb shell 子进程。
4. 调用 `process.waitForStarted()` 等待子进程启动完成。
5. 构造三个命令字符串:`command1`、`command2` 和 `command3`,分别用于设置串口属性、启动串口监听和向串口发送数据。
6. 将命令字符串转换为 UTF-8 编码的字节数组,并通过 `process.write()` 向子进程输入这些命令。
7. 调用 `process.closeWriteChannel()` 关闭子进程的写通道。
8. 调用 `process.waitForFinished()` 等待子进程执行完毕,最多等待 5 秒。
9. 调用 `process.readAllStandardOutput()` 读取子进程的标准输出,并将其存储到 `output` 变量中。
10. 判断 `output` 中的最后五个字符是否为 " 1234",如果是,则返回 0,表示测试通过;否则返回 -1,表示测试失败。
需要注意的是,该函数中执行了一些 adb shell 命令,因此需要确保 adb 工具已经正确安装,并且在系统环境变量中设置了 adb 工具的路径。另外,该函数中使用了 `cmd.exe` 命令行解释器来启动 adb shell 子进程,因此该函数只能在 Windows 系统中运行。
阅读全文