原 自学JVAVA---(41)--(内功心法【39】)TreeSet

本文深入解析了TreeSet的数据结构和工作原理,包括其底层实现为TreeMap的机制,以及如何通过比较接口进行元素排序。通过一个具体的示例,展示了TreeSet如何根据自定义对象的compareTo方法进行排序,并在元素相等时的处理策略。

TreeSet
一颗键值哈希树,只有前键做仓库。
比较顺序有内幕,排序接口来指路。

TreeSet底层是TreeMap

public class TreeSet<E> extends AbstractSet<E>
    implements NavigableSet<E>, Cloneable, java.io.Serializable
{
    /**
     * The backing map.
     */
    private transient NavigableMap<E,Object> m;

    // Dummy value to associate with an Object in the backing Map
    private static final Object PRESENT = new Object();

    /**
     * Constructs a set backed by the specified navigable map.
     */
    TreeSet(NavigableMap<E,Object> m) {
        this.m = m;
    }

TreeSet测试


public class TreeSetDemo {
    public static void main(String[] args) {
       TreeSet<People> ps = new TreeSet<>();
       ps.add(new People(1,"亚历山大",40,30000));
       ps.add(new People(3,"奥巴马",32,30000));
       ps.add(new People(7,"安倍晋三",44,30000));
       ps.add(new People(2,"马克龙",21,300));
       ps.add(new People(5,"罗斯福",55,7000));
        //TreeSet是根据compareTo方法判断两个元素是大于还是小于 来排序
        // 如果相等就就会取第一个元素后边的不要
       ps.add(new People(3,"马相伯1",12,80000));
       ps.add(new People(3,"马相伯2",12,80000));
       ps.add(new People(3,"马相伯3",12,80000));
        System.out.println(ps);

    }
}

class People implements  Comparable<People>{
    private  Integer id;
    private  String name;
    private  Integer age;
    private  Integer salary;

    public People(Integer id, String name, Integer age, Integer salary) {
        this.id = id;
        this.name = name;
        this.age = age;
        this.salary = salary;
    }

    @Override
    public int compareTo(People o) {
        if(this.age > o.age){
            return 1;
        }else if(this.age < o.age){
            return -1;
        }else  if(this.id > o.id){
            return  1;
        }else if(this.id < o.id){
            return  -1;
        }if(this.id == o.id){
            //TreeSet是根据compareTo方法判断两个元素是大于还是小于 来排序
            // 如果相等就就会取第一个元素后边的不要
            System.out.println("相等");
            return  0;
        }
        return 0;
    }

    @Override
    public String toString() {
        return "People{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", age=" + age +
                ", salary=" + salary +
                '}';
    }
}
在Java中获取视频时长通常需要借助第三方库来解析视频文件,因为Java标准库本身并不直接支持视频文件的处理。一个常用的库是Xuggler,它可以被用来获取视频的基本信息,包括时长。以下是使用Xuggler库来获取视频时长的一个基本示例: ```java import com.xuggle.mediatool.IMediaReader; import com.xuggle.mediatool.ToolFactory; import com.xuggle.mediatool.event.IVideoPictureEvent; import com.xuggle.xuggler.IStream; import com.xuggle.xuggler.IStreamCoder; import com.xuggle.xuggler.IVideoResampler; public class VideoDuration { public static void main(String[] args) { // 创建媒体读取器 IMediaReader mediaReader = ToolFactory.makeReader("video_file_path.mp4"); // 设置事件处理器 mediaReader.addListener(new MediaAdapter() { @Override public void onVideoPicture(IVideoPictureEvent event) { // 获取视频流 IStream stream = event.getStream(); // 获取流编解码器 IStreamCoder coder = stream.getStreamCoder(); if (coder.getCodecType() == IStreamCoder.Type.VIDEO) { long duration = stream.getContainer().getDuration(); System.out.println("视频时长: " + duration / 1000 + " 秒"); } } }); // 读取媒体文件 while (mediaReader.readPacket() == null) { // 循环读取直到结束 } } } ``` 在这个示例中,我们创建了一个`IMediaReader`对象来读取视频文件,并且设置了一个事件监听器来处理视频帧事件。当读取到视频帧时,我们检查了帧所属的流,并获取了流的时长信息。需要注意的是,这个示例使用了Xuggler的旧API,而Xuggler已经不再维护。现在推荐使用Xuggler的后续项目——JAVE(Java Audio Video Encoder)。 请确保在项目中添加了所需的依赖库才能运行上述代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值