草庐IT

flushing

全部标签

c++ - 调用 flush cout 无效

我试图让cout缓冲区刷新,以便在我操作它之前查看一个字符串。我试图通过调用std::flush()和std::cout.flush()来刷新缓冲区,但实际上都没有刷新我的输出。只有调用std::endl才能为我成功刷新缓冲区。这是我的代码std::istringstreamstm(game.date());intday,month,year;chardelim='/';std::cout>month>>delim;stm>>day>>delim;stm>>year>>delim;std::cout这是我的输出日期之后:|2013年1月31日日期之后:|2012年3月21日日期之后:|

c++ - std::endl << std::flush 有目的吗?

std::flush紧接在std::endl用于我正在查看的遗留代码之后。当我第一次看到这个时,我的想法是查看std::endl和std::flush的描述是多余的:http://en.cppreference.com/w/cpp/io/manip/endlhttp://en.cppreference.com/w/cpp/io/manip/flush这是我在遗留源代码中看到的示例:std::cout但是,由于多年来许多高级软件开发人员都看过这段代码,我想知道我是否遗漏了一些细节。在std::endl之后添加std::flush有什么意义吗? 最佳答案

redis - Redis中使用RDB+AOF混合持久化时如何自动flush appendonly.aof?

我正在尝试在具有以下配置的Redis中使用混合持久性(RDB+AOF作为尾部):aof-use-rdb-preambleyesappendonlyyessave101#我假设来自https://github.com/antirez/redis/blob/4.0/redis.conf#L746-L782当Redis重新启动时,它会从[RDB文件][AOF尾部]加载种子数据。我希望每次写入RDB时,AOF文件都会被刷新,以便只保留尾部(自上次RDB保存以来的最新更新)。这可以通过一些配置实现吗? 最佳答案 不,这不可能。尽管AOF有一个

redis - 在 Redis 集群上运行 SCRIPT FLUSH 是否安全?

最近,我的一个Redis集群开始出现问题。used_memroy和used_memory_rss不断增加。根据一些谷歌搜索,我发现了以下讨论:https://github.com/antirez/redis/issues/4570现在我想知道在我的生产Redis集群上运行SCRIPTFLUSH命令是否安全? 最佳答案 是的-您可以在生产集群中安全地运行SCRIPTFLUSH命令。唯一潜在的副作用是在服务器执行时阻塞服务器。但是请注意,您需要在每个节点中调用它。 关于redis-在Redi

mysql innodb :innodb_flush_method

在下面的链接中http://dev.mysql.com/doc/refman/5.1/en/innodb-parameters.html#sysvar_innodb_flush_method它说:这个变量的不同值会对InnoDB性能产生显着影响。例如,在InnoDB数据和日志文件位于SAN上的某些系统上,已发现将innodb_flush_method设置为O_DIRECT会使简单SELECT语句的性能降低三倍。为什么O_DIRECT会减慢select语句的速度? 最佳答案 O_DIRECT绕过操作系统的缓存系统。SAN可能是一个非常

c# - NetworkStream.Write 和 Flush 成功,尽管远程套接字已关闭

我在尝试将数据写入远程TCP服务器时遇到问题,连接被切断,但我无法检测到这种情况何时发生。我目前的假设是WriteAsync正在缓冲数据,但是我还假设FlushAsync应该通过网络强制它(并导致IOException)。我尝试这样做的真正原因是我需要执行一些低级别的HTTP流量,并且我想在发送请求正文之前验证HTTPheader是否已正确发送。我有一个简单的单元测试来说明我面临的问题。publicsealedclassSocketDisconnectTests{[Fact]publicasyncTaskShouldNotWriteIfDisconnected(){varlistene

java.net.Socket > outputStream > BufferedOutputStream flush() 确认

有没有办法知道BufferedOutputStream线程的flush()方法何时或是否成功完成?在我的例子中,我使用它通过java.net.Socket发送一个简单的字符串。在下面的代码中,flush()方法与BufferedReader.read()方法并行运行,套接字输出立即被输入读取阻塞,从而导致类似于死锁的情况。我想做的是等待输出结束,然后开始读取输入。Socketsk=newSocket("192.168.0.112",3000);BufferedOutputStreambo=newBufferedOutputStream(sk.getOutputStream());bo.

java - 套接字流的 flush() 有多可靠?

考虑这段(简化的)代码:publicclassTest{//assignedelsewhereInetSocketAddresssocketAddress;StringsocketHost;intsocketPort;Socketsocket;intCOMMAND=10;intCONNECTION_TIMEOUT=10*1000;intSOCKET_TIMEOUT=30*1000;DataOutputStreamdos;DataInputStreamdis;protectedvoidconnect()throwsIOException,InterruptedException{sock

c# - 通过临时启用 NoDelay 套接字 "Flush"

背景我有一个用C#实现的HTTP服务器。使用ab我发现了一个奇怪的性能问题。每个请求在Keep-Alive关闭时花费5毫秒,但在Keep-Alive打开时花费40毫秒!测试页生成为单个byte[],使用单个socket.Send调用作为回复发送。据我所知,原因是TCP堆栈中使用的Nagle算法。TCP同花顺?到目前为止,我使用的是NoDelay服务的每个HTTP请求末尾的属性。socket.NoDelay=true;socket.NoDelay=false;这确实解决了现在的问题。但是我没有文档来支持我的发现。这是在linux/mono系统上测试的。是否有刷新TCP连接的标准方法?相关

java - OutputStream 的 flush 方法什么都不做?

来自OutputStream.flush()文档。为什么它在文档中说明OutputStream的flush方法什么都不做在解释它实际上做了一些事情之后?非常困惑。 最佳答案 OutputStream是一个派生自的抽象类。子类将提供自己的实现如有必要。否则默认行为是什么都不做。例如查看ObjectOutputStream.flush()的代码 关于java-OutputStream的flush方法什么都不做?,我们在StackOverflow上找到一个类似的问题: