首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Java线程对象如何调用原始类中的方法?

Java线程对象可以通过以下几种方式调用原始类中的方法:

  1. 继承Thread类:创建一个继承自Thread类的子类,并重写run()方法,在run()方法中调用原始类中的方法。然后创建该子类的对象,并调用start()方法启动线程。
代码语言:txt
复制
class MyThread extends Thread {
    private OriginalClass original;

    public MyThread(OriginalClass original) {
        this.original = original;
    }

    @Override
    public void run() {
        original.method();
    }
}

OriginalClass original = new OriginalClass();
Thread thread = new MyThread(original);
thread.start();
  1. 实现Runnable接口:创建一个实现了Runnable接口的类,并实现其run()方法,在run()方法中调用原始类中的方法。然后创建该类的对象,并将其作为参数传递给Thread类的构造函数,最后调用start()方法启动线程。
代码语言:txt
复制
class MyRunnable implements Runnable {
    private OriginalClass original;

    public MyRunnable(OriginalClass original) {
        this.original = original;
    }

    @Override
    public void run() {
        original.method();
    }
}

OriginalClass original = new OriginalClass();
Runnable runnable = new MyRunnable(original);
Thread thread = new Thread(runnable);
thread.start();
  1. 使用匿名内部类:可以直接在创建线程对象时使用匿名内部类来重写run()方法,并在其中调用原始类中的方法。
代码语言:txt
复制
OriginalClass original = new OriginalClass();
Thread thread = new Thread(new Runnable() {
    @Override
    public void run() {
        original.method();
    }
});
thread.start();

以上是三种常见的调用原始类方法的方式,根据具体情况选择适合的方式。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • Java多线程面试题及回答(详细总结)

    在任何Java面试当中多线程和并发方面的问题都是必不可少的一部分。如果你想获得任何股票投资银行的前台资讯职位,那么你应该准备很多关于多线程的问题。在投资银行业务中多线程和并发是一个非常受欢迎的话题,特别是电子交易发展方面相关的,他们会问面试者很多令人混淆的Java线程问题,面试官只是想确信面试者有足够的Java线程与并发方面的知识,因为候选人中有很多只浮于表面,用于直接面向市场交易的高容量和低延时的电子交易系统在本质上是并发的。下面这些是我在不同时间不同地点喜欢问的Java线程问题,我没有提供答案,但只要可能我会给你线索,有些时候这些线索足够回答问题,现在引用Java5并发包关于并发工具和并发集合的问题正在增多。那些问题中ThreadLocal、BlockingQueue、CountingSemaphore和ConcurrentHashMap比较流行。

    00

    Java多线程与并发

    答:进程是资源分配的最小单位,线程是CPU调度的最小单位。   1)、进程是资源分配的基本单位,所有与进行相关的资源,都被记录在进程控制块PCB中,以表示该进程拥有这些资源或者正在使用它们。   2)、进程是抢占处理机的调度单位,线程属于某个进程,共享其资源。进程拥有一个完整的虚拟内存地址空间,当进程发生调度的时候,不同的进程拥有不同的虚拟地址空间,而同一进程内不同线程共享同一地址空间,与进程相对应。线程与资源分配无关,它属于某一个进程,并与进程内的其它线程一起共享进程里面的资源。   3)、线程只由堆栈、寄存器、程序计数器和线程计数表TCB组成。

    02

    15个顶级Java多线程面试题及回答

    在任何Java面试当中多线程和并发方面的问题都是必不可少的一部分。如果你想获得任何股票投资银行的前台资讯职位,那么你应该准备很多关于多线程的问题。在投资银行业务中多线程和并发是一个非常受欢迎的话题,特别是电子交易发展方面相关的。他们会问面试者很多令人混淆的Java线程问题。面试官只是想确信面试者有足够的Java线程与并发方面的知识,因为候选人中有很多只浮于表面。用于直接面向市场交易的高容量和低延时的电子交易系统在本质上是并发的。下面这些是我在不同时间不同地点喜欢问的Java线程问题。我没有提供答案,但只要可能我会给你线索,有些时候这些线索足够回答问题。现在引用Java5并发包关于并发工具和并发集合的问题正在增多。那些问题中ThreadLocal、Blocking Queue、Counting Semaphore和ConcurrentHashMap比较流行。

    03

    线程与Java线程

    对于程序的运行过程,操作系统中最重要的两个概念是进程和CPU,进程就是运行程序的一个抽象,CPU主要工作就是对进程的调度。需要理解的是,一个CPU在一个瞬间,只能执行一个进程,通常这个时间片段是几十毫秒或几百毫秒,但对于用户来讲,就像多个程序同时运行,这就是伪并行(对于一个CPU来讲)。进程包含几乎程序运行的所需要的所有信息,包括程序计数器、堆栈指针、程序对应地址空间(存放可执行程序、程序的数据、程序的堆栈等)的读写操作以及其他资源的信息。进程的执行有三个状态:正在运行的进程是运行态,还包括就绪态(可运行,CPU正在执行别的进程)、阻塞态(等待某个资源或某个事件发生之前的进程的状态)。三种状态的切换如下图所示:

    03
    领券