新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 本版讨论.NET,C#,ASP,VB技术
    [返回] 计算机科学论坛计算机技术与应用『 Dot NET,C#,ASP,VB 』 → 多线程:从对象池(object pool)谈同步(syncronization) ——一个调试的问题 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 7242 个阅读者浏览上一篇主题  刷新本主题   平板显示贴子 浏览下一篇主题
     * 贴子主题: 多线程:从对象池(object pool)谈同步(syncronization) ——一个调试的问题 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     卷积内核 帅哥哟,离线,有人找我吗?
      
      
      威望:8
      头衔:总统
      等级:博士二年级(版主)
      文章:3942
      积分:27590
      门派:XML.ORG.CN
      注册:2004/7/21

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给卷积内核发送一个短消息 把卷积内核加入好友 查看卷积内核的个人资料 搜索卷积内核在『 Dot NET,C#,ASP,VB 』的所有贴子 访问卷积内核的主页 引用回复这个贴子 回复这个贴子 查看卷积内核的博客楼主
    发贴心情 

    作为该书中的一个完整的例子。书中提供了一个数据库连接object pool的实现。代码如下:

    using System;

    using System.Data.SqlClient;

    namespace WroxCS

    {

         public sealed class DBConnectionSingleton : ObjectPool

         {

           private DBConnectionSingleton() {}

           public static readonly DBConnectionSingleton Instance =

               new DBConnectionSingleton();

           private static string _connectionString =

               @"server=(local); Integrated Security=SSPI;database=northwind";

           public static string ConnectionString

           {

             set

             {

               _connectionString = value;

             }

             get

             {

               return _connectionString;

             }

           }

           protected override object Create()

           {

             SqlConnection temp = new SqlConnection( ConnectionString);

             temp.Open();

             return(temp);

           }

           protected override bool Validate(object o)

           {

             try

             {

               SqlConnection temp = (SqlConnection)o;

              return(

                ! ((temp.State.Equals(System.Data.ConnectionState.Closed))));

             }

             catch (SqlException)

             {

               return false;

             }

           }

           protected override void Expire(object o)

           {

             try

             {

               ((SqlConnection) o ).Close();

             }

             catch (SqlException)

             {

             }

           }

           public SqlConnection BorrowDBConnection()

           {

             try

             {

               return((SqlConnection)base.GetObjectFromPool());

             }

             catch (Exception e)

             {

               throw e;

             }

           }

           

           public void ReturnDBConnection(SqlConnection c)

           {

             base.ReturnObjectToPool(c);

           }

         }

    }
    使用这个类的方法大致如下:

    // Initialize the Pool

           DBConnectionSingleton pool;

           pool = DBConnectionSingleton.Instance;

           // Set the ConnectionString of the DatabaseConnectionPool

           DBConnectionSingleton.ConnectionString =

           "server=(local);User ID=sa;Password=;database=northwind";

           // Borrow the SqlConnection object from the pool

           SqlConnection myConnection = pool.BorrowDBConnection();

           // Return the Connection to the pool after using it

    pool.ReturnDBConnection(myConnection);
    由于下载不到源代码,我自己写了个简单的测试程序。创建一个简单窗体项目。拖了一个TextBox。想的是利用object pool中的连接来访问Nothwind并把一些数据显示到TextBox中。

    ----------------------------------------------
    事业是国家的,荣誉是单位的,成绩是领导的,工资是老婆的,财产是孩子的,错误是自己的。

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2009/9/5 9:07:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 Dot NET,C#,ASP,VB 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/9/22 18:52:18

    本主题贴数4,分页: [1]

     *树形目录 (最近20个回帖) 顶端 
    主题:  多线程:从对象池(object pool)谈同步(syncronization)&nbs..(4957字) - 卷积内核,2009年9月5日
        回复:  Hit Line Source Code 1 using System;..(4996字) - 卷积内核,2009年9月5日
        回复:  我添加的代码如下:private DBConnectionSingleton pool = D..(2384字) - 卷积内核,2009年9月5日
        回复:  作为该书中的一个完整的例子。书中提供了一个数据库连接object pool的实现。代码如下:u..(2700字) - 卷积内核,2009年9月5日

    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    62.500ms