java自定义的getInstance()返回泛型

1.背景

实际中经常使用getInstance()方法返回一个对象,对于工厂模式,传入对应的参数返回与之相对应的对象.但是,问题来了,返回的对象需要被强制转换,很麻烦.

import java.lang.reflect.*;

public class test
{
    public static void main(String[] args) {
        test1 t1 = factory.getInstance("test1");
        test2 t2 = factory.getInstance("test2");
    }
}

class factory
{
    public static Object getInstance(String className)
    {
        try
        {
            return Class.forName(className).getConstructor().newInstance();
        }
        catch(Exception e)
        {
            e.printStackTrace();
        }
        return null;
    }
}

class test1
{
    public test1()
    {
    }
}

class test2
{
    public test2()
    {
    }
}

编译不通过,说类型不兼容.

因此加上强制类型转换,编译通过了.

test1 t1 = (test1)factory.getInstance("test1");
test2 t2 = (test2)factory.getInstance("test2");

2.如何处理

例子只有两个类,手动强制转换还可以,但如果多个类咋办啊?而且作者是那种非常懒的人,也不想手动去转换,因此,用大招-----泛型!

3.使用泛型

使用Class<T> 泛型可以避免强制转换从而更有效地偷懒 ,需要把返回类型改成<T> T,同时由于使用了T,必须修改传进来的参数.

public static <T> T getInstance(Class<T> t)

4.完整代码

import java.lang.reflect.*;

public class test
{
    public static void main(String[] args) {
        test1 t1 = factory.getInstance(test1.class);
        test2 t2 = factory.getInstance(test2.class);
    }
}

class factory
{
    public static <T> T getInstance(Class<T> t)
    {
        try
        {
            return t.getConstructor().newInstance();
        }
        catch(Exception e)
        {
            e.printStackTrace();
        }
        return null;
    }
}

class test1
{
    public test1()
    {

    }
}

class test2
{
    public test2()
    {

    }
}

以下是作者的公众号,欢迎关注.

原文地址:https://www.cnblogs.com/Blueeeeeeee/p/11739167.html

时间: 2024-08-10 12:06:01

java自定义的getInstance()返回泛型的相关文章

Java编程的逻辑 (35) - 泛型 (上) - 基本概念和原理

之前章节中我们多次提到过泛型这个概念,从本节开始,我们就来详细讨论Java中的泛型,虽然泛型的基本思维和概念是比较简单的,但它有一些非常令人费解的语法.细节.以及局限性,内容比较多. 所以我们分为三节,逐步来讨论,本节我们主要来介绍泛型的基本概念和原理,下节我们重点讨论令人费解的通配符,最后一节,我们讨论一些细节和泛型的局限性. 后续章节我们会介绍各种容器类,容器类可以说是日常程序开发中天天用到的,没有容器类,难以想象能开发什么真正有用的程序.而容器类是基于泛型的,不理解泛型,我们就难以深刻理解

集合框架(ArrayList存储自定义对象并遍历泛型版)

//集合框架(ArrayList存储自定义对象并遍历泛型版) package cn.itcast_02; import java.util.ArrayList; import java.util.Iterator; /* * 需求:存储自定义对象并遍历. * * A:创建学生类 * B:创建集合对象 * C:创建元素对象 * D:把元素添加到集合 * E:遍历集合 */ public class ArrayListDemo2 { public static void main(String[]

java 一个函数EnumMap返回多个值

java 一个函数如何返回多个值 在开发过程中,经常会有这种情况,就是一个函数需要返回多个值,这是一个问题!! 网上这个问题的解决方法: 1.使用map返回值:这个方法问题是,你并不知道如何返回值的key是什么,只能通过doc或者通过源代码来查看. 2.传入一个引用进去,修改引用的属性值.问题:不实用. 3.通过泛型构造一个类似python的tuple类,或者构造一个JavaBean,其问题都是“一次性”,觉的不优雅. 个人解决方案: 使用EnumMap作为返回值类型,自己定义一个enum,将可

Java协变式覆盖(Override)和泛型重载(Overload)

Java 协变式覆盖(Override)和泛型重载(Overload) 1.协变式覆盖(Override) 在Java1.4及以前,子类方法如果要覆盖超类的某个方法,必须具有完全相同的方法签名,包括返回值也必须完全一样. Java5.0放宽了这一限制,只要子类方法与超类方法具有相同的方法签名,或者子类方法的返回值是超类方法的子类型,就可以覆盖.这样有什么好处呢?以Object类的clone方法为例: class Object {  ...  public Object clone() { ...

[转]JNI:使用RegisterNatives方法传递和使用Java自定义类

JNI:使用RegisterNatives方法传递和使用Java自定义类 2012-03-04 13:30:22|  分类: Java |  标签:jni:registernatives  |举报|字号 订阅 转载地址:http://techbook.blog.163.com/blog/static/304885102012235613945/ 除了使用传统方法实现JNI外,也可以使用RegisterNatives实现JNI.和传统方法相比,使用RegisterNatives的好处有三点:1.C

java 一个函数如何返回多个值

在开发过程中,经常会有这种情况,就是一个函数需要返回多个值,这是一个问题!! 网上这个问题的解决方法: 1.使用map返回值:这个方法问题是,你并不知道如何返回值的key是什么,只能通过doc或者通过源代码来查看. 2.传入一个引用进去,修改引用的属性值.问题:不实用. 3.通过泛型构造一个类似python的tuple类,或者构造一个JavaBean,其问题都是"一次性",觉的不优雅. 个人解决方案: 使用EnumMap作为返回值类型,自己定义一个enum,将可能返回的属性名定义为en

Java 8 新特性之泛型的类型推导

1. 泛型究竟是什么? 在讨论类型推导(type inference)之前,必须回顾一下什么是泛型(Generic).泛型是Java SE 1.5的新特性,泛型的本质是参数化类型,也就是说所操作的数据类型被指定为一个参数.通俗点将就是“类型的变量”.这种类型变量可以用在类.接口和方法的创建中.理解Java泛型最简单的方法是把它看成一种便捷语法,能节省你某些Java类型转换(casting)上的操作: List<Apple> box = new ArrayList<Apple>();

Java自定义注解反射校验数据

package com.annotations.ecargo; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; @Target(ElementType.FIELD) @Retention(RetentionPolicy.RUN

[转]使用自定义HttpMessageConverter对返回内容进行加密

今天上午技术群里的一个人问” 如何在 Spring MVC 中统一对返回的 Json 进行加密?”. 大部分人的第一反应是通过 Spring 拦截器(Interceptor)中的postHandler方法处理.实际这是行不通的,因为当程序运行到该方法,是在返回数据之后,渲染页面之前,所以这时候 Response 中的输出流已经关闭了,自然无法在对返回数据进行处理. 其实这个问题用几行代码就可以搞定,因为 Spring 提供了非常丰富的扩展支持,无论是之前提到的Interceptor和Method