关于数据输入缓冲区的几个小疑问(未解决)

本文通过几个具体的C++示例,探讨了cin、cin.get()和cin.getline()三种输入方式的区别及其工作原理。特别是在输入缓冲区管理和字符读取终止条件上的不同行为。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

代码如下:

 

发现如果不做任何注释,结果如下

image

如果注释掉8-11行后运行结果如下:

image

再继续注释掉12-15行后运行结果如下:

image

可以发现当执行第一个cin的时候后面的cin.get()不会再让你输入,但是为什么单独的时候就需要你再去输入呢?

我的理解:每一个函数应该独立的输入数据流。cin的时候你输入,cin.get的时候你再重新输入,cin.getline的时候你再重新输入(当我们注释掉一部分确实出现了这样的情况)。但没有按我想的做,而是形成了一个缓冲池,cin默认是以空格结束的,所以只输出一部分,然后缓冲池剩余的部分再到cin.get中,如果还有剩余再到cin.getline中,如果没有了剩余就应该另行输入啊,但是看上面的程序显然没有再输入一次。

 

我试着多输入了一些,证明了我的猜想多余的会逐步递进到下面的函数中,如下图。为什么呢??????

image

memcpy(inputBuf, encodedPacket.data, dataSize);还是一到这里就出段错误啊void *open_media(void *argv){ __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "open_media xxxxxxxxxx"); ThreadData *data = static_cast<ThreadData *>(argv); RKMpp* mppDecoder = data->mppDecoder.get(); const char *rurl = data->url; std::string cstr = std::string(data->cameraId); int cameraId = std::stoi(cstr); std::string istr = std::string(data->indexStr); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "open_media xxxxxxxxxx %s", istr.c_str()); int index = std::stoi(istr); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "open_media %d %s %i", cameraId, rurl, index); int retries = 0; while (retries < MAX_RETRIES) { cv::VideoCapture stream1(rurl, cv::CAP_FFMPEG); if (!stream1.isOpened()) { __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "Cannot open RTSP stream!"); std::cerr << "无法打开 RTSP 流,尝试第 " << retries + 1 << " 次重连..." << std::endl; retries++; std::this_thread::sleep_for(std::chrono::seconds(RETRY_INTERVAL)); continue; } __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "oooooooooooo!"); cv::Mat encodedPacket; // 假设存储编码数据(如 H.264 包) while (true) { // 从流中读取编码数据包(需验证 OpenCV 是否支持直接读包) if (!stream1.grab()) { // 处理断流重连 break; } __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "kkkkkkkkkk!"); // 获取 MPP 输入缓冲区 int inputIndex = mppDecoder->dequeueInputBuffer(500000); if (inputIndex < 0) continue; __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "ppppppppppp!"); // 读取编码数据缓冲区 if (stream1.retrieve(encodedPacket)) { __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "iiiiiiiiii!"); char *inputBuf = mppDecoder->getInputBuffer(inputIndex); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "uuuuuuuuuuu!"); size_t dataSize = encodedPacket.total() * encodedPacket.elemSize(); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "ffffffffff!"); memcpy(inputBuf, encodedPacket.data, dataSize); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "aaaaaaaaa!"); mppDecoder->queueInputBuffer(inputIndex, 0, dataSize, 0); __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "sssssssssss!"); } __LOG_PRINT(ANDROID_LOG_DEBUG, "rtsp", "jjjjjjjjjjjj!"); // 获取解码后的帧 int outputIndex = mppDecoder->dequeueOutputBuffer(100000); // if (outputIndex >= 0) { // char *decodedFrame = mppDecoder.getFrame(); // screenShot(num, cameraId, index, decodedFrame); // 修改后的截图函数 // } } } }
最新发布
03-25
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值