在 Linux 上使用 C/C++ 中的 write() 函数通过 UART Beaglebone Black 写入 70kB
using write() function in C/C++ on Linux to write 70kB via UART Beaglebone Black
我正在尝试通过 UART 在 Beaglebone Black 上写入图像。但是当我在 library 中使用 write()
函数时。
int write(int handle, void *buffer, int nbyte);
不管agurment nbyte
有int
类型,我不能一次传输70kB。我显示传输的字节数,结果是字节数=4111。
length = write(fd,body.c_str(),strlen(body.c_str())); //
cout<<length<<endl; // result length = 4111;
cout<<strlen(body.c_str())<<endl; // result strlen(body.c_str()) = 72255;
希望收到你的来信!
write
调用不保证您可以写入提供的数据量,这就是为什么它像 return 一样是整数,而不是布尔值。您看到的行为实际上在不同的操作系统中很常见,这可能是由于下划线设备可能没有足够的缓冲区或存储空间供您写入 70kb。你需要的是循环写入,每次写入将写入未写入的数量:
int total = body.length(); // or strlen(body.c_str())
char *buffer = body.c_str();
int written = 0;
int ret;
while (written < total) {
ret = write(fd, buffer + written, total - written);
if (ret < 0) {
// error
break;
}
written += ret;
}
我正在尝试通过 UART 在 Beaglebone Black 上写入图像。但是当我在 library 中使用 write()
函数时。
int write(int handle, void *buffer, int nbyte);
不管agurment nbyte
有int
类型,我不能一次传输70kB。我显示传输的字节数,结果是字节数=4111。
length = write(fd,body.c_str(),strlen(body.c_str())); //
cout<<length<<endl; // result length = 4111;
cout<<strlen(body.c_str())<<endl; // result strlen(body.c_str()) = 72255;
希望收到你的来信!
write
调用不保证您可以写入提供的数据量,这就是为什么它像 return 一样是整数,而不是布尔值。您看到的行为实际上在不同的操作系统中很常见,这可能是由于下划线设备可能没有足够的缓冲区或存储空间供您写入 70kb。你需要的是循环写入,每次写入将写入未写入的数量:
int total = body.length(); // or strlen(body.c_str())
char *buffer = body.c_str();
int written = 0;
int ret;
while (written < total) {
ret = write(fd, buffer + written, total - written);
if (ret < 0) {
// error
break;
}
written += ret;
}