标签:一个 tcl ada str 必须 except 实例 编译 mic
在Salesforce的世界,凡事皆Metadata。
先通过一句经常使用的代码带入一下:
Account accountItem = (Account)JSON.deserialize(accountString,Account.class);
这种代码相信大部分开发都会写过,前台将数据序列化,通过字符串的形参传递给后台,后台将数据进行反序列化,从而获取到这个表或者这个自定义类的实例。所以问题来了,为啥第二个参数是 Account.class?我们通过官方的API描述可能更好的进行了解。
这里我们引出了 Type的概念,他是apex 预定的类型,包括 基础数据类型(Integer等) , 集合, sObject类型以及 用户定义的类。基础数据类型等等都是 object类型,所以当我们理解salesforce里面的类型时,可以简单的分成两个大类:Object & sObject。所以Type概念引入完了,它用来干嘛?怎么声明?什么时候用呢?
Type t1 = Integer.class; Type t2 = Type.forName(‘Integer‘); system.debug(t1.equals(t2));
上面的简单的demo中提供了两种声明Type的方式,一种是根据 object | sObject使用 .class声明,另外一种是使用 Type的方法forName来实例化变量。既然变量可以声明出来,我们就可以看看他的方法考虑如何搞事情了。
Type的方法非常少,所以我们想要查看其对应的方法描述以及使用很容易就看完。这里针对几个重要的方法进行描述:
基础信息介绍完毕,此篇浅入浅出,介绍两种可能用到的场景。
1. JSON序列化与反序列化
这个我们经常使用,一笔带过:通过字符串以及指定的 Type类型可以转换成指定的数据类型。
Account accountItem = (Account)JSON.deserialize(accountString,Account.class);
2. 针对Custom Setting等根据配置的动态的类调用动态方法的使用
ParentClass是一个父类,有两个变量以及一个虚拟的方法,继承的子类可以进行实现
public abstract class ParentClass { public String param1 { get; set; } public String param2 { get; set; } public ParentClass() { this.param1 = ‘value1‘; this.param2 = ‘value2‘; } public virtual String joinParam() { return param1 + param2; } }
SonClass1继承了它并实现了它相关的方法
public class SonClass1 extends ParentClass { public SonClass1() { super(); this.param1 = ‘son value1‘; this.param2 = ‘son value2‘; } public override String joinParam() { return super.joinParam(); } }
还有其他的SonClassn继承了它并实现了它的相关的方法,我们在custom setting中配置了不同的场景应该调用的不同的子类,公共方法中,我们只需要使用以下的代码来判断和调用即可。
public String executeJoin(String className) { Type t = Type.forName(className); Type t2 = Type.forName(‘ParentClass‘); if(!t2.isAssignableFrom(t)) { throw new CustomException(‘should be son class of ParentClass‘); } ParentClass newObj = (ParentClass)t.newInstance(); return newObj.joinParam(); }
总结:篇中简单的介绍了salesforce中的 Type的使用,抛砖引玉,想要深入了解还要自行查看官方文档。篇中有错误的地方欢迎指出,有不懂的欢迎留言。
标签:一个 tcl ada str 必须 except 实例 编译 mic
原文地址:https://www.cnblogs.com/zero-zyq/p/13097745.html