【发布时间】:2012-12-26 18:59:45
【问题描述】:
我已经阅读了很多帖子,其中谈到了使用 JavaME 同时读取和写入文件不。我有一个特殊的用例场景,其中我的日志文件(可能是完整文件或只是文件的一部分)定期上传到服务器。这必须在不妨碍应用程序在同一文件中的当前日志记录的情况下继续进行。
代码示例如下:
boolean writing = true;
boolean reading = true;
void main() {
new Thread("THREAD-FILE-READ") {
public void run() {
InputStream instream = getFileInStream();
if (null != instream) {
while (reading) {
try {
try {
synchronized(READ_LOCK) {
READ_LOCK.wait();
}
} catch (InterruptedException ex) {
ex.printStackTrace();
}
if (writtenCharsLen > 0) {
byte[] bytes = new byte[writtenCharsLen];
instream.read(bytes, 0, writtenCharsLen);
System.out.println("Read="+new String(bytes));
bytes = null;
writtenCharsLen = 0;
}
} catch (IOException ioe) {
ioe.printStackTrace();
}
}
}
closeStream(instream);
}
}.start();
new Thread("THREAD-FILE-WRITE") {
public void run() {
OutputStream outstream = getFileOutStream();
if (null != outstream) {
while (writing) {
try {
byte[] str = randomString();
if (null != str) {
writtenCharsLen = str.length;
System.out.println("Write=" + new String(str));
outstream.write(str);
str = null;
}
} catch (IOException ex) {
ex.printStackTrace();
} finally {
notifyReadStream();
}
try {
synchronized(WRITE_LOCK) {
WRITE_LOCK.wait();
}
} catch (InterruptedException ex) {
ex.printStackTrace();
}
}
}
closeStream(outstream );
}
}.start();
}
void notifyReadStream() {
try {
synchronized (READ_LOCK) {
READ_LOCK.notify();
}
} catch (Exception e) {
e.printStackTrace();
}
}
void notifyWriteStream() {
try {
synchronized (WRITE_LOCK) {
WRITE_LOCK.notify();
}
} catch (Exception e) {
e.printStackTrace();
}
}
在上面的代码中,我将用对网络 IO 方法的正确调用来替换 sop-read 和 sop-write。
PS:由于这段代码将运行多个文件和多个设备,我需要尽可能压缩修改以保持我的运行时堆尽可能低。此外,这段代码将一直运行到应用程序生命周期,因此不考虑在中间关闭和打开文件。
出现不希望的结果:
读写线程显示正在运行的读写操作。读取线程正在从写入线程已写入的位置读取。我在这段代码中没有遇到任何异常,但结果是不希望的。我也尝试过同步读写流,但那是抛出IllegalMonitorStateException
预期结果: 流的读取必须在写入流完成后触发,并且读取线程必须能够从文件中的任何位置读取。
任何帮助/指针有用吗?
编辑:我能够使用不同的监视器同步读取和写入流,但我仍然觉得,我可以使用单个监视器做得更好。稍后会尝试。
【问题讨论】:
-
您对多线程代码的适应程度如何?例如,Jenkov's tutorial 中的主题看起来很熟悉吗?鉴于 J2ME 的限制,我会说这是我见过的最相关的介绍
-
@gnat,感谢您的链接,阅读它真的很有见地。是的,我对多线程移动环境和开发非常满意。请检查我的问题描述,我已经编辑了同步实现。我现在正在研究的下一个问题是如何巧妙地,以及使用多个变量来记录添加/删除的字节数的传统方式,从我拥有的最后一个位置的文件中读取足够的字节已经上传到服务器了。我正在为这个实现寻找一种优化的方法。
-
对于那个下一个问题,你考虑过BlockingQueue吗? Jenkov 的章节中有解释和代码。如果我理解正确,“THREAD-FILE-WRITE”将
enqueue和“THREAD-FILE-READ”将dequeue -
@gnat,是的,我有。正如你所说,它将入队和出队,我可以通过对我的监视器进行排序来实现。我现在的直接问题是如何有效地从写入器写入的文件中读取足够的字节以发送到服务器。我知道我可以通过使用存储文件中字节的当前位置和新位置的变量来做到这一点,但我的目标是优化方法 bcoz (a) 它的 IO 操作是资源密集型的 & (b) 这将发生为多次通知读取队列。我正在考虑一些更简单的方法来解决上述问题。
-
我明白了。看起来你正在寻找一些有趣的东西。 :) 就队列而言,您必须设计什么、何时以及如何入队/出队,对吗?
标签: java multithreading java-me midp