问题是这样的,我有一个文件夹大概有10万行数据,然后用c++和python分别其数出有多少行数据是符合要求的。因为不知道什么原因,c++和python总是只能数出其中的七千多行就结束了,然后我就用了文件指针定位来解决了这个问题,然后c++和python写的两个程序都能正常运行和计算了。但是我发现c++运行出结果需要29秒,而python只需要7秒。为什么会这样ps:c++我用的是getline函数,而python我用的是readlines函数。另外有个问题就是在另一个每一行不等长的文件中,c++的指针定位为什么总是不像python一样能够精准定位到文件尾,文件指针和getline函数搭配怎么使用。。。?求大神求大神。。。哭求。。。回复内容:
因为 c++ 有「兼容 c」的历史包袱在。默认情况下 std::cin 每次操作后都要和 stdin 的缓冲区做同步,以便 iostream 和 stdio 混用。关掉这一行为即可大幅提升性能:
std::ios_base::sync_with_stdio(false);
就算是刘翔跑一步停一下,再跑一步再停一下,也没我连着跑一万米快…楼主你信还是不信
我觉得跟getline比较的应该是python的readline函数,而不是readlines函数。
在优化大致相当的情况下,无非就是时间和空间的相互妥协。getline每次返回一行,也只用一行的内存。而readlines一次读取10万行,然后一行行给你。c++多花的时间是为他少花的内存付出的代价而已。
学习了