JAVA入门——Generic/泛型
在台科大的第二次JAVA作业,老师课上讲的内容是泛型。
泛型(generic),泛型是Java SE 1.5的新特性,泛型的本质是参数化类型,也就是说所操作的数据类型被指定为一个参数。这种参数类型可以用在类、接口和方法的创建中,分别称为泛型类、泛型接口、泛型方法。通俗点说就是一个盒子本来只能放int,改成泛型之后就可以灵活地根据你的要求放你的类型,如int,double,char,string等。下面看两个例子:
第一个例子中声明了一个Box类型,并继承了Number,也就是说Box只能用于对数的声明,如int,double,而如果改成3处的代码,则1,2处的代码可以正常运行,因为没有再继承Number,Box泛型也就包括了char,string等。
public class TestDemo2 {
public static void main(String[] args) {
//1 Box<String> name1 = new Box<String>("corn");
Box<Integer> name2 = new Box<Integer>(12);
//2 System.out.println("name:" + name1.getData());
System.out.println("name:" + name2.getData());
}
}
//3 class Box<T>{
class Box<T extends Number> {
private T data;
public Box() {
}
public Box(T data) {
this.data = data;
}
public T getData() {
return data;
}
}
运行结果:
name:12
第二个例子声明了一个Point类型,里面包含两个坐标的设置和获取。
public static void main(String[] args){
// 实例化泛型类
Point<Integer, Integer> p1 = new Point<Integer, Integer>();
p1.setX(10);
p1.setY(20);
int x = p1.getX();
int y = p1.getY();
System.out.println("This point is:" + x + ", " + y);
Point<Double, String> p2 = new Point<Double, String>();
p2.setX(25.4);
p2.setY("东京180度");
double m = p2.getX();
String n = p2.getY();
System.out.println("This point is:" + m + ", " + n);
}
}
// 定义泛型类
class Point<T1, T2>{
T1 x;
T2 y;
public T1 getX() {
return x;
}
public void setX(T1 x) {
this.x = x;
}
public T2 getY() {
return y;
}
public void setY(T2 y) {
this.y = y;
}
}
运行结果:
This point is:10, 20
This point is:25.4, 东京180度
老师布置的是编写一个插入算法的泛型类,对于数据结构非常差的我来说,简直了,不过只有慢慢查资料慢慢改。下面放作业代码。
import java.util.Comparator;
public class LinkedList<T> {
public <T extends Comparable> void sort(T x) {
Node<T> HEAD=head.next,PRE=head.next;
Node<T> newNode = new Node(x, null);
Node<T> transNode= new Node(null,null);
for(int i=0;i<count;i++){
if(i==0){
if(x.compareTo(head.data)< 0)//if x<head.data/x字典顺序小于第一个数据
{
newNode = new Node(x, head);
transNode.next=newNode;
head= transNode.next;
count++;
break;
}
HEAD=head.next;
continue;
}
if(i==1){
if(x.compareTo(HEAD.data)< 0)
{
newNode = new Node(x,HEAD);
head.next=newNode;
count++;
break;
}
else
{
HEAD=HEAD.next;
PRE=head.next;
continue;
}
}
if(i<count-1){
if(x.compareTo(HEAD.data)< 0)
{
newNode = new Node(x,HEAD);
PRE.next=newNode;
count++;
break;
}
else{
PRE=HEAD;
HEAD=HEAD.next;
}
}
if(i==count-1){
if(x.compareTo(HEAD.data)< 0)
{
newNode.next=HEAD;
PRE.next=newNode;
newNode.data=x;
count++;
break;
}
else
HEAD.next=newNode;
newNode.data=x;
newNode.next=null;
count++;
}
}
}
public static class Node<T> {
T data;
Node next;
public Node(T data, Node<T> next) {
this.data = data;
this.next = next;
}
public String toString() {
return data.toString();
}
}
static int count;
Node<T> head;
public LinkedList() {
count = 0;
head = null;
}
public boolean insert(int index, T entry) {
if (index < 0 || index > count) {
return false;
}
if (index == 0) {
Node<T> newNode = new Node(entry, head);
head = newNode;
count++;
return true;
}
Node<T> node = head;
for (int i = 0; i < index - 1; i++, node = node.next);
//System.out.println("prev "+node);
Node<T> newNode = new Node(entry, node.next);
node.next = newNode;
count++;
return true;
}
public int size() {
return count;
}
public boolean isEmpty() {
return count == 0;
}
public String toString() {
StringBuilder s = new StringBuilder();
for (Node<T> node = head; node != null; node = node.next) {
if (node != head) {
s.append(", ");
}
s.append(node.toString());
}
return s.toString();
}
public class Member {
String firstname;
String lastname;
int age;
public Member(String firstname, String lastname, int age) {
this.firstname = firstname;
this.lastname = lastname;
this.age = age;
}
public String toString() {
return firstname + " " + lastname + " age=" + age;
}
}
public static void main(String args[]) {
LinkedList<String> fruits = new LinkedList();
fruits.insert(0, "apple");
fruits.insert(1, "banana");
fruits.insert(2, "melon");
fruits.insert(3, "pear");
fruits.insert(4, "zzz");
System.out.println(fruits);
System.out.println("***********");
System.out.println("insertion sort:ccc");
fruits.sort("ccc");
System.out.println(fruits);
System.out.print("count:");
System.out.println(fruits.count);
System.out.println("------------------");
LinkedList<Integer> IntNum = new LinkedList();
IntNum.insert(0, 1);
IntNum.insert(1, 3);
IntNum.insert(2, 5);
IntNum.insert(3, 7);
IntNum.insert(4, 9);
System.out.println(IntNum);
System.out.println("***********");
System.out.println("insertion sort:4");
IntNum.sort(4);
System.out.println(IntNum);
System.out.print("count:");
System.out.println(IntNum.count);
System.out.println("------------------");
LinkedList<Double> DouNum = new LinkedList();
DouNum.insert(0, 1.1);
DouNum.insert(1, 3.3);
DouNum.insert(2, 5.1);
DouNum.insert(3, 7.1);
DouNum.insert(4, 9.1);
System.out.println(DouNum);
System.out.println("***********");
System.out.println("insertion sort:4.1");
DouNum.sort(4.1);
System.out.println(DouNum);
System.out.print("count:");
System.out.println(DouNum.count);
System.out.println("------------------");
}
}
运行结果:
apple, banana, melon, pear, zzz
***********
insertion sort:ccc
apple, banana, ccc, melon, pear, zzz
count:6
------------------
1, 3, 5, 7, 9
***********
insertion sort:4
1, 3, 4, 5, 7, 9
count:6
------------------
1.1, 3.3, 5.1, 7.1, 9.1
***********
insertion sort:4.1
1.1, 3.3, 4.1, 5.1, 7.1, 9.1
count:6
------------------
JAVA入门——Generic/泛型的更多相关文章
- Java入门系列 泛型
前言 <Java编程思想>第四版足足用了75页来讲泛型——厚厚的一沓内容,很容易让人头大——但其实根本不用这么多,只需要一句话:我是一个泛型队列,狗可以站进来,猫也可以站进来,但最好不要既 ...
- Java入门(二)——泛型
如果你写过前端,可能会经常写一下关于变量类型的判断,比如:typeof fn === 'function'之类的代码.因为JavaScript作为一门弱类型语言,类型的判断往往需要开发人员自己去检查. ...
- 【Java入门提高篇】Day14 Java中的泛型初探
泛型是一个很有意思也很重要的概念,本篇将简单介绍Java中的泛型特性,主要从以下角度讲解: 1.什么是泛型. 2.如何使用泛型. 3.泛型的好处. 1.什么是泛型? 泛型,字面意思便是参数化类型,平时 ...
- 《java入门第一季》之根据小案例体会泛型
泛型在哪些地方使用呢? * 看API,如果类,接口,抽象类后面跟的有<E>就说要使用泛型.一般来说就是在集合中使用. 下面根据案例,加深体会泛型的作用. 案例一: import java. ...
- 夯实Java基础系列13:深入理解Java中的泛型
目录 泛型概述 一个栗子 特性 泛型的使用方式 泛型类 泛型接口 泛型通配符 泛型方法 泛型方法的基本用法 类中的泛型方法 泛型方法与可变参数 静态方法与泛型 泛型方法总结 泛型上下边界 泛型常见面试 ...
- [JavaCore]JAVA中的泛型
JAVA中的泛型 [更新总结] 泛型就是定义在类里面的一个类型,这个类型在编写类的时候是不确定的,而在初始化对象时,必须确定该类型:这个类型可以在一个在里定义多个:在一旦使用某种类型,在类方法中,那么 ...
- Java 中的泛型详解-Java编程思想
Java中的泛型参考了C++的模板,Java的界限是Java泛型的局限. 2.简单泛型 促成泛型出现最引人注目的一个原因就是为了创造容器类. 首先看一个只能持有单个对象的类,这个类可以明确指定其持有的 ...
- java中的泛型(转)
什么是泛型? 泛型(Generic type 或者 generics)是对 Java 语言的类型系统的一种扩展,以支持创建可以按类型进行参数化的类.可以把类型参数看作是使用参数化类型时指定的类型的一个 ...
- 3. Java面向对象之泛型-指定多个泛型
3. Java面向对象之泛型-指定多个泛型 package generic; class MutiGeneric<K, T> { private K key; private T take ...
随机推荐
- 【原】Java学习笔记031 - 常用类
package cn.temptation; public class Sample01 { public static void main(String[] args) { /* * 类 Math: ...
- 芝麻HTTP:Python爬虫入门之正则表达式
1.了解正则表达式 正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符.及这些特定字符的组合,组成一个"规则字符串",这个"规则字符串"用来 ...
- How to verify Certificate Pinning?
Some friends of mine they worry about the risk of Man-in-the-middle so they ask me how to verify the ...
- ls -l 显示年份
默认情况下ls -l命令只显示月和日,不显示年份: $ ls -llrwxrwxrwx 1 root root 7 Feb 27 16:12 bin -> usr/bin 如要要显示年份,就要使 ...
- tablesorter 的使用
<table id="myTable" class="tablesorter"> <thead> <tr> <th&g ...
- Python基础__字典、集合、运算符
之前讨论的字符串.列表.元组都是有序对象,本节则重点讨论无序对象:字典与集合.一.字典 列表是Python中的有序集合,列表中的序指的是列表中的元素与自然数集形成了一个一一对应的关系.例如L=['I' ...
- 「拆小鹤」使用 python 实现 QQ机器人服务。
使用的是python的qqbot机器人库,我其实只是实现了这个库的一个插件. 具体的说明,我觉得qqbot的官方文档,还有我的插件的注释都写得很详细了,可以直接看.所以有空再写吧. 没错我就是懒..
- 【BZOJ2946】公共串(后缀数组)
[BZOJ2946]公共串(后缀数组) 题面 权限题... 只有CJOJ题面啦 Description 给出几个由小写字母构成的单词,求它们最长的公共子串的长度. 任务: 读入单词,计算最长公共子串的 ...
- 【BZOJ3530】数数(AC自动机,动态规划)
[BZOJ3530]数数(AC自动机,动态规划) 题面 BZOJ 题解 很套路的\(AC\)自动机+\(DP\) 首先,如果长度小于\(N\) 就不存在任何限制 直接大力\(DP\) 然后强制限制不能 ...
- C#中DateTime的缺陷与代替品DateTimeOffset
C#中的DateTime在逻辑上有个非常严重的缺陷: > var d = DateTime.Now; > var d2 = d.ToUniversalTime(); > d == d ...