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 ...
随机推荐
- 芝麻HTTP:Python爬虫入门之Urllib库的基本使用
1.分分钟扒一个网页下来 怎样扒网页呢?其实就是根据URL来获取它的网页信息,虽然我们在浏览器中看到的是一幅幅优美的画面,但是其实是由浏览器解释才呈现出来的,实质它是一段HTML代码,加 JS.CSS ...
- 微信小程序滚动动画,点击事件及评分星星制作!
前言 小程序上线刷爆了朋友圈,但是最近渐渐消沉了,很少有动静!最近公司项目需要,体验了一下微信小程序,制作了几个功能,布局感觉很简单,但是交互和动画等写起来确实很费劲,主要是因为他不能操作DOM,只能 ...
- webpack学习(二):先写几个webpack基础demo
一.先写一个简单demo1 1-1安装好webpack后创建这样一个目录: 1-2:向src各文件和dist/index.html文件写入内容: <!DOCTYPE html> <h ...
- WebView的使用--Hybrid App
App页面是运行在WebView中的,一个App页面对应一个WebView,本例实现两个WebView之间的跳转. 实现过程(用到了MUI框架): 1.页面标识+跳转按钮(index.html.mai ...
- ProgressBar、ProgessDialog用法解析
一.ProgressBar 1. 常用类型 1.1 不确定式圆形进度条 style="@android:style/Widget.Holo.Light.ProgressBar" s ...
- PyCharm的注册码获取
1.在server选项里边输入 http://elporfirio.com:1017/就可以了. 2.server选项里边输入 http://idea.imsxm.com/ 3.server选项里边 ...
- sql注入之一次艰难的绕过-三层防护(oracle)
打开:www.xxxx.com/news/detail.jsp?id=2862 我们经过测试知道此处含有sql注入.我们尝试下: http://www.xxxxxx.com/news/detail.j ...
- C# Redis实战(七)
七.修改数据 在上一篇 C# Redis实战(六)中介绍了如何查询Redis中数据,本篇将介绍如何修改Redis中相关数据.大家都知道Redis是key-value型存储系统,所以应该可以修改key, ...
- ngrx/store effects 使用总结1:计数器
本教程案例github:https://github.com/axel10/ngrx_demo-counter-and-list angular2+ 的学习成本应该是三大框架中最高的一个,教程及案例稀 ...
- hadoop2.x源码编译
转载请标明出处: http://blog.csdn.net/zwto1/article/details/50733753: 介绍 本篇主要会涉及以下内容: 学会编译hadoop2.x源码 编译hado ...