第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;
        }
    }
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏技术小讲堂

iBatis.Net(4):DataMapper API

在iBatis.Net中,可以通过SqlMapper实例访问DataMapper API,其实以前写的都是一些iBatis.Net的概念和一些配置的问题,从这一...

32510
来自专栏jeremy的技术点滴

JVM的Finalization Delay引起的OOM

3808
来自专栏技术博客

设计模式之四(抽象工厂模式第三回合)

抽象工厂模式:提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类。

1202
来自专栏跟着阿笨一起玩NET

C#实现文件数据库

本文转载:http://www.cnblogs.com/gaochundong/archive/2013/04/24/csharp_file_database....

2121
来自专栏大内老A

ASP.NET Core的配置(3): 将配置绑定为对象[上篇]

出于编程上的便利,我们通常不会直接利用ConfigurationBuilder创建的Configuration对象读取某个单一配置项的值,而是倾向于将一组相关的...

2086
来自专栏跟着阿笨一起玩NET

C#实现文件数据库

本文为 Dennis Gao 原创技术文章,发表于博客园博客,未经作者本人允许禁止任何形式的转载。

861
来自专栏跟着阿笨一起玩NET

C#反射读取和设置类的属性

http://www.cnblogs.com/william-lin/archive/2013/06/05/3118233.html

1681
来自专栏Kiba518

【我们一起写框架】C#的AOP框架

因为,AOP单独设计的框架几乎是无法使用的。普遍的情况是,AOP要是和其他设计模式结合在一起使用。

993
来自专栏码农分享

LinqToExcel.Extend 源码分析

展开目录结构,我们能够更加请详细的分析出每个目录所完成的功能模块。 这里主要讲解工具集中最重要的一个模块Validate

1404
来自专栏菩提树下的杨过

Flex4中使用WCF

虽然flex跟.net交互的首选是FluorineFx,但是如果在某些特定情况下(比如服务端是现成的,不允许修改,或者服务端开发方不懂FluorineFx为何物...

1959

扫码关注云+社区