zoukankan      html  css  js  c++  java
  • 【Java编译】含package的类文件编译

    含package的类文件编译:

    package com.zhangxueliang.setdemo;
    public class Demo1 {
        public static void main(String[] args) {
            System.out.println("123456");
        }
    }

    package com.zhangxueliang.setdemo;
    
    import java.util.HashSet;
    
    /*
     *    使用HashSet存储自定义对象并遍历     
     *    通过查看源码发现:
     *                HashSet的add()方法,首先会使用当前集合中的每一个元素和新添加的元素进行hash值比较,
     *                如果hash值不一样,则直接添加新的元素
     *                如果hash值一样,比较地址值或者使用equals方法进行比较
     *                比较结果一样,则认为是重复不添加
     *                所有的比较结果都不一样则添加
     */
    public class HashSetDemo2 {
        public static void main(String[] args) {
            //创建集合对象
            HashSet<Student> hs = new HashSet<Student>();
            //创建元素对象
            Student s = new Student("zhangsan",18);
            Student s2 = new Student("lisi",19);
            Student s3 = new Student("lisi",19);
            //添加元素对象
            hs.add(s);
            hs.add(s2);
            hs.add(s3);
            //遍历集合对象
            for (Student student : hs) {
                System.out.println(student);
            }
             
        }
             
    }
    
    class Student {
        String name;
        int age;
        
        public Student(String name,int age) {
            this.name = name;
            this.age = age;
        }
    
        @Override
        public String toString() {
            return "Student [name=" + name + ", age=" + age + "]";
        }
    
        @Override
        public boolean equals(Object obj) {
            //System.out.println("-------------------");
            Student s = (Student)obj;//向下转型,可以获取子类特有成员
            
            //比较年龄是否相等,如果不等则返回false
            if(this.age != s.age) {
                return false;
            }
            
            //比较姓名是否相等,如果不等则返回false
            if(!this.name.equals(s.name)) {
                return false;
            }
            
            //默认返回true,说明两个学生是相等的
            return true;
        }
        
        @Override
        public int hashCode() {
            return 1;
        }
        
    }
  • 相关阅读:
    Luogu 4841 城市规划
    Luogu 4721 【模板】分治 FFT
    Luogu 4091 [HEOI2016/TJOI2016]求和
    Luogu 3723 [AH2017/HNOI2017]礼物
    FFT笔记
    Luogu 4900 食堂
    Luogu 4155 [SCOI2015]国旗计划
    Luogu 4069 [SDOI2016]游戏
    Luogu 4254 [JSOI2008]Blue Mary开公司
    Luogu 4251 [SCOI2015]小凸玩矩阵
  • 原文地址:https://www.cnblogs.com/niwotaxuexiba/p/10259326.html
Copyright © 2011-2022 走看看