会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132384个问题
JAVA 全系列/第二阶段:JAVA 基础深化和提高/反射技术(旧) 3348楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/容器(旧) 3349楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/IO 流技术(旧) 3350楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/多线程技术(旧) 3353楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/多线程技术 3355楼

老师,我的Users  类如下:


import java.util.Objects;

public class Users implements Comparable<Users>{
  private String usersname;
  private int  usersage;

    public Users(String yanggege, String s) {
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        Users users = (Users) o;
        return usersage == users.usersage &&
                Objects.equals(usersname, users.usersname);
    }

    @Override
    public int hashCode() {
        return Objects.hash(usersname, usersage);
    }

    public Users(String usersname, int usersage) {
        this.usersname = usersname;
        this.usersage = usersage;
    }

    public String getUsersname() {
        return usersname;
    }

    public void setUsersname(String usersname) {
        this.usersname = usersname;
    }

    public int getUsersage() {
        return usersage;
    }

    public void setUsersage(int usersage) {
        this.usersage = usersage;
    }

    @Override
    public String toString() {
        return "Users{" +
                "usersname='" + usersname + '\'' +
                ", usersage=" + usersage +
                '}';
    }

    @Override
    public int compareTo(Users o) {
        if (this.usersage>o.getUsersage()){
            return 1;
        }
        if (this.usersname==o.getUsersname()){
            return this.usersname.compareTo(o.usersname);
        }
        return -1;
    }
}

TreeMap 代码:

 import java.util.Map;
 import java.util.Set;
 import java.util.TreeMap;

public class TreeMapTset {
    public static void main(String[] args) {

        //实例化RreeMap
        Map<Users,String> map=new TreeMap<>();
         Users u1=new Users("杨明","24");
         Users u2=new Users("李飞","19");
         Users u3=new Users("张哥","10");
         Users u4=new Users("陈飞信","55");
         map.put(u1,"杨明");
         map.put(u2,"zangxiao");
         map.put(u3,"sixiaozi");
         map.put(u4,"lixiaozo");
         Set<Users> set=map.keySet();
         for (Users str:set){
            System.out.println(str+"====="+map.get(str));
         }

    }


}

输出:请问下是哪里错了。

image.png

JAVA 全系列/第二阶段:JAVA 基础深化和提高/容器(旧) 3356楼

/**
 * 创建缓冲区
 * 要点:
 * 1、创建缓冲区空间大小(目前是数组空间)  →  生产者生产数据  →  判断空间是否满了?满了就进入阻滞状态调用Object下面wait方法
 *    满了消费者没来拿数据,就需要唤醒消费者 (调用Object下面notify方法唤醒单个线程)
 * 2、消费者来拿  →判断有没有数据  →  如果没了就进入阻滞状态  →  同时唤醒生产者线程
 */


//定义馒头类
class ManTou{
    private int id;
    public ManTou(int id){
        this.id=id;
    }

    public int getId() {        //私有属性需要
        return this.id;
    }
}

//定义缓冲区
class SycStack{          //缓冲区不需要继承谁,它只是一个放数据地方
    //定义放馒头的空间
    private ManTou[] mt =new ManTou[10];

    //定义操作空间的索引;
    private int index;

    //放馒头
    public synchronized void push(ManTou manTou) throws InterruptedException {
        while(this.index==this.mt.length){          //放数据之前要先判断空间满没满,用循环多判断几次,一次不保险

            this.wait();    //Object  类下的   让线程休眠的方法;  必须在synchronized域内使用。 会先释放对象锁,再休眠。

        }
        this.notify();   //Object  类下  唤醒单个线程的方法,必须在synchronized域内使用。会唤醒在等待队列状态中的  单个线程。/notifyAll是全部线程
        this.mt[this.index]=manTou;    //放馒头时需要知道位置,默认是0;
        this.index++;    //每放一个,索引+1,直到空间满了
    }

    //取馒头
    public synchronized  ManTou pop() throws InterruptedException {
        while (this.index==0){
            this.wait();
        }
        this.notify();     //对方线程若是处于运行状态  唤醒也无妨
        this.index--;
        return this.mt[this.index];   //先判断,不为空则 拿一个,拿完之后把剩下的返回;
    }
}

//定义生产者线程
class ShengChan extends Thread{
    private SycStack ss;     //生产的数据要放在缓冲区,
    public ShengChan(SycStack ss){
        this.ss=ss;
    }

    @Override
    public void run() {
        for(int i=0;i<10;i++){
            System.out.println("生产的馒头"+i);
            ManTou mt=new ManTou(i);    //不知道这里为什么这么做,要创建馒头对象
            try {
                this.ss.push(mt);     //调用放馒头的方法
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}


//定义消费者线程
class XiaoFei extends Thread{
    private SycStack ss;     //消费的数据也放在缓冲区,
    public XiaoFei(SycStack ss) {
        this.ss = ss;

    }

    @Override
    public void run() {
        for(int i=0;i<10;i++){
            try {
                ManTou manTou = this.ss.pop();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            System.out.println("消费的馒头"+i);
            }
    }

}


public class TestProduceTread {
    public static void main(String[] args) {

        //s实例化缓冲区
        SycStack ss=new SycStack();

        //实例放、取馒头化线程
        new ShengChan(ss).start();
        new XiaoFei(ss).start();
    }
}

老师为什么我的代码结果是顺序排的?试了几次都这样2.png

JAVA 全系列/第二阶段:JAVA 基础深化和提高/多线程技术 3357楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/网络编程(旧) 3360楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637