C# winform中ComboBox数据绑定的两种方法及效率详解

 更新时间:2023年08月04日 08:38:13   作者:chentiebo  
这篇文章主要给大家介绍了关于C# winform中ComboBox数据绑定的两种方法及效率,Winform ComboBox数据绑定是指将数据源中的数据与ComboBox控件进行关联,需要的朋友可以参考下

一、ComboBox两种数据绑定的方法

1.1、方法一、DataTable

           //创建DataTable
            DataTable dataTable = new DataTable();
 
            dataTable.Columns.Add("ID");
            dataTable.Columns.Add("Name");
 
            DataRow dataRow = dataTable.NewRow();
 
            dataRow["ID"] = "1";
            dataRow["Name"] = "方法1-测试1";
            dataTable.Rows.Add(dataRow);
 
            DataRow dataRow1 = dataTable.NewRow();
            dataRow1["ID"] = "2";
            dataRow1["Name"] = "方法1-测试2";
            dataTable.Rows.Add(dataRow1);
 
            DataRow dataRow2 = dataTable.NewRow();
            dataRow2["ID"] = "3";
            dataRow2["Name"] = "方法1-测试3";
            dataTable.Rows.Add(dataRow2);
 
            // ComboBox数据绑定
            this.comboBox1.DataSource = dataTable;
            comboBox1.DisplayMember = "Name";
            comboBox1.ValueMember = "ID";

1.2、方法二、List

       //创建Test类
        public class Test
        {
            public Test() { }
            public Test(int sid, string name, int age)
            {
                SID = sid;
                Name = name;
                Age = age;
            }
            public string Name { get; }
            public int Age { get; }
            public int SID { get; }
         }
        public List<Test> GetDate2()
        {
            List<Test> list = new List<Test>();
            Test test = new Test(1, "方法二--测试1", 21);
            list.Add(test);
            Test test1 = new Test(2, "方法二--测试2", 22);
            list.Add(test1);
            Test test2 = new Test(3, "方法二--测试3", 23);
            list.Add(test2);
           // ComboBox数据绑定Lsit
            this.comboBox2.DataSource = list;
            comboBox2.DisplayMember = "Name";
            comboBox2.ValueMember = "SID";
            return list;
        }

二、比较两种方法的效率

2.1、窗体设计

2.2、代码

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Diagnostics;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
namespace WindowsFormsApp1
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
            方法一
            //this.comboBox1.DataSource = GteDate1();
            //comboBox1.DisplayMember = "Name";
            //comboBox1.ValueMember = "ID";
            方法二
            //this.comboBox2.DataSource = GetDate2();
            //comboBox2.DisplayMember = "Name";
            //comboBox2.ValueMember = "SID";
            #region 处理2
            //创建计时
            Stopwatch str1 = new Stopwatch();
            //计时开始
            str1.Start();
            //运行方法一
            GetDate1();
            // 计时停止
            str1.Stop();
            //控件label1显示出总共花费的时间(单位毫秒)
            this.label1Time1.Text = str1.Elapsed.TotalMilliseconds.ToString();
            //创建计时
            Stopwatch str2 = new Stopwatch();
            //计时开始
            str2.Start();
            //运行方法二
            GetDate2();
            // 计时停止
            str2.Stop();
            //控件label1显示出总共花费的时间(单位毫秒)
            this.label1Time2.Text = str2.Elapsed.TotalMilliseconds.ToString();
            #endregion 
        }
        #region ComboBox两种数据绑定的方法
        //方法一,dataTable
        public DataTable GetDate1()
        {
            //创建DataTable
            DataTable dataTable = new DataTable();
            dataTable.Columns.Add("ID");
            dataTable.Columns.Add("Name");
            DataRow dataRow = dataTable.NewRow();
            dataRow["ID"] = "1";
            dataRow["Name"] = "方法1-测试1";
            dataTable.Rows.Add(dataRow);
            DataRow dataRow1 = dataTable.NewRow();
            dataRow1["ID"] = "2";
            dataRow1["Name"] = "方法1-测试2";
            dataTable.Rows.Add(dataRow1);
            DataRow dataRow2 = dataTable.NewRow();
            dataRow2["ID"] = "3";
            dataRow2["Name"] = "方法1-测试3";
            dataTable.Rows.Add(dataRow2);
            // 数据绑定
            this.comboBox1.DataSource = dataTable;
            comboBox1.DisplayMember = "Name";
            comboBox1.ValueMember = "ID";
            return dataTable; 
        }
        // 方法二,list
            //创建Test类
        public class Test
        {
            public Test() { }
            public Test(int sid, string name, int age)
            {
                SID = sid;
                Name = name;
                Age = age;
            }
            public string Name { get; }
            public int Age { get; }
            public int SID { get; }
         }
        public List<Test> GetDate2()
        {
            List<Test> list = new List<Test>();
            Test test = new Test(1, "方法二--测试1", 21);
            list.Add(test);
            Test test1 = new Test(2, "方法二--测试2", 22);
            list.Add(test1);
            Test test2 = new Test(3, "方法二--测试3", 23);
            list.Add(test2);
            this.comboBox2.DataSource = list;
            comboBox2.DisplayMember = "Name";
            comboBox2.ValueMember = "SID";
            return list;
        }
         #endregion
    }
}

