解决方法
    方法一:先将QString转换为标准库中的string类型,然后将string转换为char*,如下:

    1. std::string str = filename.toStdString();
    2. const char* ch = str.c_str();

    经测试,没有出现中文乱码。

    方法二:Qt中,很多时候,我们用 char* ch 变量去显示到界面时,都会先将其转换成QString。如果直接使用强转换QString(ch),得到的结果会是乱码。但是,使用如下方法转换即可解决问题,代码如下:
    1.设置编码:

    1. QTextCodec::setCodecForTr(QTextCodec::codecForName("utf-8"));
    2. QTextCodec::setCodecForCStrings(QTextCodec::codecForName("utf-8"));
    3. QTextCodec::setCodecForLocale(QTextCodec::codecForName("utf-8"));

    2.将QString转换成char * 过程:

    1. QString str = "中文测试";
    2. QByteArray temp = str.toLocal8Bit();
    3. char *name = temp.data();
    4. qDebug()<<"name: "<<name;

    尽管此时qDebug()输出显示的是乱码,但是假如这里的name 只是作为一个中间变量,是为了调用某些接口而使用的,最后还是需要将 name 转换会 QString 供界面显示。那么我们可以忽略这个name变量的乱码问题,只需要关注:最后将name转换为QString时,不会乱码就行。

    3.将char* 转换为 QString

    1. char name[256];
    2. memset(name,0,sizeof(name));
    3. getFileName(name); //从某个地方获取name,自定义
    4. QString str = QString::fromLocal8Bit(name); //转换成QString,供界面显示。
    5. //此处如果直接使用强制转换QString str = QString(name),会出现乱码。

    所以,关键在于 toLocal8Bit() 以及 fromLocal8Bit() 的配套使用。