多线程-java相同线程,不同方法线程内传值问题

问题描述

java相同线程,不同方法线程内传值问题

大家好,我想请问一个问题,比如
class A{
new Thread(() -> {
int a = 1;
B b = new B();
b.invokeB(a);
});
}

class B{
public void invokeB(int a){
C c = new C();
c.invokeC();
}
}

class C{
public void invokeC(){
//这里我想用a的值,由于某些原因,不能直接把a传过来,听说用ThreadLocal可以实现,但是不太会用,有人能帮我么,谢谢大家。
}
}

解决方案

第一,你的代码有编译错误,A类的那段代码应该放在代码块中,而且new Thread并没有start所以,没有运行结果。
首先,你要知道ThreadLocal修饰的成员变量,它修饰类的成员变量,可以获取当前线程存入的这个变量的副本。
其次,你的C方法,必须能跟这个a练习起来,那么a必须定义为某个类的ThreadLocal类型的成员变量才能。而且它的访问也是直接操作这个变量的。
你说的这种需求有点牵强,C类没有与局部变量a的连接点,不可能得到a的值。而且你的B的invokeB(int a)已经有参数了却没有用。
你要真的想这么用的话,要么传递给C,要么将a定义为全局静态共享的变量。

 public class A {
    public static int a = 1;

    public static void main(String[] args) {
        new A().invokeA();
    }

    public void invokeA(){
        new Thread(() -> {
            //设置当前线程的a的值
            B b = new B();
            b.invokeB();
        }).start();//需要start启动线程
    }
}

class B {
    public void invokeB() {
        C c = new C();
        c.invokeC();
    }
}

class C {
    public void invokeC() {
        // 这里我想用a的值,由于某些原因,不能直接把a传过来,听说用ThreadLocal可以实现,但是不太会用,有人能帮我么,谢谢大家。
        System.out.println(A.a);
    }
}

解决方案二:

楼上正解,其实就是一个变量生命周期的问题,c跟a没有任何的连接点怎么使用。而且线程没启动,方法没调用。楼主对线程的理解也不够深入。还是多看看书,有帮助的。

解决方案三:

一楼正解,其实自己可以试一试

时间: 2024-11-08 19:54:37

多线程-java相同线程,不同方法线程内传值问题的相关文章

多线程-JAVA中如何在一个线程里面停掉另一个线程

问题描述 JAVA中如何在一个线程里面停掉另一个线程 JAVA中如何在一个线程里面停掉另一个线程,是在一个线程里面哦 PS:新人第一次问问题,希望大神求教 解决方案 定义一个共享变量在run方法里面 while(start){ } 解决方案二: 所以说,这个问题的答案是:不可以! 虽然的确有那么个方法可以摧毁别人的线程,但很早很早就已经过期了,如果没记错的话我之前也这么玩,而结果是这个过期的方法根本没有作用-- 虽然说办法不是没有,那就是通过改变变量值,它知道自己该死了,就退出循环,走向结束.

Java基础-23总结多线程,线程实现Runnable接口,线程名字获取和设置,线程控制,线程安全,同步线程

你需要的是什么,直接评论留言. 获取更多资源加微信公众号"Java帮帮" (是公众号,不是微信好友哦) 还有"Java帮帮"今日头条号,技术文章与新闻,每日更新,欢迎阅读 学习交流请加Java帮帮交流QQ群553841695 分享是一种美德,分享更快乐! 1:多线程(理解) (1)多线程:一个应用程序有多条执行路径 进程:正在执行的应用程序 线程:进程的执行单元,执行路径 单线程:一个应用程序只有一条执行路径 多线程:一个应用程序有多条执行路径 多进程的意义? 提高

【疑惑】Java的多线程与“用户级线程”/“核心级线程”的疑惑

