Apex - 接口
什么是接口?
接口就像一个Apex类,其中没有一个方法被实现。 它只包含方法签名,但每个方法的主体是空的。 要使用接口,另一个类必须通过为接口中包含的所有方法提供一个体来实现它。
接口主要用于为代码提供抽象层。 它们将实现与方法的声明分开。
让我们举一个化学公司的例子。 假设我们需要向高级和普通客户提供折扣,两者的折扣将不同。
我们将创建一个接口,称为discountprocessor。
//Interface public interface DiscountProcessor{ Double percentageDiscountTobeApplied();//method signature only } //Premium Customer Class public class PremiumCustomer implements DiscountProcessor{ //Method Call public Double percentageDiscountTobeApplied () { //For Premium customer, discount should be 30% return 0.30; } } //Normal Customer Class public class NormalCustomer implements DiscountProcessor{ //Method Call public Double percentageDiscountTobeApplied () { //For Premium customer, discount should be 10% return 0.10; } }
当你实现接口,那么强制实现该接口的方法。 如果你不实现Interface方法,它会抛出一个错误。 当您想要让开发人员强制实施方法时,您应该使用Interfaces。
批处理的标准Salesforce接口
SFDC有标准接口,如Database.Batchable,Schedulable等。例如,如果实现Database.Batchable接口,那么必须实现接口中定义的三个方法:开始,执行和完成。
以下是标准Salesforce提供的Database.Batchable接口的示例,该接口向具有批处理状态的用户发送电子邮件。 此界面有3种方法,“开始”,“执行”和“完成”。 使用这个接口,我们可以实现Batchable功能,它提供了BatchableContext变量,我们可以使用它来获取有关正在执行的Batch的更多信息,并执行其他功能。
global class CustomerProessingBatch implements Database.Batchable<sobject>, Schedulable{ //Add here your email address global String [] email = new String[] {'test@test.com'}; //Start Method global Database.Querylocator start (Database.BatchableContext BC) { //This is the Query which will determine the scope of Records and fetching the same return Database.getQueryLocator('Select id, Name, APEX_Customer_Status__c, APEX_Customer_Decscription__c From APEX_Customer__c WHERE createdDate = today && APEX_Active__c = true'); } //Execute method global void execute (Database.BatchableContext BC, List<sobject> scope) { List<apex_customer__c> customerList = new List<apex_customer__c>(); List<apex_customer__c> updtaedCustomerList = new List<apex_customer__c>(); for (sObject objScope: scope) { //type casting from generic sOject to APEX_Customer__c APEX_Customer__c newObjScope = (APEX_Customer__c)objScope ; newObjScope.APEX_Customer_Decscription__c = 'Updated Via Batch Job'; newObjScope.APEX_Customer_Status__c = 'Processed'; //Add records to the List updtaedCustomerList.add(newObjScope); } //Check if List is empty or not if (updtaedCustomerList != null && updtaedCustomerList.size()>0) { //Update the Records Database.update(updtaedCustomerList); System.debug('List Size '+updtaedCustomerList.size()); } } //Finish Method global void finish(Database.BatchableContext BC){ Messaging.SingleEmailMessage mail = new Messaging.SingleEmailMessage(); //get the job Id AsyncApexJob a = [Select a.TotalJobItems, a.Status, a.NumberOfErrors, a.JobType, a.JobItemsProcessed, a.ExtendedStatus, a.CreatedById, a.CompletedDate From AsyncApexJob a WHERE id = :BC.getJobId()]; System.debug('$$$ Jobid is'+BC.getJobId()); //below code will send an email to User about the status mail.setToAddresses(email); //Add here your email address mail.setReplyTo('test@test.com'); mail.setSenderDisplayName('Apex Batch Processing Module'); mail.setSubject('Batch Processing '+a.Status); mail.setPlainTextBody('The Batch Apex job processed '+a.TotalJobItems+'batches with '+a.NumberOfErrors+'failures'+'Job Item processed are'+a.JobItemsProcessed); Messaging.sendEmail(new Messaging.Singleemailmessage [] {mail}); } //Scheduler Method to scedule the class global void execute(SchedulableContext sc){ CustomerProessingBatch conInstance = new CustomerProessingBatch(); database.executebatch(conInstance,100); } }
要执行这个类,你必须在开发者控制台中运行下面的代码。
CustomerProessingBatch objBatch = new CustomerProessingBatch (); Database.executeBatch(objBatch);