科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道[冷枫]J2me多线程

[冷枫]J2me多线程

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

J2me多线程(入门级别)

作者:冷枫 来源:CSDN 2007年9月24日

关键字: 冷枫 J2ME 多线程

  • 评论
  • 分享微博
  • 分享邮件
线程也称为轻型进程 (LWP)。因为线程只能在单个进程的作用域内活动,所以创建线程比创建进程要廉价

得多。这样,因为线程允许协作和数据交换,并 且在计算资源方面非常廉价,所以线程比进程更可取。线程需

操作系统的支持,因此不是所有的机器都提供线程。Java 编程语言,作为相当新的一种语言, 已将线程支

与语言本身合为一体,而作为java的微小版本的J2ME同样对线程提供了强健的支持。 在java语言编程中,

使用线程的方法只有两种:一是通过继承Thread类,二是在用到线程的类中实现runnable接口。


Thread 类

Thread 类是一个具体的类,即不是抽象类,该类封装了线程的行为。要创建一个线程,就必须创建一个继承自

Thread 类子类。程序员必须覆盖Thread 的 run() 函数来完成有用的工作。使用时并不直接调用此函数;而是

必须调用 Thread 的 start() 函数,该函数再调用 run()。下面的代码说明了它的用法:

import javax.microedition.lcdui.*;
import javax.microedition.midlet.*;
public class Bounce extends MIDlet {
private BounceCanvas myCanvas;
/**
* 声明RectThread线程类
*/
private RectThread rectThreads[];
private boolean done = false;
private Display myDisplay;
/**
* repaint锁
*/
private Object repaintLock = new Object();
Bounce() {
myDisplay = Display.getDisplay(this);
myCanvas = new BounceCanvas();
createRectThreads();
}
/*
* 创建四个矩形框
*/
void createRectThreads () {
rectThreads = new RectThread[4];
rectThreads[0] = new RectThread(2, 2, 30, 30, 8, myCanvas);
rectThreads[1] = new RectThread(-2, -2, 40, 40, 4, myCanvas);
rectThreads[2] = new RectThread(-1, -1, 50, 10, 10,myCanvas);
rectThreads[3] = new RectThread(4, 4, 10, 10, 2, myCanvas);
}
/**
* 启动线程
*/
protected void startApp() throws MIDletStateChangeException {
myDisplay.setCurrent(myCanvas);
if (rectThreads == null) {
createRectThreads();
}
for (int i = 0; i < rectThreads.length; i++) {
if (!rectThreads[i].isAlive()) {
rectThreads[i].start();
}
}
}
/**
* 停止线程
*/
protected void pauseApp() {
done = true;
if (rectThreads != null) {
for(int i = 0; i < rectThreads.length; i++) {
rectThreads[i].stopThread();
}
rectThreads = null;
}
}
protected void destroyApp(boolean unconditional) {}
class BounceCanvas extends Canvas {
public static final int BACKGROUND_COLOR = 0xFFFFFF;
public static final int FOREGROUND_COLOR = 0x000000;
public void paint(Graphics g) {
synchronized (g) {
g.setColor(BACKGROUND_COLOR);
g.fillRect(0, 0, getWidth(), getHeight());
if (rectThreads != null) {
for (int i = 0; i < rectThreads.length; i++) {
rectThreads[i].paint(g);
}
}
}
}
}



Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=333476

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章