C++中的省略号

C++允许定义形参个数和类型不确定的函数。例如,C语言中的标准函数printf便使用这种机制。

在声明不确定形参的函数时,形参部分可以使用省略号“…”代替。“…”告诉编译器,

在函数调用时不检查形参类型是否与实参类型相同,也不检查参数个数。

例如:

void ConnectData(int i,...)

在上面的代码中,编译器只检查第一个参数是否为整型,而不对其他参数进行检查。

对于可变参数的函数,需要进行特殊的处理。首先需要引用 <stdarg.h> 头文件,

然后利用va_list类型和va_start、va_arg、va_end 3个宏读取传递到函数中的参数值。

这几个宏的定义如下(在 ANSI C 中):
type va_arg( va_list arg_ptr, type );
void va_end( va_list arg_ptr );
void va_start( va_list arg_ptr, prev_param );   

说明如下:
va_start 

sets arg_ptr to the first optional argument in the list of arguments passed to the function. 

The argument arg_ptr must have va_list type. The argument prev_param is the name of 

the required parameter immediately preceding the first optional argument in the argument list. 

If prev_param is declared with the register storage class, the macro’s behavior is undefined. 

va_start must be used before va_arg is used for the first time.

va_start函数将参数arg_ptr设置为可变参数列表的第一个参数。参数arg_ptr的类型必须为va_list。

参数prev_param是在可变参数列表之前的那一个参数。(也就是说在 ANSI C 中,如果一个函数有可变参数,

那么在该可变参数前必须有一个明确定义的参数,否则无法调用函数 va_start ,例如函数 int add(int i,...)是合法的,

而函数 int add(...)是不合法的。)


va_arg 

retrieves a value of type from the location given by arg_ptr and increments arg_ptr to point to the next argument in the list, 

using the size of type to determine where the next argument starts. va_arg can be used any number of times within the function 

to retrieve arguments from the list.  

va_arg函数将返回 arg_ptr 所指位置的值,并将 arg_ptr 指向下一个参数.

va_end
After all arguments have been retrieved, va_end resets the pointer to NULL.
#include "stdafx.h"  
#include "iostream.h"  
#include "cstdarg"  
void ConnectData(int i,...)  {  
     va_list ap;  
     va_start(ap,i);//是对第一个形参进行提取  
     while(i--)  {  
         char* ctemp = va_arg(ap,char*);//提取第2个形参  
         int itemp = va_arg(ap,int);//提取第三个形参  
         float ftemp = va_arg(ap,double);//第四个形参  
         cout << ctemp ;  
         cout << itemp ;  
         cout << ftemp <<"/n";  
     }  
     va_end(ap);  
}  
int main()  {  
     ConnectData(2,"Mul",2006,7.12,"Co.,Ltd.",54,8.2);  
     return 0;  
}   

//运行结果  
Mul 2006  7.12  
Co., Ltd 54  8.2  
#include   <stdio.h>     
#include   <stdarg.h>     
#include <iostream>  
using namespace std;  

  /*   calculate   sum   of   a   0   terminated   list   */     
  void   sum(char   *msg,   ...)   {     
        int   total   =   0;     
        va_list   ap;     
        int   arg;     
        va_start(ap, msg);  //第一个参数是char*类型,其余的是int类型   
        while   ((arg   =   va_arg(ap,int))   !=   0)    
        {     
              total   +=   arg;     
        }     
        printf(msg,   total);     
        va_end(ap);     
  }     
      
  int   main(void)   {     
        sum("The   total   of   1+2+3+4   is   %d/n",   1,2,3,4,0);    
        system("pause");   
        return   0;     
  }   



在使用Qt框架中的`QTableView`显示中文内容时,如果列中的内容过长,可能无法完整显示,此时可以通过设置`QTableView`的委托(delegate)来实现过长文本的省略显示。以下是一个简单的示例代码,演示如何为`QTableView`设置一个委托,使得过长的文本以省略号显示: 首先,需要引入`QStyledItemDelegate`,它是用于定制`QTableView`中单元格显示方式的一个委托类。 ```cpp #include <QStyledItemDelegate> #include <QApplication> #include <QTableView> #include <QStandardItemModel> // 自定义委托类,用于处理文本截断和省略显示 class ElideDelegate : public QStyledItemDelegate { public: ElideDelegate(QObject *parent = nullptr) : QStyledItemDelegate(parent) {} // 重写paint方法,实现文本的省略显示 void paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const override { // 调用基类的paint方法处理常规绘制 QStyledItemDelegate::paint(painter, option, index); // 获取当前单元格的文本 QString text = index.model()->data(index, Qt::DisplayRole).toString(); // 检查文本是否需要截断 if (option.rect.width() < painter->boundingRect(option.rect, Qt::TextWordWrap | Qt::TextShowMnemonic, text).width()) { // 计算截断位置 int elideWidth = option.rect.width(); QString elidedText = painter->fontMetrics().elidedText(text, Qt::ElideRight, elideWidth); // 在同一位置绘制省略后的文本 painter->drawText(option.rect, Qt::TextWordWrap | Qt::TextShowMnemonic, elidedText); } } }; int main(int argc, char *argv[]) { QApplication app(argc, argv); // 创建QTableView对象 QTableView tableView; // 创建委托对象 ElideDelegate *delegate = new ElideDelegate(&tableView); // 设置委托给QTableView tableView.setItemDelegate(delegate); // 创建模型并填充数据 QStandardItemModel model(4, 2); model.setHorizontalHeaderLabels(QStringList() << "长标题1" << "长标题2"); model.setItem(0, 0, new QStandardItem("这是一段很长很长的文本内容,可能会超出显示范围...")); model.setItem(1, 0, new QStandardItem("短文本")); model.setItem(2, 0, new QStandardItem("超出显示范围的文本")); model.setItem(3, 0, new QStandardItem("其他文本")); // 将模型设置给QTableView tableView.setModel(&model); // 显示QTableView tableView.show(); return app.exec(); } ``` 在这段代码中,`ElideDelegate`类继承自`QStyledItemDelegate`,并重写了`paint`方法以实现文本的省略显示。在`paint`方法中,我们首先调用基类的`paint`方法来处理常规绘制,然后获取当前单元格的文本并检查是否需要截断。如果需要,我们计算截断位置,并使用`elidedText`方法生成省略后的文本,最后在相同的位置绘制省略后的文本。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值