QString *s与QString s用法的差别,在使用at()函数时为什么不一样

QString *s与QString s用法的区别,在使用at()函数时为什么不一样?
第一种实现方法:
QString *strlistpath
strlistpath = new QStringList();
strlistpath->append(File+"(loical)");
最后取出容器里的元素使用strlistpath->at(k),当添加多个元素时,用at函数报错,说超界了

第二种实现方法:
QString strlistpath

strlistpath.append(File+"(loical)");

最后取出容器元素还是使用strlistpath.at(k),使用正常,请帮忙分析下第一种实现方法中的错误。

我实在做音乐播放器保存列表时,用第一种方法一种报错,后来就直接用第二种实现的,应该是指针使用错误吧,但求大神解释!

------解决方案--------------------
计算机组成原理→DOS命令→汇编语言→C语言(不包括C++)、代码书写规范→数据结构、编译原理、操作系统→计算机网络、数据库原理、正则表达式→其它语言(包括C++)、架构……

对学习编程者的忠告:
眼过千遍不如手过一遍!
书看千行不如手敲一行!
手敲千行不如单步一行!
单步源代码千行不如单步对应汇编一行!

单步类的实例“构造”或“复制”或“作为函数参数”或“作为函数返回值返回”或“参加各种运算”或“退出作用域”的语句对应的汇编代码几步后,就会来到该类的“构造函数”或“复制构造函数”或“运算符重载”或“析构函数”对应的C/C++源代码处。

VC调试时按Alt+8、Alt+7、Alt+6和Alt+5,打开汇编窗口、堆栈窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应堆栈、内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
(Turbo C或Borland C用Turbo Debugger调试,Linux或Unix下用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)

------解决方案--------------------
这种就别求大神了,c++基础知识为0导致的,去学吧。
QString类型的指针,却new了一段QStringList的内存
------解决方案--------------------

QString *strlistpath;
//这个是指针, 没有分配内存空间给它赋值,肯定出问题拉!
//先分配点空间给它再作赋值操作吧!
QString strlistpath;
//这是因为在栈区,系统给你分配了空间的!