问题描述 翻阅操作系统的书得到两个概念,"用户级线程"和"核心级线程",而且列举了用户级线程的优缺点.其中,讲到用户级线程的缺点的地方有两点:1.统一进程的多个线程不能真正并行:2.由于线程对操作系统透明,调度处于进程级别,若进程中的一个线程通过系统调用进入操作系统受阻,那么将阻塞该进程疑惑来了,反思Java的多线程实现是用户级线程:1.那么Java的多线程实现并发怎么回事,难道骗人的?(CPU多核?)2.用户级线程调度发生在进程级别,与核心级线程的调度有何区别.3

JAVA之旅(十五)——多线程的生产者和消费者,停止线程,守护线程,线程的优先级,setPriority设置优先级,yield临时停止

JAVA之旅(十五)--多线程的生产者和消费者,停止线程,守护线程,线程的优先级,setPriority设置优先级,yield临时停止 我们接着多线程讲 一.生产者和消费者 什么是生产者和消费者?我们解释过来应该是生产一个,消费一个,的意思,具体我们通过例子来说 package com.lgl.hellojava; //公共的 类 类名 public class HelloJJAVA { public static void main(String[] args) { /** * 生产者和消费者

Java多线程:用三个线程控制循环输出10次ABC

题目:有A,B,C三个线程, A线程输出A, B线程输出B, C线程输出C,要求, 同时启动三个线程, 按顺序输出ABC, 循环10次. 解题思路:要按顺序输出ABC, 循环10次,就要控制三个线程同步工作,也就是说要让三个线程轮流输出,直到10个ABC全部输出则结束线程.这里用一个Lock对象来控制三个线程的同步.用一个int型变量state标识由那个线程输出.   1 package com.thread; 2 3 import java.util.concurrent.locks.Lock

详解Java多线程编程中CountDownLatch阻塞线程的方法_java

直译过来就是倒计数(CountDown)门闩(Latch).倒计数不用说,门闩的意思顾名思义就是阻止前进.在这里就是指 CountDownLatch.await() 方法在倒计数为0之前会阻塞当前线程. CountDownLatch是一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待. CountDownLatch 的作用和 Thread.join() 方法类似,可用于一组线程和另外一组线程的协作.例如,主线程在做一项工作之前需要一系列的准备工作,只有这些准备工

Java理论与实践: 线程池与工作队列

为什么要用线程池? 诸如 Web 服务器.数据库服务器.文件服务器或邮件服务器之类的许多服务 器应用程序都面向处理来自某些远程来源的大量短小的任务.请求以某种方式到 达服务器,这种方式可能是通过网络协议(例如 HTTP.FTP 或 POP).通过 JMS 队列或者可能通过轮询数据库.不管请求如何到达,服务器应用程序中经常 出现的情况是:单个任务处理的时间很短而请求的数目却是巨大的. 构建服务器应用程序的一个过于简单的模型应该是:每当一个请求到达就创 建一个新线程,然后在新线程中为请求服务.实际上

【转载】JAVA内存模型和线程安全

本文转载自http://shift-alt-ctrl.iteye.com/blog/1845309   一.JAVA内存模型(JMM,JAVA Memory Model):     运行时涉及到两种内存,主内存和工作区内存,其中工作区内存通常为CPU的高速缓存区用来加快内存数据读取操作的(各线程独立).所有的变量内容都存在主内存中,当需要对内存数据进行操作时,数据将会从主存中load到工作区缓存并由CPU计算和赋值操作,然后再由工作区内存write到主存中,读取时如果工作区内存中已经有(load

java内存模型与线程(转) good

java内存模型与线程 参考 http://baike.baidu.com/view/8657411.htm  http://developer.51cto.com/art/201309/410971_all.htm http://www.cnblogs.com/skywang12345/p/3447546.html 计算机的CPU计算能力超强,其计算速度与 内存等存储 和通讯子系统的速度相比快了几个数量级, 数据加载到内存中后,cpu处理器运算处理时,大部分时间花在等待获取去获取磁盘IO.网络