1. import java.util.ArrayList;
  2. import java.util.Random;
  3.  
  4. public class Test {
  5. public static void main(String[] args) {
  6. // Holder.test();
  7. // TupleTest.test();
  8. // LinkedStack.test();
  9. RandomList.test();
  10. }
  11. }
  12.  
  13. /*
  14. 泛型最初的目的是希望类或方法能够具备最广泛的表达能力。如何做到这一点,正是
  15. 通过解耦类或方法与所用的类型之间的约束。但是Java中的泛型并没有这么高的追求
  16. */
  17.  
  18. /*
  19. 15.2 简单的泛型
  20. */
  21. class A{}
  22. class B{}
  23. class C{}
  24. class Holder<T> {
  25. private T a;
  26.  
  27. public Holder(T a) {
  28. this.a = a;
  29. }
  30.  
  31. public T getA() {
  32. return a;
  33. }
  34.  
  35. public void setA(T a) {
  36. this.a = a;
  37. }
  38.  
  39. public static void test() {
  40. Holder<A> h = new Holder<>(new A());
  41. A a = h.getA();
  42. }
  43. }
  44.  
  45. /*
  46. 15.2.1 一个元祖类库
  47.  
  48. 我记得STL库在实现这部分时,采用了一个很酷的写法,也是用到了继承
  49. */
  50. class TwoTuple<A, B> {
  51. public final A first;
  52. public final B second;
  53.  
  54. public TwoTuple(A first, B second) {
  55. this.first = first;
  56. this.second = second;
  57. }
  58.  
  59. public String toString() {
  60. return "(" + first + "," + second + ")";
  61. }
  62. }
  63. class ThreeTuple<A, B, C> extends TwoTuple<A, B> {
  64. public final C third;
  65.  
  66. public ThreeTuple(A first, B second, C third) {
  67. super(first, second);
  68. this.third = third;
  69. }
  70.  
  71. @Override
  72. public String toString() {
  73. return "(" + first + ", " + second + ", " + third + ")";
  74. }
  75. }
  76. class FourTuple<A,B,C,D> extends ThreeTuple{
  77. public final D fourth;
  78.  
  79. public FourTuple(Object first, Object second, Object third, D fourth) {
  80. super(first, second, third);
  81. this.fourth = fourth;
  82. }
  83.  
  84. public String toString() {
  85. return "(" + first + ", " + second + ", " + third + ", " + fourth + ")";
  86. }
  87. }
  88. class FiveTuple<A,B,C,D,E> extends FourTuple{
  89. private E fifth;
  90.  
  91. public FiveTuple(Object first, Object second, Object third, Object fourth, E fifth) {
  92. super(first, second, third, fourth);
  93. this.fifth = fifth;
  94. }
  95.  
  96. public String toString() {
  97. return "(" + first + ", " + second + ", " + third + ", " + fourth + ", " + fifth + ")";
  98. }
  99. }
  100. class TupleTest {
  101. static TwoTuple<String,Integer> f() {
  102. return new TwoTuple<>("hi", 47);
  103. }
  104.  
  105. static ThreeTuple<A,String,Integer> g() {
  106. return new ThreeTuple<>(new A(), "1234", 100);
  107. }
  108.  
  109. static FourTuple<String,String,String,String> h() {
  110. return new FourTuple<>("1","2","3","4");
  111. }
  112.  
  113. static FiveTuple<String,String,String,String,String> i(){
  114. return new FiveTuple<>("1","2","3","4","5");
  115. }
  116.  
  117. static void test(){}
  118. }
  119.  
  120. /*
  121. 15.2.2 一个堆栈类
  122. */
  123.  
  124. /*
  125. 这个用的是那种逆序的链表
  126. */
  127. class LinkedStack<T>{
  128. //这个地方用的时嵌套类
  129. private static class Node<U>{
  130. U item;
  131. Node<U> next;
  132.  
  133. Node() {
  134. item = null;
  135. next = null;
  136. }
  137.  
  138. Node(U item, Node next) {
  139. this.item=item;
  140. this.next=next;
  141. }
  142.  
  143. boolean end() {
  144. return item == null && next==null;
  145. }
  146. }
  147.  
  148. private Node<T> top = new Node<>();
  149.  
  150. public void push(T item) {
  151. top = new Node(item, top);
  152. }
  153.  
  154. public T pop(){
  155. T result = top.item;
  156. if (!top.end()) {
  157. top=top.next;
  158. }
  159. return result;
  160. }
  161.  
  162. static void test() {
  163. LinkedStack<String> lss = new LinkedStack<>();
  164. for(String s : "Phasers or stun!".split(" "))
  165. lss.push(s);
  166.  
  167. String s;
  168. while ((s = lss.pop()) != null) {
  169. System.out.println(s);
  170. }
  171. }
  172. }
  173.  
  174. /*
  175. 15.2.3 RandomList
  176. */
  177. class RandomList<T>{
  178. private ArrayList<T> storage = new ArrayList<>();
  179. private Random random = new Random(47);
  180.  
  181. public void add(T item) {
  182. storage.add(item);
  183. }
  184.  
  185. public T select() {
  186. return storage.get(random.nextInt(storage.size()));
  187. }
  188.  
  189. static void test() {
  190. RandomList<String> rs = new RandomList<>();
  191. for(String s : "a b c d e f g h i j k l m n".split(" "))
  192. rs.add(s);
  193.  
  194. for (int i = 0; i < 11; i++) {
  195. System.out.println(rs.select()+" ");
  196. }
  197. }
  198. }

