第2章 对象激活上下文-对象激活
对象激活主要包括
- 构造字符串
- 及时激活
- 对象池
- 私有组件
1.构造字符串
服务器苏建只能使用默认的构造函数,这样在对象创建的时候你就不能通过构造函数初始化数据.但是你可以使用构造字符串实现类似的功能,只是每次实例化的时候都只能使用相同的构造字符串.系统管理员可以改变构造字符串.(比如用到配置数据库的连接字符串).
通过[ConstructionEnabled]特性和其Default属性把默认的构造字符串添加到配置元数据中.在类内部你必须重写基类SericedComponent的Construct方法.当每次创建对象时,这种方法会被COM+基础结构调用.
2.即时激活(Just-in-Time Activation JITA)
JITA是一个用于减少服务器负载的特性.对于打开lJITA支持的组件,他的生命周期和他使用的客户端应用程序无关.这个服务器组件自己通过设置完成位来决定对象什么时候应该被终止.如果客户应用程序通过客户端的同一个引用来调用一个对象的方法,而这个对象在服务器端已经被终止的话,一个新的对象会被自动创建并激活.
JITA是通过设置[JustInTimeActiveation]来启用的.
要使用JITA,必须重写两个基类ServicedComponent的方法:Activate和Deactive.当对象生成后Activate方法会被运行时自动调用.当对象终止前Deactive方法会被自动调用.
为组件设置完成的两种方法:
- [AutoComplate]
- 设置ContextUtil的静态属性DeactivateOnReturn为True.
3.对象池
对象池对于那种初始化过程很长的对象(比如,连接到一个老系统的服务器,或创建一个复杂的矩阵以进行数学运算)是个有用的服务.如果调用方法所需要的时间少于创建所需要的时间,应该考虑对象池技术.
对象的初始化过程在客户端第一次使用它之前进行:在应用程序启动后,为对象池设定的最小的对象就会被创建和初始化.
4.私有组件
私有组件是COM+1.5带来的新特性之一.被标记为[PrivateComplent]特性的组件只能由应用程序内部的对象激活,客户端应用程序不行.
using System;
using System.EnterpriseServices;
using System.Xml;
using System.Globalization;
using System.IO;
namespace Demo.Introduction
{
[ObjectPooling(true,100,1000)]
[JustInTimeActivation]
[ConstructionEnabled(Default = @"C:Temp")]
[EventTrackingEnabled]
public class CoursesComponent : ServicedComponent, ICourseOrder
{
private string path;
public CoursesComponent() { }
protected override void Construct(string s)
{
path = s;
}
#region ICourseOrder 成员
[AutoComplete]
public void Order(string xmlOrder)
{
CreateFile();
XmlDocument doc = new XmlDocument();
doc.LoadXml(xmlOrder);
XmlNodeList courses = doc.GetElementsByTagName("Course");
foreach (XmlNode nodeCourse in courses)
{
XmlElement xmlCourse = nodeCourse as XmlElement;
if (xmlCourse != null)
{
string courseNumber = xmlCourse.GetAttribute("Number");
string title = GetText(xmlCourse, "Title")[0];
DateTime date = DateTime.Parse(GetText(xmlCourse, "StartDate")[0]);
string[] attendees = GetText(xmlCourse, "Attendee");
for (int i = 0; i < attendees.Length; i++)
{
WritToFile(courseNumber, title, date, attendees[i]);
}
}
}
CloseFile();
}
#endregion
private StreamWriter writer = null;
/// <summary>
/// Create and opens aunique file
/// </summary>
private void CreateFile()
{
string uniqueName = Guid.NewGuid().ToString();
writer = new StreamWriter(path + uniqueName + ".txt");
}
private void CloseFile()
{
writer.Close();
}
protected override void Activate()
{
CreateFile();
}
protected override void Deactivate()
{
CloseFile();
}
/// <summary>
/// Write course information to the comma-separated file
/// </summary>
/// <param name="courseNumber"></param>
/// <param name="title"></param>
/// <param name="startDate"></param>
/// <param name="attendee"></param>
private void WritToFile(string courseNumber, string title, DateTime startDate, string attendee)
{
writer.WriteLine("{0};{1};{2};{3}", courseNumber, title, startDate.ToString("d", CultureInfo.InstalledUICulture), attendee);
}
/// <summary>
/// parses the xml data of a single course for the xml element
/// tagName to return the inner text elements
/// </summary>
/// <param name="xmlCourse"></param>
/// <param name="tagName"></param>
/// <returns></returns>
private string[] GetText(XmlElement xmlCourse, string tagName)
{
string[] text = null;
XmlNodeList nodeList = xmlCourse.GetElementsByTagName(tagName);
if (nodeList.Count < 1)
throw new Exception("No elements of type <" + tagName + "> available");
//CourseException("No elements of type <" + tagName + "> available");
text = new string[nodeList.Count];
for (int i = 0; i < nodeList.Count; i++)
{
XmlElement element = nodeList[i] as XmlElement;
if (element != null)
{
text[i] = element.InnerText;
}
}
return text;
}
}
}
- 从老漏洞到新漏洞---iMessage 0day(CVE-2016-1843) 挖掘实录
- Wordpress <= 4.6.1 使用语言文件任意代码执行 漏洞分析
- 如何使用hadoop命令向CDH集群提交MapReduce作业
- Wordpress <= 4.6.1 使用主题文件触发存储型XSS 漏洞分析
- 如何跨平台在本地开发环境提交MapReduce作业到CDH集群
- 区块链行业的机会
- KEGG数据库的rest API(附带R语言小技巧)
- 如何使用Java代码访问HDFS.docx
- Django CSRF Bypass (CVE-2016-7401) 漏洞分析
- 如何使用Cloudera Manager禁用YARN的HA
- Web Worker 中的 importScripts 和 baseHref 同源策略绕过问题
- 如何使用Java代码访问CDH的Solr服务
- Safari UXSS漏洞分析(CVE-2016-4758)
- Sqoop抽取Hive Parquet表数据到MySQL异常分析
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 守护进程
- 【tensorflow2.0】自动微分机制
- Vue3.0 beta版学习笔记
- 【tensorflow2.0】低阶api--张量操作、计算图、自动微分
- mybatis之第一个mybatis程序(一)
- 进程间通信
- django-表单之创建表单(一)
- 原来sqlite3_get_table() 是这样抓取数据的!!!
- 【tensorflow2.0】中阶api--模型、损失函数、优化器、数据管道、特征列等
- 最短路径Dijkstra算法的简单实现
- django-表单之获取表单信息(二)
- 【tensorflow2.0】高阶api--主要为tf.keras.models提供的模型的类接口
- django-表单之模型表单(三)
- sqlite3数据库封装 - 动态链接库
- 【tensorflow2.0】张量的结构操作