- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
在编码时——你可以使用 Java 作为引用/示例,因为我最熟悉它——你如何设法让多个“ Action ”同时连续发生?我理解,通过足够的循环/boolean 值,您可以设置简单的代码来不断发生——根据不同的输入产生不同的输出——但这并不完全是我的意思。据我所知,代码是相当顺序的(这很好,但我的意思是纯粹的、具体的顺序)。例如,对于某种转换计算器:请求输入、接收输入/处理错误输入、转换、显示、请求再次转换/完成。
但是,对于更复杂的代码,我想知道如何允许各种操作/事件同时发生,或者这种情况的可能性。例如,移动应用程序。允许在(几乎)任何给定时间更改设置,而不是等待程序运行中的特定时间来请求更改设置。同样,视频游戏允许在任何给定时间进行输入,而其他 Action 仍在发生(例如跳跃时移动以及允许人工智能/敌人互动)。是的,代码仍然必须遵循顺序,但是在同一个程序中运行其他进程/过程时,如何同时发生各种输入/输出或操作?
简而言之,我能想到的描述我所问问题的最佳方式是:如何在一个项目中同时运行“多个程序/代码”?
最佳答案
您所描述的是并发或多线程(请查看 Java 文档 http://docs.oracle.com/javase/tutorial/essential/concurrency/ 或其他教程 http://www.vogella.com/tutorials/JavaConcurrency/article.html )。这使您可以通过利用多个核心或在 Activity 之间快速切换以产生同时性的错觉来同时完成多项任务。只是一些基础知识...为此,您创建多个 Thread 对象,并为每个线程对象提供一个 Runnable 对象,该对象基本上用于告诉线程您想要它做什么。每个线程只能执行一次。线程也可以进入“ sleep ”状态,这意味着它们的执行将暂停一段给定的时间(您想要这样做的一个例子可能是,如果您正在制作一个计时器,并且需要一些东西来更改时间)屏幕上每秒都会显示一次。)您还应该意识到线程有可能抛出异常,因此通常必须捕获异常。
我编写了这个程序作为线程的示例。它将打印出正在运行的线程,然后在唤醒之前将线程置于 sleep 状态,并为每个线程重复 25 次。
Runnable myRunnable = new Runnable() {
public void run() {
try {
for (int i = 0; i < 26; i++) {
System.out.println(Thread.currentThread().getName()
+ " is running.");
Thread.sleep(500);
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
};
Thread a = new Thread(myRunnable, "Thread one");
a.start();
Thread b = new Thread(myRunnable, "Thread two");
b.start();
}
这给出了输出
Thread one is running.
Thread one is running.
Thread two is running.
Thread two is running.
Thread one is running.
Thread two is running.
Thread one is running.
Thread one is running.
Thread two is running.
请注意每次输出都不同,并且不像您通常习惯的那样从线程一到线程二线性进展。
关于java - 如何有多个循环/进程/等。同时发生?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20320664/
我是 Linux 的新手,并且继承了保持我们的单一 Linux 服务器运行的职责。这是我们的SVN服务器,所以比较重要。 原来在我之前维护它的人有一个 cron 任务,当有太多 svnserve 进程
Node 虽然自身存在多个线程,但是运行在 v8 上的 JavaScript 是单线程的。Node 的 child_process 模块用于创建子进程,我们可以通过子进程充分利用 CPU。范例:
Jenkins 有这么多进程处于事件状态是否正常? 我检查了我的设置,我只配置了 2 个“执行者”... htop http://d.pr/i/RZzG+ 最佳答案 您不仅要限制 Master 中的执
我正在尝试在 scala 中运行这样的 bash 命令: cat "example file.txt" | grep abc Scala 有一个特殊的流程管道语法,所以这是我的第一个方法: val f
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
我需要一些帮助来理解并发编程的基础知识。事实上,我读得越多,就越感到困惑。因此,我理解进程是顺序执行的程序的一个实例,并且它可以由一个或多个线程组成。在单核CPU中,一次只能执行一个线程,而在多核CP
我的问题是在上一次集成测试后服务器进程没有关闭。 在integration.rs中,我有: lazy_static! { static ref SERVER: Arc> = {
我正在使用 Scala scala.sys.process图书馆。 我知道我可以用 ! 捕获退出代码和输出 !!但是如果我想同时捕获两者呢? 我看过这个答案 https://stackoverflow
我正在开发一个C++类(MyClass.cpp),将其编译为动态共享库(MyClass.so)。 同一台Linux计算机上运行的两个不同应用程序将使用此共享库。 它们是两个不同的应用程序。它不是多线程
我在我的 C 程序中使用 recvfrom() 从多个客户端接收 UDP 数据包,这些客户端可以使用自定义用户名登录。一旦他们登录,我希望他们的用户名与唯一的客户端进程配对,这样服务器就可以通过数据包
如何更改程序,以便函数 function_delayed_1 和 function_delayed_2 仅同时执行一次: int main(int argc, char *argv[]) {
考虑这两个程序: //in #define MAX 50 int main(int argc, char* argv[]) { int *count; int fd=shm
请告诉我如何一次打开三个终端,这样我的项目就可以轻松执行,而不必打开三个终端三次然后运行三个exe文件。请问我们如何通过脚本来做到这一点,即打开三个终端并执行三个 exe 文件。 最佳答案 在后台运行
我编写了一个监控服务来跟踪一组进程,并在服务行为异常、内存使用率高、超出 CPU 运行时间等时发出通知。 这在我的本地计算机上运行良好,但我需要它指向远程机器并获取这些机器上的进程信息。 我的方法,在
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 8年前关闭。 Improve this qu
我有一个允许用户上传文件的应用程序。上传完成后,必须在服务器上完成许多处理步骤(解压、存储、验证等...),因此稍后会在一切完成后通过电子邮件通知用户。 我见过很多示例,其中 System.Compo
这个问题对很多人来说可能听起来很愚蠢,但我想对这个话题有一个清晰的理解。例如:当我们在 linux(ubuntu, x86) 上构建一个 C 程序时,它会在成功编译和链接过程后生成 a.out。 a.
ps -eaf | grep java 命令在这里不是识别进程是否是 java 进程的解决方案,因为执行此命令后我的许多 java 进程未在输出中列出。 最佳答案 简答(希望有人写一个更全面的): 获
我有几个与内核态和用户态的 Windows 进程相关的问题。 如果我有一个 hello world 应用程序和一个暴露新系统调用 foo() 的 hello world 驱动程序,我很好奇在内核模式下
我找不到很多关于 Windows 中不受信任的完整性级别的信息,对此有一些疑问: 是否有不受信任的完整性级别进程可以创建命名对象的地方? (互斥锁、事件等) 不受信任的完整性级别进程是否应该能够打开一
我是一名优秀的程序员,十分优秀!