Java编程思想:简单的泛型的更多相关文章

  1. Java编程思想学习(十一) 泛型

    1.概要 generics enable types (classes and interfaces) to be parameters when defining classes, interfac ...

  2. Java编程思想里的泛型实现一个堆栈类

    觉得作者写得太好了,不得不收藏一下. 对这个例子的理解: //类型参数不能用基本类型,T和U其实是同一类型. //每次放新数据都成为新的top,把原来的top往下压一级,通过指针建立链接. //末端哨 ...

  3. Java中的泛型 --- Java 编程思想

    前言 ​ 我一直都认为泛型是程序语言设计中一个非常基础,重要的概念,Java 中的泛型到底是怎么样的,为什么会有泛型,泛型怎么发展出来的.通透理解泛型是学好基础里面中非常重要的.于是,我对<Ja ...

  4. java编程思想第四版中net.mindview.util包下载,及源码简单导入使用

    在java编程思想第四版中需要使用net.mindview.util包,大家可以直接到http://www.mindviewinc.com/TIJ4/CodeInstructions.html 去下载 ...

  5. Java编程思想(11~17)

    [注:此博客旨在从<Java编程思想>这本书的目录结构上来检验自己的Java基础知识,只为笔记之用] 第十一章 持有对象 11.1 泛型和类型安全的容器>eg: List<St ...

  6. Java编程思想 (1~10)

    [注:此博客旨在从<Java编程思想>这本书的目录结构上来检验自己的Java基础知识,只为笔记之用] 第一章 对象导论 1.万物皆对象2.程序就是对象的集合3.每个对象都是由其它对象所构成 ...

  7. Java编程思想读书笔记(一)【对象导论】

    2018年1月7日15:45:58 前言 作为学习Java语言的经典之作<Java编程思想>,常常被人提起.虽然这本书出版十年有余,但是内容还是很给力的.很多人说这本书不是很适合初学者,我 ...

  8. Java编程思想(后)

    Java编程思想(后) 持有对象 如果一个程序只包含固定数量的且其生命期都是已知的对象,那么这是一个非常简单的程序. Java中的库基本类型: List, Set, Queue和Map --- 称为集 ...

  9. Java编程思想(前十章)

    Java编程思想 有C++编程基础的条件下, 前10章可以快速过一下,都是基本语法,不需要花太多时间. 着重中后段的一些章节,类型信息.泛型.容器.IO.并发等. 中文翻译版 阅读地址 对于一个架构师 ...

  10. 《Java编程思想第四版完整中文高清版.pdf》-笔记

    D.2.1 安插自己的测试代码 插入下述“显式”计时代码,对程序进行评测: long start = System.currentTimeMillis(); // 要计时的运算代码放在这儿 long ...

随机推荐

  1. ArcGIS for Desktop入门教程_第六章_用ArcMap制作地图 - ArcGIS知乎-新一代ArcGIS问答社区

    原文:ArcGIS for Desktop入门教程_第六章_用ArcMap制作地图 - ArcGIS知乎-新一代ArcGIS问答社区 1 用ArcMap制作地图 作为ArcGIS for Deskto ...

  2. android adb socket 通信

    今天遇到一个问题:pc客户端和android的App通信,心跳通道(心跳包27个字节,是一个业务空包)在部分pc上总是会超时(5秒超时),nagle算法也给禁用了,pc端时按按量发送心跳的,怀疑来怀疑 ...

  3. PostgreSQL在win7上安装详细步骤

    原文:PostgreSQL在win7上安装详细步骤 PostgreSQL安装: 一.windows下安装过程 安装介质:postgresql-9.1.3-1-windows.exe(46M),安装过程 ...

  4. MySql如何将一个表字段更新到另一个表字段

    今天遇到这样一个需求: 有两张表,一张是专辑表,另一张是专辑下的图片表, 专辑表中有拍摄年\月,两个字段; 图片表中有实际拍摄日期的字段; 因为专辑表中这两个字段是后加入的,因此只能用一条sql语句将 ...

  5. Android零基础入门第70节:ViewPager轻松完成TabHost效果

    上一期学习了ViewPager的简单使用,本期一起来学习ViewPager的更多用法. 相信很多同学都使用过今日头条APP吧,一打开主界面就可以看到顶部有很多Tab,然后通过左右滑动来切换,就可以通过 ...

  6. 判断一个窗口是否被挂起(发WM_NULL消息,或者调用IsHungAppWindow API进行测试)

    判断一个窗口是否被挂起了(就是没有响应了),在多窗口编程了经常会用到,在给别的窗口发消息前,为了目的窗口能确定收到消息,常常在之前先检测窗口是否被挂起了,我们以前常用的方式的是使用下面的方法: //  ...

  7. JavaScript规定了几种语言类型?

    JavaScript中的每一个值都有它自己的类型,JavaScript规定了七种语言类型: 1.Undefined 2.Null 3.Boolean 4.String 5.Number 6.Symbo ...

  8. C语言实现常用数据结构——堆

    #include<stdio.h> #include<stdlib.h> #define CAPACITY 20 /*堆有两个性质: * 1.结构性:堆必须是一颗完全二叉树 * ...

  9. 3011C语言_基础知识

    第一章  基础知识 1.1  基本框架 //任何一个c语言程序都必须包括以下格式: int main(int argc, char *argv[] ) { : } //这是c语言的基本结构,任何一个程 ...

  10. Django之Cookie Session详解,CBV,FBV登陆验证装饰器和自定义分页

    Cookie Session和自定义分页   cookie Cookie的由来 大家都知道HTTP协议是无状态的. 无状态的意思是每次请求都是独立的,它的执行情况和结果与前面的请求和之后的请求都无直接 ...