用qtextbrowser的settext显示一段可变字符串qstring,200ms调用一次,占用cpu逐步提高,最后达到100%, 猜测原因可能是执行一次settext的时间超过200ms,导致cpu被预先占用,实际看到的就是占用率逐步升高。可是有个好奇怪的问题,就是停止执行settext后cpu占用率一直都不下来。而重复允许一次程序,几秒内停止执行settext,cpu又回复正常了。 后来发现是qstring的问题,原来新信息通过qstring+= 添加到字符串末尾,就是qstring的+=运算符号导致的问题,重复执行几秒内停止后cpu回复正常的原因是每次重新开始会清空qtstring字符串,通过qstring.clear(); 最后不使用+= 运算符操作,直接用= 符号,CPU占用率一直在正常水平。 看来qstring还有许多不安全的操作隐患
最后发现:原来是我把qstring定义为全局变量导致的问题,
在C++中,内存分成5个区,他们分别是堆、栈、自由存储区、全局/静态存储区和常量存储区。 栈,就是那些由编译器在需要的时候分配,在不需要的时候自动清楚的变量的存储区。里面的变量 通常是局部变量、函数参数等。 堆,就是那些由new分配的内存块,他们的释放编译器不去管,由我们的应用程序去控制,一般一 个new就要对应一个delete。如果程序员没有释放掉,那么在程序结束后,操作系统会自动回收。 自由存储区,就是那些由malloc等分配的内存块,他和堆是十分相似的,不过它是用free来结束 自己的生命的。 全局/静态存储区,全局变量和静态变量被分配到同一块内存中,在以前的C语言中,全局变量又分 为初始化的和未初始化的,在C++里面没有这个区分了,他们共同占用同一块内存区。 常量存储区,这是一块比较特殊的存储区,他们里面存放的是常量,不允许修改。
因为全局变量和静态变量一样是由编译器编译时静态确定了的,当我后来在qstring末端添加 数据时导致qstring对静态存储区进行操作,而静态存储区是不可扩充的,所以导致qstring 内部一直对静态存储操作不成功,可能换用了其他方案进行扩充,所以CPU占用率一下子就上来了,而且随着 添加次数越多,cpu占用越高, 最后解决方法,把全局qstring改成qstring*, 在堆上用new 新建,最后解决问题!!!
|