JAVA ---直接调用run方法

在Java中,直接调用`Thread`类的`run()`方法是可以的,但这并不是推荐的做法,也不是多线程编程的正确方式。
直接调用`run()`方法会在当前线程中执行`run()`方法的内容,而不会启动新的线程。为了实现多线程编程,应该使用`start()`方法来启动线程,这样会在新的线程中执行`run()`方法。
  1. 线程启动的正确方式
    要启动一个新线程,应该调用Thread类的start()方法,而不是run()方法。start()方法会启动一个新的线程,并在新的线程中调用run()方法。

  2. 直接调用run()方法的效果
    如果直接调用Thread类的run()方法,那么run()方法会在当前线程(通常是主线程)中执行,而不会创建新的线程。这意味着代码会按顺序执行,没有并发性,失去了多线程编程的意义。

  3. 示例代码

    public class MyThread extends Thread {
        @Override
        public void run() {
            System.out.println("Thread is running.");
        }
    
        public static void main(String[] args) {
            MyThread myThread = new MyThread();
    
            // 正确的启动线程方式
            myThread.start();
    
            // 错误的启动线程方式
            // myThread.run();
        }
    }
    

    在这个示例中,如果调用myThread.start(),会启动一个新的线程并在新线程中执行run()方法。如果调用myThread.run()run()方法会在主线程中执行。

  4. 总结
    直接调用Thread类的run()方法不会启动新的线程,而是会在当前线程中执行run()方法的内容。为了实现多线程编程,应该始终使用start()方法来启动线程。

### Java `-jar` 命令 Java 的 `java -jar` 命令用于执行打包成 JAR 文件的 Java 应用程序。此命令适用于任何标准的 Java 程序,只要该程序被打包成了可执行的 JAR 文件。 当使用 `java -jar` 执行一个应用程序时,JVM 将加载 JAR 中定义的清单文件中的主,并启动这个作为入口点来运行整个应用[^1]。 ```bash java -jar myApplication.jar ``` 这种方式适合于普通的 Java 应用程序,在本地环境中直接运行,不需要额外的服务支持或复杂的配置环境。 ### Flink `run` 命令 相比之下,Apache Flink 提供了一个专门设计用来提交作业到集群上的 `flink run` 命令。它不仅能够像 `java -jar` 那样启动任务,还提供了更多针对分布式计算场景的功能选项和支持[^3]。 例如: - 可以通过 `-m <host:port>` 参数指定 JobManager 地址; - 支持设置并行度 (`-p`) 来调整性能表现; - 能够处理批处理 (Batch Processing) 和流处理 (Stream Processing) 型的任务; - 对输入输出路径的支持更加灵活,可以直接指向 HDFS 或者其他存储系统内的资源位置; 具体来说,对于 WordCount 这样的例子,可以通过如下方式调用: ```bash ./bin/flink run ./examples/batch/WordCount.jar \ --input file:///home/user/hamlet.txt \ --output file:///home/user/wordcount_out ``` 这表明了如何利用 `flink run` 向集群提交一个预编译好的 Flink 项目,并指定了数据源以及目标保存地点。 ### 主要差异总结 | 特性 | java -jar | flink run | |--| | **适用范围** | 普通 Java 应用 | Apache Flink 作业 | | **默认行为** | 直接在当前 JVM 实例上运行 | 把作业提交给远程或本地的 Flink 集群 | | **资源配置控制** | 不提供 | 支持自定义内存大小、CPU 数量等 | | **日志管理** | 日志记录依赖于应用程序本身 | 统一的日志收集机制 | | **监控与调试工具** | 缺乏内置支持 | 内置 Web UI 和 REST API |
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

需要重新演唱

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值