菜鸟问一个简单的C# 函数问题

yxdkenshin 2010-07-14 09:51:10
经常看网上的一些.NET开源代码,发现数据层类里面一般有这样的方法。
比如:
/// <summary>
/// 执行SQL语句,返回影响的记录数
/// </summary>
/// <param name="SQLString">SQL语句</param>
/// <returns>影响的记录数</returns>
public static int ExecuteSql(string SQLString, params SqlParameter[] cmdParms)
{
using (SqlConnection connection = new SqlConnection(connectionString))
{
using (SqlCommand cmd = new SqlCommand())
{
try
{
PrepareCommand(cmd, connection, null, SQLString, cmdParms); //这里调用了另外一个方法
int rows = cmd.ExecuteNonQuery(); //为什么这里的CMD对象能执行?
cmd.Parameters.Clear();
return rows;
}
catch (System.Data.SqlClient.SqlException E)
{
throw new Exception(E.Message);
}
}
}
}

这个方法是执行SQL语句,在方法里面又调用了PrepareCommand 这个方法:

private static void PrepareCommand(SqlCommand cmd, SqlConnection conn, SqlTransaction trans, string cmdText, SqlParameter[] cmdParms)
{
if (conn.State != ConnectionState.Open)
conn.Open();
cmd.Connection = conn;
cmd.CommandText = cmdText;
if (trans != null)
cmd.Transaction = trans;
cmd.CommandType = CommandType.Text;//cmdType;
if (cmdParms != null)
{
foreach (SqlParameter parm in cmdParms)
cmd.Parameters.Add(parm);
}
}

现在问题来了,注意看这2段
PrepareCommand(cmd, connection, null, SQLString, cmdParms); //这里调用了另外一个函数
int rows = cmd.ExecuteNonQuery(); //为什么这里的CMD对象能执行?

CMD对象是在第一个方法里面创建的,但是在这个方法里面调用了另外一个方法以后,CMD对象就有参数可以执行了,这是为什么呢? 又没有用OUT或者REF引用,怎么能把PrepareCommand方法里面的CMD等同于ExecuteSql方法里面的CMD对象呢?而且PrepareCommand方法又没有返回值?
...全文
107 11 打赏 收藏 转发到动态 举报
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
z2362990 2010-07-15
  • 打赏
  • 举报
回复
问题在于值类型与引用类型的区别。
SqlCommand是引用类型,传递的是地址,只要不在方法里改变引用的指向,不加ref也可。
winbq5 2010-07-15
  • 打赏
  • 举报
回复
SqlCommand cmd 是引用类型,传递的是地址

就是这个原因
Zhanlixin 2010-07-15
  • 打赏
  • 举报
回复
SqlCommand cmd 是引用类型,传递的是地址
wantalcs 2010-07-15
  • 打赏
  • 举报
回复
cmd是引用类型,只要不在方法里改变引用的指向,不加ref也可。
yxdkenshin 2010-07-14
  • 打赏
  • 举报
回复
好像有点弄清楚了,第2个方法,是把对象的地址传进去了,所以方法里面的操作,直接影响到了对象本身,不知道这样理解对不对?
yxdkenshin 2010-07-14
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 skydemo 的回复:]
那2个cmd又不是同一个 ,肯定能执行啊 第2个方法就是用事务执行多条sql语句
其实就相当于 一个执行语句而已!!
[/Quote]

大哥,看清楚点,第2个方法,只是给CMD对象附上了参数,真正执行还是在第一个方法的CMD
vip__888 2010-07-14
  • 打赏
  • 举报
回复
看看值类型和引用类型
一切为了你 2010-07-14
  • 打赏
  • 举报
回复
ref 是值传递
一切为了你 2010-07-14
  • 打赏
  • 举报
回复
那2个cmd又不是同一个 ,肯定能执行啊 第2个方法就是用事务执行多条sql语句
其实就相当于 一个执行语句而已!!
yxdkenshin 2010-07-14
  • 打赏
  • 举报
回复
那什么情况下,对象的地址会变呢?因为以前看C#书的时候,说进入函数以后所作的操作不影响函数外部定义的变量,除非用REF把地址传进去。那为什么这里没有用REF,函数内部的操作还是会影响到外部的对象呢?
bancxc 2010-07-14
  • 打赏
  • 举报
回复
对象所在的地址没有变 直接在托管堆上操作 所以会影响结果
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用欢迎随时与博主沟通,第一时间进行解答!

110,536

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