2.3、两种方法消耗时间对比

list相对于DataTable消耗的时长要少

总结

到此这篇关于C# winform中ComboBox数据绑定的两种方法及效率的文章就介绍到这了,更多相关C# winform ComboBox数据绑定内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C#抓取当前屏幕并保存为图片的方法

    C#抓取当前屏幕并保存为图片的方法

    这篇文章主要介绍了C#抓取当前屏幕并保存为图片的方法,实例分析了C#操作图片的相关技巧,非常具有实用价值,需要的朋友可以参考下
    2015-04-04
  • OpenXml读取word内容的实例

    OpenXml读取word内容的实例

    下面小编就为大家分享一篇OpenXml读取word内容的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2017-12-12
  • C# 实现基于ADO.NET框架的DBHelper工具类(简化数据库操作)

    C# 实现基于ADO.NET框架的DBHelper工具类(简化数据库操作)

    ADO.NET是.NET框架中用于与数据库交互的核心组件,提供了一套用于连接数据库、执行SQL查询、插入、更新和删除数据的类库,包括SqlConnection、SqlCommand、SqlDataReader等,本文介绍如何使用DBHelper类封装数据库操作,以提高代码的可维护性和复用性,感兴趣的朋友一起看看吧
    2024-08-08
  • C#通过配置文件动态修改web.config内容的操作步骤

    C#通过配置文件动态修改web.config内容的操作步骤

    这篇文章主要介绍了C#通过配置文件动态修改web.config内容的操作步骤,文中通过图文结合的方式介绍的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2024-03-03
  • C#中Invoke的用法讲解

    C#中Invoke的用法讲解

    这篇文章主要介绍了C#中Invoke的用法讲解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • C#中DataSet,DataTable,DataView的区别与用法

    C#中DataSet,DataTable,DataView的区别与用法

    这篇文章介绍了C#中DataSet,DataTable,DataView的区别与用法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • C#连接mariadb(MYSQL分支)代码示例分享

    C#连接mariadb(MYSQL分支)代码示例分享

    这篇文章主要介绍了C#连接mariadb的方法,和MySQL连接方式差不多,大家参考使用吧
    2013-11-11
  • C#使用doggleReport生成pdf报表的方法

    C#使用doggleReport生成pdf报表的方法

    这篇文章主要介绍了C#使用doggleReport生成pdf报表的方法,结合实例形式分析了C# doggleReport安装及使用具体操作技巧,需要的朋友可以参考下
    2017-06-06
  • C#实现主窗体最小化后出现悬浮框及双击悬浮框恢复原窗体的方法

    C#实现主窗体最小化后出现悬浮框及双击悬浮框恢复原窗体的方法

    这篇文章主要介绍了C#实现主窗体最小化后出现悬浮框及双击悬浮框恢复原窗体的方法,涉及C#窗体及鼠标事件响应的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-08-08
  • 利用C#编写Linux守护进程实例代码

    利用C#编写Linux守护进程实例代码

    如今的编程是一场程序员和上帝的竞赛,程序员要开发出更大更好、傻瓜都会用到软件,下面这篇文章主要给大家介绍了关于利用C#编写Linux守护进程的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下。
    2018-01-01

最新评论