JAVA泛型接口

事例代码:

 1 package com.xt.thins_15_3;
 2 
 3 import java.util.Iterator;
 4 
 5 /**
 6  * 泛型接口
 7  * 
 8  * @author xue
 9  * 
10  * @param <T>
11  */
12 interface Generic<T> {
13     public T next();
14 }
15 
16 /**
17  * 斐波纳契(一种整数数列),普通类实现
18  * 
19  * @author xue
20  * 
21  */
22 class Fibonacci implements Generic<Integer> {
23 
24     protected static int count = 0;
25 
26     @Override
27     public Integer next() {
28         // TODO Auto-generated method stub
29         return fib(count++);
30     }
31 
32     public int fib(int n) {
33         if (n < 2)
34             return 1;
35         return fib(n - 2) + fib(n - 1);
36     }
37 }
38 
39 /**
40  * 迭代适配器迭代斐波纳契(一种整数数列)
41  * 
42  * @author xue
43  * 
44  */
45 class IterableFibonacci extends Fibonacci implements Iterable<Integer> {
46 
47     private int size;
48 
49     public IterableFibonacci(int size) {
50         this.size = size;
51         count = 0;
52     }
53 
54     @Override
55     public Iterator<Integer> iterator() {
56         // TODO Auto-generated method stub
57         return new Iterator<Integer>() {
58 
59             @Override
60             public void remove() {
61                 // TODO Auto-generated method stub
62 
63             }
64 
65             @Override
66             public Integer next() {
67                 // TODO Auto-generated method stub
68                 size--;
69                 return IterableFibonacci.this.next();
70             }
71 
72             @Override
73             public boolean hasNext() {
74                 // TODO Auto-generated method stub
75                 return size > 0;
76             }
77         };
78     }
79 
80 }
81 
82 public class FibonacciTest {
83     public static void main(String[] args) {
84         Fibonacci fib = new Fibonacci();
85         for (int i = 0; i < 20; i++) {
86             System.out.print(fib.next() + ",");
87         }
88         System.out.println("\n");
89         IterableFibonacci ifib = new IterableFibonacci(20);
90         for (Integer integer : ifib) {
91             System.out.print(integer + ",");
92         }
93     }
94 }

 

更多相关文章
  • 本文作者 Jacek Laskowski 拥有近20年的应用程序开发经验,现 CodiLime 的软件开发团队 Leader,曾从 IBM 取得多种资格认证.在这篇博文中,Jacek 分享了 Warsaw Scala Enthusiasts Meetup 上 Rafal Krzewski 介绍的一个 ...
  • 前言:上一篇介绍了下多线程的相关知识:C#基础系列——多线程的常见用法详解,里面就提到了委托变量.这篇简单介绍下委托的使用.当然啦,园子里面很多介绍委托的文章都会说道:委托和事件的概念就像一道坎,过了这个槛的人,觉得真是太容易了,而没有过去的人每次见到委托和事件就觉得心里发慌.确实这东西就像最开始学 ...
  • 前言:xml的操作方式有多种,但要论使用频繁程度,博主用得最多的还是Linq to xml的方式,觉得它使用起来很方便,就用那么几个方法就能完成简单xml的读写.之前做的一个项目有一个很变态的需求:C#项目调用不知道是什么语言写的一个WebService,然后添加服务引用总是失败,通过代理的方式动态 ...
  •                                                                       LCS算法妙解 LCS问题简述:最长公共子序列 一个数列 S,如果分别是两个或多个已知数列的子序列,且是所有符合此条件序列中最长的,则S 称为已知序列的最长公共 ...
  • Common Subsequence Time Limit: 1MS   Memory Limit: 10K Total Submissions: 43194   Accepted: 17514 Description A subsequence of a given sequence is the ...
  • Docker的流行激活了一直不温不火的PaaS,随着而来的是各类Micro-PaaS的出现,Kubernetes是其中最具代表性的一员,它是Google多年大规模容器管理技术的开源版本.本系列文章将逐一分析Kubernetes,本文介绍 Kubernetes中2个主要的监控模块cAdvisor 和H ...
一周排行
  • PIX启动是考FLOOPY把IMAGE读到RAM里去的  Rebooting....  如果把里面的82559网卡拿出那么他会检测不到硬件而不段REBOOT  Cisco Secure PIX Firewall BI ...
  • 在查看执行计划或调优过程中,执行计划里面有些现象总会让人有些疑惑不解:     1:为什么同一条SQL语句有时候会走索引查找,有时候SQL脚本又不走索引查找,反而走全表扫描?     2:同一条SQL语句,查询条件的 ...
  •         对于刚入职的新员工来说,软件版本的管理常常被忽略.本文简单地介绍了软件版本的分类,并介绍了一种实用的软件版本的管理方法.        1. 软件版本的分类        在实际的软件开发项目中,一般 ...
  •         ios应用程序是一个图像主导的产品.在开发一个应用程序时,你需要各种尺寸的图标,你需要为每个图像文件制作一个@1x尺寸和一个@2x尺寸.这样你的应用看上去才足够精美.但缺点是你必须单独生成这些文件.随 ...
  • 以下是国外人写的一个C#编译器,当然由于他依然使用的.Net下的FCL,所以不可能是真正意义上的编译器, 飞刀我介绍出来,只是可以让大家摆脱csc的约束,在Win界面上完成编译. 你必须以下面的步骤完成: 1.建立一 ...
  • 又值年末,许多人又在开始为礼品的事情犯愁.一年来给予了自己大量支持与配合的合作伙伴,需要用一份小礼品来表示感谢;走亲访友时,一份合适的礼品可以更好地表达自己的心意.可是选择什么礼品却是个麻烦事,市面上常见的礼品,不是 ...
  • 使用gcc的警告信息间接知道变量的类型   #include <stdio.h> #include <stdlib.h> #include <stddef.h> #include ...
  • 1.在APPproject的新建一个Localizable.strings File->new file>Resource >strings File 2.添加需要的语言文件 如InfoPlist. ...
  • /* C,翻译自 C++ 代码 */ # include <stdio.h> # include<iostream> using namespace std; const int maxCou ...
  • 无前趋的顶点优先的拓扑排序方法     该方法的每一步总是输出当前无前趋(即人度为零)的顶点,其抽象算法可描述为:     NonPreFirstTopSort(G){//优先输出无前趋的顶点       while ...