一、在一个类中重写toString方法

public class Person {
private String name;
private int age; public Person() {
} public Person(String name, int age) {
this.name = name;
this.age = age;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public int getAge() {
return age;
} public void setAge(int age) {
this.age = age;
} @Override
public String toString() {
// {name=name , age= age}
return "{" + "name=" + getName() +
"age=" + getAge() +
"}";
} // 重写 equals @Override
public boolean equals(Object obj) {
// 判断内存地址是否相同
if( this == obj ){
return true;
}
// 判断 传入的obj的对象是否为空 obj的类型与当前类型是否相同
if ( obj == null || this.getClass() != obj.getClass() ){
return false;
} // 强转 类型
Person p = (Person) obj
// 判断传入的obj对象 的 值是否为空,判断值是否相同, return this.age == p.age && Objects. equals( this.name,p.name ) // 判断 值是否相同
}

二、泛型的定义和使用

  可以 灵活地 将数据类型应用到不同的  类、方法、接口中    将数据类型做为参数进行传递
 
 
 
 
 
  1。定义和使用含有泛型的类  ,方法,参数 
      定义格式:
          修饰符 class  类名 <代表泛型的变量>{    }
  
      例子:
      // 泛型在类中使用 定义的 位置   位于        类名 后
          public class Person <E>{
                  // 泛型作为参数   在   括号里
                  public boolean add (E e){
                  }
                  //  带有 泛型 方法  位于 替换 方法类型
                  public E get(int index){
                  
                  }
          }
  2.距离定义 泛型类
              public class MyGenericClass<MVP> {
          //没有MVP类型,在这里代表 未知的一种数据类型 未来传递什么就是什么类型
          private MVP mvp;
  
          public void setMVP(MVP mvp) {
              this.mvp = mvp;
          }
  
          public MVP getMVP() {
              return mvp;
          }
      }
      
  3.  含有泛型的 方法 定义的格式
      格式:
          修饰符 <代表泛型的变量> 返回值类型 方法名(参数){ }
  
          public class MyGenericMethod {
          public <MVP> void show(MVP mvp) {
              System.out.println(mvp.getClass());
          }
  
          public <MVP> MVP show2(MVP mvp) {
              return mvp;
          }
      }
  
  4.含有泛型的接口
      定义格式:
              修饰符 interface 接口名 <代表泛型的变量>{ }
              
       public interface  MyGenericInterface<E>{
                 public abstract void add(E e);
  
                  public abstract E getE(); 
       }
 
 
 
      在定义类的时候 确定泛型 的类型 
          例如:
                  public class MyImp1 implements MyGenericInterface<String> {
                          @Override
                          public void add(String e) {
                              // 省略...
                          }
                          @Override
                          public String getE() {
                              return null;
                          }
                }
      
      2、始终不确定泛型的类型,直到创建对象时,确定泛型的类型
          public class MyImp2<E> implements MyGenericInterface<E> {
              @Override
              public void add(E e) {
                   // 省略...
              }
  
              @Override
              public E getE() {
                  return null;
              }
          }
      /**
      确定泛型
      */
  
          public class GenericInterface {
              public static void main(String[] args) {
                  MyImp2<String>  my = new MyImp2<String>();  
                  my.add("aa");
              }
          }
一、泛型的通配符
      当使用 泛型类 或者接口时,传递的数据中,泛型的类型不确定,可以通过通配符<?>表示。但是一旦使用泛型通配符后,
   只能使用Object类的共性方法,集合中自身方法无法使用。
      
      1.通配符基本使用
              泛型的通配符的:不知道什么时候用什么类型 来 接受的时候, 此时 可以使用 ? 表示未知通配符
              
              例子:
                      public static void main(String[] args) {
                              Collection<Intger> list1 = new ArrayList<Integer>();
                              getElement(list1);
                              Collection<String> list2 = new ArrayList<String>();
                              getElement(list2);
                          }
                          public static void getElement(Collection<?> coll){}
                          //?代表可以接收任意类型
 
              Notes:
tips:泛型不存在继承关系 Collection<Object> list = new ArrayList<String>();这种是错误的; 2.通配符高级使用----受限泛型
之前设置泛型的时候,实际上是可以任意设置的,只要是类 就可以设置。但是在Java的泛型中可以制定一个泛型的上线和下限 泛型的上限:
格式: 类型名称<? extends 类> 对象名称
意义:只能接收该 类型及其子类 泛型的下限:
格式 : 类型的名称<? super 类> 对象名称
意义: 只能 接收该类型 及其父类类型
                  例子:
public static void main(String[] args) {
Collection<Intger> list1 = new ArrayList<Integer>();
Collection<String> list2 = new ArrayList<String>();
Collection<Number> list3 = new ArrayList<Number>();
Collection<Object> list4 = new ArrayList<Object>(); getElement(list1);
getElement(list2);//报错
getElement(list3);
getElement(list4);//报错 getElement2(list1);//报错
getElement2(list2);//报错
getElement2(list3);
getElement2(list4); } // 泛型的上限:此时的泛型?,必须是Number类型或者Number类型的子类
public static void getElement1(Collection<? extends Number> coll){}
// 泛型的下限:此时的泛型?,必须是Number类型或者Number类型的父类
public static void getElement2(Collection<? super Number> coll){}

常见数据结构:

栈、队列、数组、链表和红黑树。

Java重写toString和泛型的使用的更多相关文章

  1. java重写toString()方法

    toString()方法是Object类的方法,调用toString()会返回对象的描述信息. 1)为什么重写toString()方法呢? 如果不重写,直接调用Object类的toString()方法 ...

