- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
首先,介绍一下背景。阅读问题并接受答案 posted here对于我的问题的特定场景。我不确定是否存在其他类似案例,但这是我所知道的唯一案例。
上面的“怪癖”是我早就知道的事情。直到最近,我才明白其中的全部原因。
Microsoft 关于 SqlParameter
类的文档更清楚地说明了这种情况。
When you specify an
Object
in the value parameter, theSqlDbType
is inferred from the Microsoft .NET Framework type of the Object.Use caution when you use this overload of the
SqlParameter
constructor to specify integer parameter values. Because this overload takes a value of typeObject
, you must convert the integral value to anObject
type when the value is zero, as the following C# example demonstrates.
Parameter = new SqlParameter("@pname", Convert.ToInt32(0));
If you do not perform this conversion, the compiler assumes that you are trying to call the SqlParameter (string, SqlDbType) constructor overload.
(强调)
我的问题是,为什么编译器假设当您指定一个硬编码的“0”(并且只有值“0”)时,您正在尝试指定一个枚举类型,而不是一个整数类型?在这种情况下,它假定您声明的是 SqlDbType
值,而不是值 0。
这是不直观的,更糟糕的是,错误是不一致的。我有我编写的旧应用程序,多年来一直调用存储过程。我将更改应用程序(通常甚至不与我的 SQL Server 类相关联),发布更新,这个问题会突然破坏应用程序。
当包含多个方法签名的对象包含两个相似的签名,其中一个参数是对象/整数,另一个接受枚举时,为什么编译器会被值 0 混淆?
正如我所提到的,我从未将此视为任何其他类上的任何其他构造函数或方法的问题。这是 SqlParameter
类所特有的,还是 C#/.Net 中继承的错误?
最佳答案
这是因为零整数可以隐式转换为枚举:
enum SqlDbType
{
Zero = 0,
One = 1
}
class TestClass
{
public TestClass(string s, object o)
{ System.Console.WriteLine("{0} => TestClass(object)", s); }
public TestClass(string s, SqlDbType e)
{ System.Console.WriteLine("{0} => TestClass(Enum SqlDbType)", s); }
}
// This is perfectly valid:
SqlDbType valid = 0;
// Whilst this is not:
SqlDbType ohNoYouDont = 1;
var a1 = new TestClass("0", 0);
// 0 => TestClass(Enum SqlDbType)
var a2 = new TestClass("1", 1);
// => 1 => TestClass(object)
(改编自Visual C# 2008 Breaking Changes - change 12)
当编译器执行重载决议时 0 是一个 Applicable function member对于 SqlDbType
和 object
构造函数,因为:
an implicit conversion (Section 6.1) exists from the type of the argument to the type of the corresponding parameter
(SqlDbType x = 0
和 object x = 0
都有效)
SqlDbType
参数优于 object
参数,因为 better conversion rules :
T1
和 T2
是同一类型,则两种转换都不是更好。
object
和 SqlDbType
不是同一类型S
是 T1
,则 C1
是更好的转换。
0
不是对象
S
是 T2
,则 C2
是更好的转换。
0
不是 SqlDbType
T1
到T2
的隐式转换,并且不存在从T2
到T1
的隐式转换, C1
是更好的转换。
object
到SqlDbType
的隐式转换T2
到T1
的隐式转换,并且不存在从T1
到T2
的隐式转换, C2
是更好的转换。
SqlDbType
到 object
的隐式转换,因此 SqlDbType
是更好的转换请注意,在 Visual C# 2008 中确切地构成常量 0 的内容已经(非常微妙地)发生了变化(微软对 C# 规范的实现)@Eric 在他的回答中解释道。
关于c# - 编译器值类型解析和硬编码 "0"整数值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14224465/
我正在尝试学习 Fortran,并且看到了很多不同的定义,我想知道他们是否正在尝试完成同样的事情。以下有什么区别? 整数*4 整数(4) 整数(kind=4) 最佳答案 在 Fortran >=90
我以前从未编程过,最近(1 周前)才开始学习!第一门类(class)是函数式编程,使用 Haskell。 我有一项学校作业,我想通过删除一两个步骤来改进它,但我遇到了一个讨厌的错误。 基本上,我创建了
给定以下GraphQL请求和变量: 请求: query accounts($filter:AccountFilter, $first_:String, $skip_:Int) { accounts
我已经搜索了 StackOverflow,但找不到关于如何检查计算器应用程序的数字输入正则表达式的答案,该计算器应用程序将检查每个 keyup 的以下格式(jquery key up): 任何整数,例
类似于我上一篇致歉的文章,但没有那么长篇大论。基本上我想知道当每次重绘调用只重绘屏幕的一小部分时,优化重绘到 JFrame/JPanel 的最佳选择是什么。 此外,除了重绘重载之外,我并不是 100%
所以在我的教科书中有一个使用 f# 的递归函数的例子 let rec gcd = function | (0,n) -> n | (m,n) -> gcd(n % m,m);; 使用此功能,我的教科书
我有一个数据结构,例如表达式树或图形。我想添加一些“测量”功能,例如depth和 size . 如何最好地键入这些函数? 我认为以下三个变体的用处大致相同: depth :: Expr -> Int
这样写比较好 int primitive1 = 3, primitive2 = 4; Integer a = new Integer(primitive1); Integer b = new Inte
我是 Java 8 新手,想根据键对 Map 进行排序,然后在值内对每个列表进行排序。 我试图寻找一种 Java 8 方法来对键和值进行排序。HashMap>映射 map.entrySet().str
这就是我的目标... vector ,int> > var_name (x, pair (y),int>); 其中 x 是 vector var_name 的大小,y 是对内 vector 的大小。
这里是 an answer to "How do I instantiate a Queue object in java?" , Queue is an interface. You can't i
这个问题在这里已经有了答案: Weird Integer boxing in Java (12 个答案) Why are autoboxed Integers and .getClass() val
我们可以使用 C++ STL 做这样的事情吗?如果是,我将如何初始化元素?我试图这样做,但没有成功。 pair,vector>p; p.first[0]=2; 最佳答案 Can we do som
您好,我正在尝试为百分比和整数数组中的数字找到索引。假设 arraynum = ['10%','250','20%','500'] 并且用户发送一个值 15%,这个数字在哪个范围内居住?我可以使用这段
我与三列有关系:ProductName、CategoryID 和 Price。我需要选择仅那些价格高于给定类别中平均产品价格的产品。(例如,当apple(ProductName)是fruit(Cate
我已经坚持了一段时间,我正在尝试将一些数据配对在一起。这是我的代码。 #include #include using namespace std; int main() { pair data(
我收到错误:'(Int, Int)' 与 'CGPoint' 不相同 如何将 (Int, Int) 转换为 CGPoint let zigzag = [(100,100), (100,150)
我在 .cpp 文件中发现了以下代码。我不理解涉及头文件的构造或语法。我确实认识到这些特定的头文件与 Android NDK 相关。但是,我认为这个问题是关于 C++ 语法的一般问题。这些在某种程度上
我将这些输入到 Scala 解释器中: val a : Integer = 1; val b : Integer = a + 1; 我收到消息: :5: error: type mismatch;
C++:vector>v(size);当我试图打印出值时显示 0 作为值,但是当未声明 vector 大小时它显示正确的输出?为什么这样?例如: int x; cin>>x; vector>v(x);
我是一名优秀的程序员,十分优秀!