Chinaunix
标题:
一个简单的GUI程序造成X占CPU达80%以上
[打印本页]
作者:
xwzss
时间:
2007-12-27 12:11
标题:
一个简单的GUI程序造成X占CPU达80%以上
这是我程序的部分代码:
while (1) {
remaining = sizeof(buffer) - bufpos;
if ( (len = read(fd, buffer + bufpos, remaining)) > 0) {
bufpos += len;
pos = 0;
while ( (bufpos - pos) >= LENGTH) {
cnt = data_parse(buffer + pos, display, win, gc);
pos += cnt;
}
if (pos < bufpos) {
memmove(buffer, buffer + pos, bufpos - pos);
bufpos -= pos;
} else {
bufpos = 0;
}
}
}
复制代码
data_parse部分:
int
data_parse(unsigned char *data, Display *display, Window win, GC gc)
{
int loop, bad;
int x, y, p;
int new_x, new_y, new_p;
bad = 0;
for (loop = 0; loop < LENGTH; loop++) {
if ( ((loop == 0) && !(data[loop] & 0x80)) || ((loop != 0) && (data[loop] & 0x80))) {
bad = 1;
if ( (loop != 0) && (data[loop] & 0x80))
return loop;
}
}
if (bad)
return LENGTH;
if ( !(data[0] & 1)) {
old_x = -1;
old_y = -1;
return LENGTH;
}
x = (data[1] << 7) + data[2];
y = (data[3] << 7) + data[4];
p = (data[5] << 7) + data[6];
if (x > 6144 || y > 8192 || p > 1024)
return LENGTH;
new_x = x_table[x];
new_y = y_table[y];
new_p = p_table[p];
if (old_x < 0 || old_y < 0) {
old_x = new_x;
old_y = new_y;
}
XSetLineAttributes(display, gc, ebook_p, LineSolid, CapRound, JoinRound);
XDrawLine(display, win, gc, old_x, old_y, new_x, new_y);
XFlush(display);
old_x = new_x;
old_y = new_y;
return LENGTH;
}
复制代码
这是个手写板的部分代码,这个程序从串口读数据,然后分析,得出X,Y坐标,再在屏幕上划出来,不过这个程序使X占CPU达到80%以上,有什么办法降低这个占用率吗?
作者:
cyberHunK
时间:
2007-12-27 12:28
由于刚接触linux环境下程序设计,系统的优化及调用机制还不明确,但根据已往的经验,在你的程序中应该出现了“盲等”这种情况!检查一下你代码中出现循环的部分,做断点跟踪观察!对一些事件检查类型的循环,要做成触发的机制,把不必要的循环判断都剔出掉!
作者:
yjfkpyu
时间:
2008-01-02 21:10
在while(1)的循环中加入usleep(n); 不然你的cpu一直在跑你的死循环当然会达近100%了,可以根据你需要的实时程度来设置n的值,n是微妙
作者:
pernlee
时间:
2008-01-05 02:32
标题:
回复 #3 yjfkpyu 的帖子
sleep(1) 就可以了
作者:
cqtzj
时间:
2008-01-05 13:38
关注,
作者:
yjfkpyu
时间:
2008-01-18 20:47
sleep(1)会太长了,这段程序还是需要一定的实时性的
作者:
ttt678
时间:
2008-03-03 14:04
用select函数试试
作者:
zhongfangqing
时间:
2008-03-04 08:48
while (1) {
remaining = sizeof(buffer) - bufpos;
if ( (len = read(fd, buffer + bufpos, remaining)) > 0) {
bufpos += len;
pos = 0;
while ( (bufpos - pos) >= LENGTH) {
cnt = data_parse(buffer + pos, display, win, gc);
pos += cnt;
}
if (pos < bufpos) {
memmove(buffer, buffer + pos, bufpos - pos);
bufpos -= pos;
} else {
bufpos = 0;
}
}
usleep(5000);//这里加一句试试
}
作者:
linux_wuliqiang
时间:
2008-03-05 18:14
标题:
回复 #1 xwzss 的帖子
问题应该在 if ( (len = read(fd, buffer + bufpos, remaining)) > 0) ,
用gdb 调试一下,看能发现什么不。。。
作者:
bluesprit980203
时间:
2008-03-06 11:04
提示:
作者被禁止或删除 内容自动屏蔽
作者:
Innost
时间:
2008-03-28 22:12
用线程吧 否则gui刷新也会很慢
欢迎光临 Chinaunix (http://bbs.chinaunix.net/)
Powered by Discuz! X3.2