  2. java重写toString方法

    在输出对象属性时,重写toString按照你希望的输出形式重写 object类里的toString只是把字符串的直接打印,数字的要转化成字符再打印,而对象,则直接打印该对象的hash码.所以当你要想按 ...

  3. Effective Java 第三版——12. 始终重写 toString 方法

    Tips <Effective Java, Third Edition>一书英文版已经出版,这本书的第二版想必很多人都读过,号称Java四大名著之一,不过第二版2009年出版,到现在已经将 ...

  4. java 中重写toString()方法

    toString()方法 一般出现在System.out.println(类名.toString()); toString()是一种自我描述方法 本身返回的是 getClass().getName() ...

  5. java打印和重写toString

    class Person { private String name; public Person(String name) { this.name=name; } } public classPri ...

  6. java实体类如果不重写toString方法,会如何?

    先认识一下Object Object 类的 toString 方法 返回一个字符串,该字符串由类名(对象是该类的一个实例).at 标记符“@”和此对象哈希码的无符号十六进制表示组成.换句话说,该方法返 ...

  7. 【java基础】为什么重写toString()方法?

    不得不说,有很多java初学者写java实体类的时候,并没有真正理解重写toString() 方法,可能是口头知道也可能是跟风随带添加toString() 方法,并没有真正理解其意义,如果真要被问起来 ...

  8. java继承 、方法重写、重写toString方法

    1.Java的继承,关键词Extends package cn.mwf.oo; public class TextExtends { public static void main(String[] ...

  9. 在java中为啥要重写toString 方法?

    在java中为啥要重写toString 方法?下面以一个简单的例子来说明. 先定义一个test5类.并写它的get,set方法. package test5; public class Test5 { ...

随机推荐

  1. Python3.2-re模块之常用正则记录

    python的re模块是个很好的模块,这里简单记录下自己编写的几个有用的正则: 1:邮箱匹配: gReMailbox = re.compile(r'([\w\.\-+]+@[\w\-]+(?:\.[\ ...

  2. QT1.1-与Opencv的hello world

    qt:一个1991年由奇趣科技开发的跨平台C++图形用户界面应用程序开发框架.它既可以开发GUI程序,也可用于开发非GUI程序,比如控制台工具和服务器.Qt是面向对象的框架,使用特殊的代码生成扩展(称 ...

  3. China Cloud Computing Conference(2018.07.24)

    时间:2018.07.24地点:北京国家会议中心

  4. AI Summit(2018.07.19)

    AI Summit 时间:2018.07.19地点:北京丽都皇冠假日酒店

  5. Android应用安全之数据传输安全

    Android软件通常使用WIFI网络与服务器进行通信.WiFi并非总是可靠的,例如,开放式网络或弱加密网络中,接入者可以监听网络流量:攻击者可能 自己设置WIFI网络钓鱼.此外,在获得root权限后 ...

  6. 20155306 白皎 0day漏洞——漏洞利用原理之DEP

    20155306 白皎 0day漏洞--漏洞利用原理之DEP 一.DEP机制的保护原理 1.为什么出现DEP? 溢出攻击的根源在于现代计算机对数据和代码没有明确区分这一先天缺陷,就目前来看重新去设计计 ...

  7. 未能正确加载包“Microsoft.Data.Entity.Design.Package.MicrosoftDataEntityDesignPackage(转)

    版权声明:作者:jiankunking 出处:http://blog.csdn.net/jiankunking 本文版权归作者和CSDN共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显 ...

  8. JS计算混合字符串长度

    用的是正则表达式 var str = ”坦克是tank的音译”; var len = str.match(/[^ -~]/g) == null ? str.length : str.length +  ...

  9. 定制 input[type="radio"] 和 input[type="checkbox"] 样式

    表单中,经常会使用到单选按钮和复选框,但是,input[type="radio"] 和 input[type="checkbox"] 的默认样式在不同的浏览器或 ...

  10. python高并发和多线程的关系

    “高并发和多线程”总是被一起提起,给人感觉两者好像相等,实则 高并发 ≠ 多线程 多线程是完成任务的一种方法,高并发是系统运行的一种状态,通过多线程有助于系统承受高并发状态的实现.   高并发是一种系 ...