const 引起的BUG

今天白天出现了碰见了一个问题,隐藏得比较深,这里记录一下。

初衷很简单,就是要更改改一个数据库的链接名,这个链接名是放在数据层public const string connDB="connDBValue",也就是DataAccess项目下面,然后我Servcie层项目也用到这个链接名使,string db=DataBaseFactory.GetDatabase(DbHelper.connDB);现在我把这个变量名的值给更改了,因为只更改了数据层 然后编译数据层dll,自测总是提示没有找对对应的链接名,然后直接编译解决方案,ok,没问题。然后因为我只动了数据层就只把数据层这个dll传到线上,然后运行,黄页,百思不得其解。然后突然想到const修饰的是静态常量也就是说在编译之后就确定下来了,也就是说线上的service dll用到的db变量还是我修改之前的那个值,那么我把本地编译之后的service dll也传到线上就行了,果然就OK了。

现在来分析下这里出现的问题。

问题就是出现在const修饰符上,const修饰的connDB为静态常量,代码中用到了这个变量的地方编译之后都会替换成表示的值 connDBValue

直接看代码,为了看区别添加了readonly 和不加修饰符做对比:

DataAccess层声明变量DBBlog

namespace Simple.DataAccess
{
   public class DbHepler
   {
       public const string constDB = "connDBValue";
       public static readonly string readonlyDB = "connDBValue";
   }
}

  

 service层调用DbHepler.DBBlog变量

namespace Simple.Service
{
    public class Example
    {
        public void GetInfo()
        {
            int constL = DbHepler.constDB.Length;
            int readonlyL = DbHepler.readonlyDB.Length;
        }
    }
}

 反编译看源代码

namespace Simple.Service
{
	public class Example
	{
		public void GetInfo()
		{
			int length = "connDBValue".Length;
			int length2 = DbHepler.readonlyDB.Length;
		}
	}
}

 这里可以看到const修饰的constDB变量编译之后已经被替换成了原来定义的值,而readonlyDB没有变化,readonlyDB会在代码执行到这里来的时候才会把值替换。

回到最上面的出现的问题,我修改了DataAccess层的变量值,但是并没有重新编译Service层 ,那么Servce层用到的值还是原始的值,所以就导致出了问题。 

 

原文地址:https://www.cnblogs.com/minesnil-forfaith/p/4612024.html