学不成不改名 2024-09-13 22:59 采纳率: 0%
浏览 7

两个相同的测试类结果不一样

为什么我后面的两个测试类写的应该一样,为什么第一个测试类结果输出的不对?


package com.example.scope.threadSafe;

public class AccountService {
    //余额
    public  Integer balance=1000;

    //存钱
    public void  add(Integer money){
        Integer newMoney=balance+money;

        try {
            Thread.sleep(2000);
        } catch (InterruptedException e) {
            throw new RuntimeException(e);
        }

        balance=newMoney;
    }

    //取钱
    public void sub(Integer money){
        Integer newMoney=balance-money;

        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            throw new RuntimeException(e);
        }

        balance=newMoney;
    }

}
package com.example.scope.threadSafe;

import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Scope;


@SpringBootTest(classes = AccountService.class)
public class AccountServiceTest {

    @Bean
    @Scope("prototype")
    public AccountService accountService() {
        return new AccountService();
    }

    @Test
    public void test(@Autowired AccountService accountService1, @Autowired AccountService accountService2) throws InterruptedException {
        new Thread(()->{
            accountService1.add(500);
        }).start();

        new Thread(()->{
            accountService2.sub(500);
        }).start();

        Thread.sleep(3000);

        System.out.println(accountService1.balance);
        System.out.println(accountService2.balance);
    }


}

img

package com.example.scope.threadSafe;

import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Scope;

@SpringBootTest(classes = ASTest.class)
public class ASTest {

    @Bean
    @Scope("prototype")
    public AccountService accountService() {
        return new AccountService();
    }

    @Test
    public void test(@Autowired AccountService accountService1, @Autowired AccountService accountService2) throws InterruptedException {
        new Thread(()->{
            accountService1.add(500);
        }).start();

        new Thread(()->{
            accountService2.sub(500);
        }).start();

        Thread.sleep(3000);

        System.out.println(accountService1.balance);
        System.out.println(accountService2.balance);

    }
}



img

  • 写回答

1条回答 默认 最新

  • 一轮明月照丘壑 2024-09-13 23:02
    关注

    以下回复参考:皆我百晓生券券喵儿等免费微信小程序作答:

    从你提供的代码和输出来看,主要问题似乎是在AccountServiceTest类中accountService的作用域设置上。你在Spring的测试配置中将accountService设置为原型作用域(prototype),这意味着每次从Spring容器中获取时都会创建一个新的实例。因此,在你的测试方法中,创建的两个线程分别使用了两个不同的AccountService实例。这意味着它们不会互相干扰,各自操作自己的实例变量balance。所以当你打印两个accountServicebalance值时,你会看到不同的值。这也解释了为什么第一个测试类结果输出的不对,因为你可能预期它们共享同一个实例的balance值。

    然而,在ASTest类中,你正确地设置了accountService为原型作用域,并且你的输出也显示了两个线程操作的是不同的实例的balance值。在这种情况下,你的测试输出是预期的,因为你对每个线程都使用了新的AccountService实例。你在测试中看到的两个线程操作的不同的余额值是正常的行为。

    如果你希望两个线程操作同一个AccountService实例的余额值,你应该将accountService的作用域设置为单例(singleton)或者在其他地方使用一个共享的实例,而不是每次都创建一个新的实例。但是在多线程环境中,还需要注意线程安全的问题,你的addsub方法当前并没有进行同步处理,可能会导致并发问题。如果你希望在多线程环境中操作同一个实例的余额值,你可能需要使用某种形式的同步机制来保证线程安全。

    评论

报告相同问题?

问题事件

  • 创建了问题 9月13日

悬赏问题

  • ¥15 如何在vue.config.js中读取到public文件夹下window.APP_CONFIG.API_BASE_URL的值
  • ¥50 浦育平台scratch图形化编程
  • ¥20 求这个的原理图 只要原理图
  • ¥15 vue2项目中,如何配置环境,可以在打完包之后修改请求的服务器地址
  • ¥20 微信的店铺小程序如何修改背景图
  • ¥15 UE5.1局部变量对蓝图不可见
  • ¥15 一共有五道问题关于整数幂的运算还有房间号码 还有网络密码的解答?(语言-python)
  • ¥20 sentry如何捕获上传Android ndk 崩溃
  • ¥15 在做logistic回归模型限制性立方条图时候,不能出完整图的困难
  • ¥15 G0系列单片机HAL库中景园gc9307液晶驱动芯片无法使用硬件SPI+DMA驱动,如何解决?