有时希望函数中的局部变量的值在函数调用结束后不消失而保留原值,这时就应该指定局部变量为“静态局部变量”,用关键字static进行声明。
【例8.15】考察静态局部变量的值。
f(int a)
{auto b=0
static c=3
b=b+1
c=c+1
return(a+b+c)
}
main()
{int a=2,i
for(i=0i<3i++)
printf("%d",f(a))
}
对静态局部变量的说明:
1) 静态局部变量属于静态存储类别,在静态存储区内分配存储单元。在程序整个运行期间都不释放。而自动变量(即动态局部变量)属于动态存储类别,占动态存储空间,函数调用结束后即释放。
2) 静态局部变量在编译时赋初值,即只赋初值一次;而对自动变量赋初值是在函数调用时进行,每调用一次函数重新给一次初值,相当于执行一次赋值语句。
3) 如果在定义局部变量时不赋初值的话,则对静态局部变量来说,编译时自动赋初值0(对数值型变量)或空字符(对字符变量)。而对自动变量来说,如果不赋初值则它的值是一个不确定的值。
【例8.16】打印1到5的阶乘值。
1)由以往的经验:在ADO.NET中,要 *** 作多个数据库,那就多写两个SqlHelper吧,或封装下,能动态的修改链接字符串。因此想到在这里能不能建多个ADO.NET实体数据模型呢?于是乎就有了这样两个文件:SealDBModel.edmx及UcmsDBModel.edmx。2)SealDBModel是主要的,因此在Server中对其处理,作了继承。也同时使用了UcmsDBModel。
3)这段代码是有问题的,当要同时 *** 作不同数据库,且有数据有效性的时候,就会发现前面的一个成功了,后面的一个失败了。怎么办呢?EF的事务机制显然已经满足不了程序的要求了,怎么办呢?加TransactionScope吧。
4)于是乎就有了这样一段代码:
namespace Seal_Services
{
public class seal_testServer : BaseServer<seal_test>, Iseal_usersServer
{
public void TTTT()
{
using (TransactionScope scope = new TransactionScope())
{
try
{
seal_test test = new seal_test()
{
name = "1111",
age = 1
}
base.AddEntity(test)
base.db.SaveChanges()
BaseUCMSServer<au_Role>ucmsserver = new BaseUCMSServer<au_Role>()
au_Role role = new au_Role()
role = ucmsserver.FindEntitie(c =>c.id == 7)
role.role_name = "BBBBBBBBBBB"
ucmsserver.UpdateEntity(role)
ucmsserver.db.SaveChangesForUCMS()
scope.Complete()
}
catch (System.Exception ex)
{
throw ex
}
}
}
}
}
5)可还是有问题呀,在处理第二个Server时会抛出异常“ 基础提供程序在 Open 上失败 ”。然而可以肯定的是,数据库链接字符串是正确的。可却报错了,这是为什么呢?【这是我电脑环境上的一个坑】
6)经过分析(翻了无数百度相同的转贴后...),想到了,会不会有SQL配置相关?导致了TransactionScope的使用失败?
7)打开 Sql Server Configuration Manager时,我看到SQL Server服务,显示的是:远程过程调用失败。这个???既然失败,那就让它正确。于是:打开 控制面板-卸载 找到 Express LocalDB。坚定的将其【卸载】。返回程序中,再执行。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)