可空值类型
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.SqlClient;
namespace _03可空值类型
{
class Program
{
static void Main(string[] args)
{
#region 可空值类型
//引用类型可空,值类型不可空
//int n = 10;
//string s = "hello";
//s = null;
//n = null;
// int? 等价于 Nullable<int>
//int? n = 10;
//Nullable<int> n = 10;
//n = null;
//n = 100;
//n++;
//Console.WriteLine(n);
//Console.WriteLine("ok");
//Console.ReadKey();
//Nullable继承于Struct,结构体是值类型的,并不能真正赋值为null(详见图一)
//所以可控制类型并没有把一个NULL值赋值给 变量n,而是编译时用另一中方式让你看起来可以为NULL。
//Nullable<int> n = 10;
//内部执行过程
//Nullable<int> n;
// 如果有值,那么内部HasValue属性赋值为true
//n.HasValue = true;
//然后赋值
//n.Value = 10;
//Nullable<int> n = null;
//如果为Null,那么只把HasValue属性赋值为false,并不真正赋值。
//n.HasValue = false;
// 使用到的时候,例如判断 int? n =null 时候为null值。
//if (n==null) //实际等价于 if(!n.HasValue)
//{
//}
// 下同
//int? n = 10;
//double? d = 10.1;
//float? x = 99;
//bool? b = false;
////string? s = "aaa"; 报错可空值类型只能用于值类型,不能应用于引用类型,因为引用类型本身可以赋值为null。
#endregion
#region 使用带参数sql语句时的一个问题
string sql = "insert into TblPerson values(@name,@age,@height,@gender)";
SqlParameter[] pms = new SqlParameter[] {
new SqlParameter("@name","王五"),
new SqlParameter("@age",0), //报错 重载识别错误,详见图二。
//new SqlParameter("@age",System.Data.SqlDbType.Int){Value=0}, //建议指明类型。
new SqlParameter("@height",180),
new SqlParameter("@gender",true)
};
_02封装SqlHelper类.SqlHelper.ExecuteNonQuery(sql, pms);
Console.WriteLine("ok");
Console.ReadKey();
#endregion
}
}
}
图一 、利用反编译软件 .NetReflector 7.0 查看内部代码:
图二 重载问题
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具