CListCtrl大数据显示[通俗易懂]

CListCtrl大数据显示[通俗易懂]CListCtrl是个很方便的东西,但是当数据大到一个程度(比如说10万条数据),显示速度就会非常的慢。解决办法就是用虚拟列表。CListCtrl显示数据的原理是将需显示的所有数据拷贝在它内部的一块空间里,然后显示出来。一但数据量过大,拷贝的时间就会延长,显示速度当然也就非常慢了。而虚拟列表则不需要将显示数据拷贝到内部空间,它的做法是当需要显示某个数据时,才将数据拷入内部空间。看上去好像和普通CLi

大家好,又见面了,我是你们的朋友全栈君。

CListCtrl是个很方便的东西,但是当数据大到一个程度(比如说10万条数据),显示速度就会非常的慢。解决办法就是用虚拟列表。

CListCtrl显示数据的原理是将需显示的所有数据拷贝在它内部的一块空间里,然后显示出来。一但数据量过大,拷贝的时间就会延长,显示速度当然也就非常慢了。而虚拟列表则不需要将显示数据拷贝到内部空间,它的做法是当需要显示某个数据时,才将数据拷入内部空间。看上去好像和普通CListCtrl的做法相同,实则大不一样。因为列表一屏的数据,最多也就几百行。也就是说虚拟列表每次最多也就只需要拷贝几百行的数据,对现在计算机的速度而言,速度的延迟是完全可以忽略的。

好了,原理说到这里。接下来该说做怎么做了。

class CVirtaulListCtrl : public CListCtrl
{
DECLARE_DYNAMIC(CVirtaulListCtrl)
public:
    CVirtaulListCtrl();
    virtual ~CVirtaulListCtrl();
public:
//导入数据
    void ImportData(CStringArray *pDataArray)
    {
        m_pDataArray = pDataArray;
        SetItemCount(m_pDataArray->GetSize());
    }
protected:
    CStringArray *m_pDataArray;
protected:
DECLARE_MESSAGE_MAP()
public:
    afx_msg void OnLvnGetdispinfo(NMHDR *pNMHDR, LRESULT *pResult)
    {
        LV_DISPINFO* pDispInfo = (LV_DISPINFO*)pNMHDR;
        LV_ITEM* pItem= &(pDispInfo)->item;
        int  iItemIndex= pItem->iItem;  //行号
        int col = pItem->iSubItem;  //列号
        if(pItem->mask & LVIF_TEXT)
        {
            if(col == 0)
            {
                //序号
                char numberStr[10];
                itoa(iItemIndex+1, numberStr, 10);
                lstrcpyn(pItem->pszText, numberStr, pItem->cchTextMax);
            }
            else if(col == 1)
            {
                lstrcpyn(pItem->pszText, m_pDataArray->GetAt(iItemIndex), pItem->cchTextMax);
            }
        }
    }
};

上面一共只有两个函数。一个是ImportData,作用是导入需要显示的数据。里面只有两条语句,第一条为获取数据指针,第二条为设置列表长度(一共有多少条数据)。这个是自定义函数,可以自定义函数名和导入的数据结构。

第二个函数是OnLvnGetdispinfo。这个函数是事件函数,当列表中的一个单元格需显示的时候调用。

使用时,还需要将列表控件的“所有者数据”属性设为“true”。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/152513.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Springboot的Mybatis拦截器实现[通俗易懂]

    Springboot的Mybatis拦截器实现[通俗易懂]MyBatis提供了一种插件(plugin)的功能,虽然叫做插件,其实就是拦截器功能MyBatis允许拦截的接口MyBatis允许你在已映射语句执行过程中的某一点进行拦截调用。默认情况下,MyBatis允许使用插件来拦截的方法调用包括:Executor(update,query,fl…

    2025年10月11日
    2
  • pycharm怎么打开database_数据库在生活中的实例

    pycharm怎么打开database_数据库在生活中的实例显示Database功能(已有自动忽略)窗口右侧打开Database输入数据库信息登录数据库可以进行任意数据库操作,该工具类似许多数据库管理软件

    2022年8月25日
    9
  • Redis的bind的误区

    Redis的bind的误区今天在搭建 Redis 服务集群的时候 发现自己一直以来对 Redis 中 bind 的理解的一个误区 在今天以前 我一直认为 Redis 中的配置文件中的 bind 的作用是 用来限制 Redis 服务器用来接收来自哪些服务器 IP 地址 的 Redis 连接请求 即 只有在 bind 指定的 IP 地址的计算机才可以访问这个 Redis 服务器 直到今天我才知道以上的理解都是错误 例如 bind127 0 0 1

    2025年10月30日
    5
  • UNITY3D MAC版本号破解

    UNITY3D MAC版本号破解

    2022年1月3日
    456
  • mac Hadoop环境变量配置

    mac Hadoop环境变量配置Mac打开、编辑.bash_profile文件一般在Mac上配置环境变量时经常要创建、编辑.bash_profile文件。创建该文件时一般都会选择在当前用户目录下,即Mac下的.bash_profile文件的路径是/Users/YourMacUserName/.bash_profile(如果该文件已经创建过的话)默认情况下,系统不显示隐藏文件,可在终端中输如下代码,即可显示…

    2022年6月21日
    75
  • fork函数简介_fork()&&fork()

    fork函数简介_fork()&&fork()包括: fork函数简介fork函数的两次返回和父子进程的执行顺序简介fork()子进程与父进程之间的文件描述符问题  [cpp] view plaincopyprint? 1  1 #include                                                                                  

    2025年6月1日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号