这篇文章主要介绍Java类和成员方法的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
成都创新互联公司服务项目包括海州网站建设、海州网站制作、海州网页制作以及海州网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,海州网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到海州省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!isInstance和isAssignableFrom
obj instanceof Class
判断obj是不是Class或者Class的子类的实例
clazz.isInstance(obj)
判断obj能不能强制转换成clazz类型,亦即obj是不是clazz或者clazz的子类的实例
clazz1.isAssignableFrom(clazz2)
如果clazz2和clazz1相同,或者clazz1是clazz2的父类则返回True,否则返回Flase
static class Parent{ } static class Son extends Parent{ } public static void main(String[] args) { Parent parent=new Parent(); Son son=new Son(); Assert.assertTrue(son instanceof Son); Assert.assertTrue(son instanceof Parent); Assert.assertFalse(parent instanceof Son); Assert.assertTrue(Son.class.isInstance(son)); Assert.assertFalse(Son.class.isInstance(parent)); Assert.assertTrue(Parent.class.isInstance(son)); Assert.assertTrue(Son.class.isAssignableFrom(Son.class)); Assert.assertFalse(Son.class.isAssignableFrom(Parent.class)); Assert.assertTrue(Parent.class.isAssignableFrom(Son.class)); }
Modifier.isTransient(field.getModifiers())
在使用Java自带的方式对对象进行序列化时,transient成员变量不会被序列化,比如银行密码这样的敏感信息不允许序列化到磁盘或者在网络上传输。
import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import java.io.Serializable; public class Account implements Serializable{ private static final long serialVersionUID = 2103161633120805900L; private String name; private transient String password; public Account(String n,String p){ this.name=n; this.password=p; } @Override public String toString(){ return "["+this.name+"]\t["+this.password+"]"; } //序列化 public static byte[] serialize(Object object) { ObjectOutputStream oos = null; ByteArrayOutputStream baos = null; try { baos = new ByteArrayOutputStream(); oos = new ObjectOutputStream(baos); oos.writeObject(object); oos.close(); byte[] bytes = baos.toByteArray(); return bytes; } catch (Exception e) { e.printStackTrace(); } return null; } // 反序列化 public static Object deserialize(byte[] bytes) { ByteArrayInputStream bais = null; try { bais = new ByteArrayInputStream(bytes); ObjectInputStream ois = new ObjectInputStream(bais); Object rect=ois.readObject(); ois.close(); return rect; } catch (Exception e) { e.printStackTrace(); } return null; } public static void main(String[] args) throws IOException { Account inst=new Account("orisun","123456"); System.out.println("序列化前"+inst); byte[] datas=serialize(inst); Account inst2=(Account)deserialize(datas); System.out.println("序列化后"+inst2); } }
以上是“Java类和成员方法的示例分析”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!
售后响应及时
7×24小时客服热线数据备份
更安全、更高效、更稳定价格公道精准
项目经理精准报价不弄虚作假合作无风险
重合同讲信誉,无效全额退款