params 和= null有什么区别吗

-一个大坑 2019-09-07 09:27:11
都是表示可以有0个或1个参数
public static bool QueryExist(string strSQL, params List<OracleParameter> commandParameters)
public static bool QueryExist(string strSQL, List<OracleParameter> commandParameters = null)
...全文
315 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
引用 9 楼 -一个大坑 的回复:
[quote=引用 7 楼 不胖到130不改名字 的回复:] 你想想类似string.format那种情况 是不是还是params比较方便
不是很懂,举个例子吧 碰到这种params OracleParameter[] commandParameters要怎么办?
for(int i=0;i<dt.Rows.count;i++){
list.Add(new OracleParameter(":lmtd_name"+i,dt.Rows[0]["lmtd_name"]));
}
[/quote] 这种情况就传这个list 也就是你开头说的第二种用法
github_36000833 2019-09-08
  • 打赏
  • 举报
回复
引用 5 楼 -一个大坑 的回复:
... 我就是觉得 OracleParameter[]不好添加OracleParameter,才写的List<OracleParameter>
作为开发者,当然可以决定哪种方便写哪个。甚至两个都写也可以。
public static bool QueryExist(string strSQL, params OracleParameter[] commandParameters)
{
   // ... 具体逻辑
}

public static bool QueryExist(string strSQL, List<OracleParameter> commandParameters = null)
{
    // 调用params OracleParameter[] 版本
    return QueryExist(strSQL, commandParameters == null ? new OracleParameter[0] : commandParameters.ToArray();
}
threenewbee 2019-09-07
  • 打赏
  • 举报
回复
params本质上传入一个数组
默认参数,则通过给参数attribute实现,编译器会根据此,在编译的时候传入默认值
Hello World, 2019-09-07
  • 打赏
  • 举报
回复
当然,可选参数也是放在必需参数的后面,像(string a="", string b)就不可以,因为b是必需的,而a是可选的,但(string a,string b="",string c="",List<string> d=null)则可以
Hello World, 2019-09-07
  • 打赏
  • 举报
回复
首先你的写法不正确,第一个要像1#那样才行,不能用List

其次params必须是形参表中的最后一个,但默认值为null或其他值的可选参数可以有不止一个

params的参数是数组类型的,可选参数另外的写法则更加灵活
github_36000833 2019-09-07
  • 打赏
  • 举报
回复
public static bool QueryExist(string strSQL, params OracleParameter[] commandParameters) 这是可变参数,params参数类型必须是一维数组,每个方法最多只能有一个可变参数。 调用例子: QueryExist("select ...", p1, p2, p3); public static bool QueryExist(string strSQL, List<OracleParameter> commandParameters = null) 这是可选实参,每个方法可以有多个可选实参。 QueryExist("select ...", new List<OracleParameter>(){p1, p2, p3});
-一个大坑 2019-09-07
  • 打赏
  • 举报
回复
引用 7 楼 不胖到130不改名字 的回复:
你想想类似string.format那种情况 是不是还是params比较方便
不是很懂,举个例子吧 碰到这种params OracleParameter[] commandParameters要怎么办?
for(int i=0;i<dt.Rows.count;i++){
list.Add(new OracleParameter(":lmtd_name"+i,dt.Rows[0]["lmtd_name"]));
}
-一个大坑 2019-09-07
  • 打赏
  • 举报
回复
不是很懂,举个例子吧 碰到这种params OracleParameter[] commandParameters要怎么办?
for(int i=0;i<dt.Rows.count;i++){
list.Add(new OracleParameter(":lmtd_name"+i,dt.Rows[0]["lmtd_name"]));
}
  • 打赏
  • 举报
回复
引用 6 楼 -一个大坑 的回复:
[quote=引用 4 楼 不胖到130不改名字 的回复:] params 和 直接 list 参数 对比的话, 效果其实没啥区别 应该就是params用起来比较方便吧 传参直接逗号分隔,不用再另外定义一个list
多个参数感觉不用list也不好办,总不能建多个OracleParameter,然后再传到方法 用OracleParameter[] param=new OracleParameter[]{xxxx}; 后面再增加参数不好增加[/quote] 你想想类似string.format那种情况 是不是还是params比较方便
-一个大坑 2019-09-07
  • 打赏
  • 举报
回复
引用 4 楼 不胖到130不改名字 的回复:
params 和 直接 list 参数 对比的话, 效果其实没啥区别 应该就是params用起来比较方便吧 传参直接逗号分隔,不用再另外定义一个list
多个参数感觉不用list也不好办,总不能建多个OracleParameter,然后再传到方法 用OracleParameter[] param=new OracleParameter[]{xxxx}; 后面再增加参数不好增加
-一个大坑 2019-09-07
  • 打赏
  • 举报
回复
引用 1 楼 github_36000833 的回复:
public static bool QueryExist(string strSQL, params OracleParameter[] commandParameters) 这是可变参数,params参数类型必须是一维数组,每个方法最多只能有一个可变参数。 调用例子: QueryExist("select ...", p1, p2, p3); public static bool QueryExist(string strSQL, List<OracleParameter> commandParameters = null) 这是可选实参,每个方法可以有多个可选实参。 QueryExist("select ...", new List<OracleParameter>(){p1, p2, p3});
也就是说用 params OracleParameter[] commandParameters后可以传多个 new OracleParameter, 我就是觉得 OracleParameter[]不好添加OracleParameter,才写的List<OracleParameter>
  • 打赏
  • 举报
回复
params 和 直接 list 参数 对比的话, 效果其实没啥区别 应该就是params用起来比较方便吧 传参直接逗号分隔,不用再另外定义一个list

62,041

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

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