书接上文,

把代码改为多线程,

public class Threads

   {

 

       public static void allStart()

       {

           for (int i = 0; i < 10; i++)

           {

               t1();

           }

       }

 

 

       public static void t1()

       {

           var t = new Thread(() =>

           {

               Class1.Test();

           });

           t.IsBackground = true;

           t.Start();

       }

 

 

   }

 

内在状况:

看了一下,CPU相当的同,但是内存已经没问题了。

现在从读的情况来看没什么问题。

 

把代码再改改。

public class Class1

   {

       private static Domain.Entities.Models.passportContext context;

       static Class1()

       {

           context =

               new Domain.Entities.Models.passportContext("passportContext");

 

           context.Configuration.ProxyCreationEnabled = false;

           context.Configuration.LazyLoadingEnabled = false;

 

           var om = ((IObjectContextAdapter)context).ObjectContext.ObjectStateManager;

 

           om.ObjectStateManagerChanged += om_ObjectStateManagerChanged;

       }

       public static void Test()

       {

           var start = int.MaxValue;

 

           while (true)

           {

               var list = context.UserSources.OrderByDescending(x => x.UserId).Where(x => x.UserId < start).Take(100).ToList();

 

               ObjectContext oc = ((IObjectContextAdapter)context).ObjectContext;

 

               var m = oc.ObjectStateManager;

               var a = list.First();

 

               var count = GetUnchangedCount(context);

 

               ClearUnchangedCache(context);

               ClearKeylessEntityCache(context);

 

               count = GetUnchangedCount(context);

 

 

 

               Console.WriteLine(string.Format("[{0}]", Thread.CurrentThread.ManagedThreadId) + a.UserId);

 

 

               //context.SaveChanges();

 

               //ClearCache(context);

               start = a.UserId;

           }

 

       }

 

然后这样就,呵呵了。

 

是的,对于多线程下,不能使用共享的Context。

下面也给出了解决方法。

http://stackoverflow.com/questions/9415955/c-sharp-working-with-entity-framework-in-a-multi-threaded-server

 

看完这个以后,我顿时明白了。

我的错误在于,为了所谓的性能考虑。

使用了

public abstract class StatBase<TSource, TStat>

      where TSource : class

      where TStat : class

  {

      protected readonly GenericRepository<TSource> Sourcelog;

      protected readonly GenericRepository<TStat> Stat;

      protected readonly SingleFileLine Sfl;

      private int sleep = 45;

 

 

      public event EventHandler<InfoEventArgs> StateInfo;

 

      protected virtual void OnStateInfo(InfoEventArgs e)

      {

          EventHandler<InfoEventArgs> handler = this.StateInfo;

          if (handler != null) handler(this, e);

      }

 

      protected virtual void OnState(InfoEventArgs e)

      {

          EventHandler<InfoEventArgs> handler = this.StateInfo;

          if (handler != null) handler(this, e);

      }

      protected virtual void OnState(string info)

      {

          EventHandler<InfoEventArgs> handler = this.StateInfo;

          if (handler != null) handler(this, new InfoEventArgs

                                             {

                                                 Info = info,

                                                 Time = System.DateTime.Now

                                             });

      }

      protected StatBase()

      {

          this.Sourcelog = new GenericRepository<TSource>(AppIniter.DefaultConnection);

          this.Stat = new GenericRepository<TStat>(AppIniter.DefaultConnection);

          this.Sfl = new SingleFileLine(typeof(TStat).Name);

      }

在构造中对Responstory进行实例化,然后再多线程中使用,所以就出现了上个文章中的问题。内存不断的增长。

 

那这样,改下程序,把实例化的过程放到线程中,每次使用实例化一个对象,然后超出作用域后就自动释放。

这是一个好的想法,但不帅了,不过,可以试试的。

代码就变成 了这样。

public abstract class StatBase<TSource, TStat>

      where TSource : class

      where TStat : class

  {

      protected GenericRepository<TSource> Sourcelog

      {

          get

          {

              return new GenericRepository<TSource>(AppIniter.DefaultConnection);

          }

      }

 

      protected GenericRepository<TStat> Stat

      {

          get

          {

              return new GenericRepository<TStat>(AppIniter.DefaultConnection);

          }

      }

 

但是处理速度上明显就下去了。

 

 

*》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》

 

其实整体上没有解决,没有按上面的路走下去,直接使用的就是 using(context)

对于自我管理 ObjectContextManager的测试的更多相关文章

  1. MagicNotes:自我管理中的破窗效应

    MagicNotes,思绪随风飞扬,偶尔在这里停留. 在<程序员修炼之道——从小工到专家>这本书里,有这么一段描述: 在市区,有些建筑漂亮而整洁,而另一些却是破败不堪的“废弃船只”.为什么 ...

  2. 精力管理 | 迅速恢复精力的N个技巧,四个关键词以及自我管理的方法和工具列表

    精力管理 | 迅速恢复精力的N个技巧,所谓坚持,是坚定的“持有”,这个“持”字很值得琢磨——不是扛.不是顶,而是“持”这样一个半放松的状态.如果你没做好自己该做的事情,如果你自己没有成长起来,随着年龄 ...

  3. 【纯手工】整理豆瓣热点推荐列表-财经&自我管理

    [纯手工]整理豆瓣热点推荐列表-财经&自我管理  简七君 2013-10-27 09:40:06     豆瓣君的首页热点推荐实在难以捉摸,只有正好跳出推荐贴时才能按图索骥找列表.简七和小伙伴 ...

  4. [Azure DevOps] 管理测试计划、测试套件和测试用例

    我喜欢测试计划,它能让团队清楚测试进度,还能妥善分配测试人员,更重要的是它能保证测试质量和效率.Azure DevOps 里提供了 Test Plans 这个模块用于管理测试计划. 1. Azure ...

  5. 【ELK】Centos7 安装 ELK 7.6.2 和 UI 管理界面以及测试例子

    1. 初始化环境 1.0 初始化环境官网参考 https://www.elastic.co/guide/en/elasticsearch/reference/current/system-config ...

  6. 测试管理_出色测试管理者的思考[持续更新ing]

    如何合理安排并按质按量按时完成每一个测试任务,做好项目管理? 如何把控到每一个测试任务的质量? 如何快速构建和构建好测试环境? 如何获取或快速制作测试数据? 如何确保每一个测试人员的工作都饱满? 如何 ...

  7. 高并发秒杀系统--Service事务管理与继承测试

    [Spring IoC的类型及应用场景]  [Spring事务使用方式] [Spring事务的特性] [Spring事务回滚的理解] [Service声明式事务的配置] 1.配置事务管理器 2.配置基 ...

  8. kubernetes容器集群管理启动一个测试示例

    创建nginx 创建3个nginx副本 [root@master bin]# kubectl run nginx --image=nginx --replicas=3 kubectl run --ge ...

  9. Oracle管理监控之测试环境清理用户脚本

    --PL/SQL块删除用户 declare  cursor cur_duser is    select sid, serial# from v$session where username in ( ...

随机推荐

  1. 前端工作准备-foxmail登陆失败汇总

    foxmail 管理邮箱账号的一个工具软件, 但是在登陆的时候总是遇到明明账号密码没有问题,却总是报错,这里我登陆的时候的集中解决方法总结下: pop和imap 是邮箱的两种协议,大多选imap协议, ...

  2. vmware 仅主机模式 ip配置

    首先关闭防火墙 主机(宿主机器 win7) 虚拟机(xp) 3..重要提示:  如果ping不通首先考虑防火墙的问题!!! vmware配置: nat模式下玩耍: 1. 配置nat的虚拟网卡:  2. ...

  3. Oracle 环境下 GoldenGate 集成抽取(Integrated Capture)模式与传统抽取模式(Classic Capture)间的切换

    检查抽取进程模式 在 GGSCI 环境下,执行类似如下语句查看特定进程的状态. GGSCI> info <Group_Name> 其中,<Group_Name> 为进程名 ...

  4. java中链表的数据(对象)位置交换

    用LinkedList类的set方法把引用 对象换了就行 ,如 import java.util.LinkedList; public class Tffdsafsdafsad { public st ...

  5. PHP Curl请求Https接口

    在请求http的时候只需要 file_get_contents("http://www.sojson.com/open/api/weather/json.shtml?city=$Positi ...

  6. 7. Reverse Integer 反转整数

    [抄题]: 将一个整数中的数字进行颠倒,当颠倒后的整数溢出时,返回 0 (标记为 32 位整数).   样例 给定 x = 123,返回 321 给定 x = -123,返回 -321 [暴力解法]: ...

  7. 12.Alias(别名)

    通过使用 SQL,可以为列名称和表名称指定别名(Alias). SQL Alias 表的 SQL Alias 语法 SELECT column_name(s) FROM table_name AS a ...

  8. ParameterizedType的作用

    public interface ParameterizedType  extends Type subParam.Java package com.example.test; public clas ...

  9. web开发四个作用域

    web开发一共有四个作用域,范围从高到低分为appliaction作用域(全局作用域),session作用域,request作用域和page作用域.${base}是el表达式语法,它会自动先从page ...

  10. Delphi xe7 up1 调用android振动功能

    Delphi xe7 up1 调用android振动功能 振动用到以下4个单元: Androidapi.JNI.App,Androidapi.JNIBridge,Androidapi.JNI.Os,A ...