C#编程实用技巧集锦:23个高效提示

需积分: 10 5 下载量 61 浏览量 更新于2024-09-15 收藏 13KB TXT 举报
"这篇文章主要介绍了在C#开发和使用过程中的一些实用技巧,涵盖了从界面设计到数据库操作等多个方面。" 1. 自定义DataGrid显示:在C#中,可以利用`DataGridTableStyle`和`DataGridTextBoxColumn`来自定义DataGrid的显示样式。例如,创建一个新的`DataGridTableStyle`,设置映射名称,并添加`DataGridTextBoxColumn`来指定列名和表头文本。 2. 处理空值查询:在SQL查询中,可以使用`IS NULL`条件来筛选出某一列值为空的结果。例如,`WHERE col_name IS NULL`将返回所有`col_name`列值为空的记录。 3. 设置WinForm默认按钮:在C# WinForm应用中,可以设置一个窗体的`AcceptButton`属性,这样按下回车键时,该按钮会被触发。 4. 数据类型转换:当从Oracle的`NUMBER(15)`字段导入到SQL Server时,对应的数据类型应为`numeric(15,0)`,以保持数据一致性。 5. SQL Server的LIKE操作:在SQL Server中,如果需要进行模糊匹配,可以使用`LIKE`关键字配合通配符 `%`。例如,`WHERE column LIKE '%'+@search_text+'%'` 可以查找包含`@search_text`的行。 6. 阻止TextBox回车事件:在WinForm中,可以通过重写`KeyPress`事件来防止用户按下回车键触发默认行为,如提交表单。只需在事件处理器中检查按键是否为回车键,如果是则忽略事件。 7. 转换数据库查询结果:如果从数据库查询得到的结果是可空类型,如`object`,并且需要将其转换为`Int32`,可以先将结果转换为字符串,然后再使用`Int32.Parse()`方法。 8. 动态添加DataColumn:当DataSource已经绑定到一个DataTable时,可以通过创建新的`DataColumn`并设置表达式来动态添加列。这可以用于关联其他列,比如`dc.Expression = "Parent.parentColumnName"`。 9. DataGrid仅显示子集:在显示DataTable时,可以通过设置`DataGridColumn`的`Expression`属性来实现只显示部分数据,例如,只显示某字符串的子串。 10. ComboBox显示模式:在WinForm的ComboBox中,可以通过设置`DropDownStyle`属性来控制下拉列表的行为。如果希望禁用编辑功能,确保其设置为`ComboBoxStyle.DropDownList`。 这些技巧对于提升C#开发效率和优化代码质量非常有帮助,它们涵盖了数据绑定、界面交互和数据库操作等多个关键领域。理解并掌握这些技巧将使开发者在日常工作中更加得心应手。
2013-07-14 上传
1、 FACTORY —追 MM 少不了请吃饭了, 麦当劳的鸡翅和肯德基的鸡翅都是 MM 爱吃的东西, 虽然口味有所不同, 但不管你带 MM 去麦当劳或肯德基, 只管向服务员说“来四个鸡翅”就行 了。麦当劳和肯德基就是生产鸡翅的 Factory 工厂模式:客户类和工厂类分开。消费者任何时候需要某种产品,只需向工厂请求即可。消 工厂模式 费者无须修改就可以接纳新产品。缺点是当产品修改时,工厂类也要做相应的修改。如:如 何创建及如何向客户端提供。 2、BUILDER — MM 最爱听的就是“我爱你”这句话了,见到不同地方的 MM,要能够用她们的 、 方言跟她说这句话哦,我有一个多种语言翻译机,上面每种语言都有一个按键,见到 MM 我只要按对应的键, 它就能够用相应的语言说出“我爱你”这句话了, 国外的 MM 也可以轻松 搞掂,这就是我的“我爱你”builder。 (这一定比美军在 伊拉克用的翻译机好卖) 建造模式: 从而使一个建造过程生成具有不 建造模式 将产品的内部表象和产品的生成过程分割开来, 同的内部表象的产品对象。 建造模式使得产品内部表象可以独立的变化, 客户不必知道产品 内部组成的细节。建造模式可以强制实行一种分步骤进行的建造过程。 3、FACTORY METHOD —请 MM 去麦当劳吃汉堡,不同的 MM 有不同的口味,要每个都记住 、 是一件烦人的事情,我一般采用 Factory Method 模式,带着 MM 到服务员那儿,说“要一个 汉堡”,具体要什么样的汉堡呢,让 MM 直接跟服务员说就行了。 工厂方法模式: 而是将具体创建的工作交给子类去做, 工厂方法模式 核心工厂类不再负责所有产品的创建, 成为一个抽象工厂角色, 仅负责给出具体工厂类必须实现的接口, 而不接触哪一个产品类应 当被实例化这种细节。 4、 、 PROTOTYPE —跟 MM 用 QQ 聊天, 一定要说些深情的话语了, 我搜集了好多肉麻的情话, 需要时只要 copy 出来放到 QQ 里面就行了, 这就是我的情话 prototype 了。 (100 块钱一份, 你要不要) 原始模型模式: 原始模型模式 通过给出一个原型对象来指明所要创建的对象的类型,然后用复制这个原 型对象的方法创建出更多同类型的对象。 原始模型模式允许动态的增加或减少产品类, 产品 类不需要非得有任何事先确定的等级结构, 原始模型模式适用于任何的等级结构。 缺点是每 一个类都必须配备一个克隆方法。 5、 、 SINGLETON —俺有 6 个漂亮的老婆, 她们的老公都是我, 我就是我们家里的老公 Sigleton, 她们只要说道“老公”,都是指的同一个人,那就是我(刚才做了个梦啦,哪有这么好的事) 单例模式: 而且自行实例化并向整个系统提供这个实 单例模式 单例模式确保某一个类只有一个实例, 例单例模式。单例模式只应在有真正的“单一实例”的需求时才可使用。 结构型模式 6、ADAPTER —在朋友聚会上碰到了一个美女 Sarah,从香港来的,可我不会说粤语,她不 、 会说普通话,只好求助于我的朋友 kent 了,他作为我和 Sarah 之间的 Adapter,让我和 Sarah 可以相互交谈了(也不知道他会不会耍我) 适配器模式: 从而使原本因接口原因不 适配器模式 把一个类的接口变换成客户端所期待的另一种接口, 匹配而无法一起工作的两个类能够一起工作。 适配类可以根据参数返还一个合适的实例给客 户端。 7、BRIDGE —早上碰到 MM,要说早上好,晚上碰到 MM,要说晚上好;碰到 MM 穿了件新 、 衣服, 要说你的衣服好漂亮哦, 碰到 MM 新做的发型, 要说你的头发好漂亮哦。 不要问我“早 上碰到 MM 新做了个发型怎么说”这种问题,自己用 BRIDGE 组合一下不就行了 桥梁模式:将抽象化与实现化脱耦,使得二者可以独立的变化,也就是说将他们之间的强关 桥梁模式 联变成弱关联,也就是指在一个软件系统的抽象化和实现化之间使用组合/聚合关系而不是 继承关系,从而使两者可以独立的变化。 8、COMPOSITE —Mary 今天过生日。“我过生日,你要送我一件礼物。”“嗯,好吧,去商店, 、 你自己挑。”“这件 T 恤挺漂亮,买,这条裙子好看,买,这个包也不错, 买。”“喂,买了 三件了呀,我只答应送一件礼物的哦。”“什么呀,T 恤加裙子加包包,正好配成一套呀,小 姐,麻烦你包起来。”“……”,MM 都会用 Composite 模式了,你会了没有? 合成模式:合成模式将对象组织到树结构中,可以用来描述整体与部分的关系。合成模式就 合成模式 是一个处理对象的树结构的模式。 合成模式把部分与整体的