[问题] function用char**当参数

楼主: wong0101 (wong0101)   2018-04-21 15:57:07
想请问板上的大大一个问题
下面有一段code, func2()是别人开的API, 我在func1()目前这样实作看起来正常,
但是想厘清这样写会不会有潜在的内存问题?
(1) 在messages从func1传到func2时
因为没有malloc内存给messages,导致在func2存取时发生奇怪行为?
(2) 在messages[0] = s1.toLocal8Bit()时
没有将s1.toLocal8Bit()的值存起来,
而是让messages[0]指到一个有可能被覆蓋的内存空间?
(3) 其他?
先谢谢各位了
void func1
(
const QString& s1,
const QString& s2
)
{
const char* messages[2];
// convert QString to char *
messages[0] = s1.toLocal8Bit();
messages[1] = s2.toLocal8Bit();
func2( 2, messages );
}
void func2
(
const int num_messages,
const char ** messages
)
{
// do something
}
楼主: wong0101 (wong0101)   2018-04-21 16:42:00
目前自己的想法是(1)因为messages还会在stack中所以还是可以在func2中被存取的,(2)messages[0]指到的位置应该会有机会被盖掉,导致奇怪的问题
作者: peterwu4 (notd)   2018-04-21 17:33:00
应该纯粹就是因为func1的messages是个矩阵,本身就是pointer,宣告成pointer的pointer,所以才这样子传递参数的~
作者: AstralBrain   2018-04-21 17:41:00
1)不会 2)会,QByteArray在toLocal8Bit()那行结束的时候就destruct掉了
作者: peterwu4 (notd)   2018-04-21 17:54:00
qt不熟,但是只要func1传入的字串被释放内存前,都不会有问题,大家指到的位置都是s1,s2存放内容的矩阵位置
作者: AstralBrain   2018-04-21 18:02:00
toLocal8Bit()会生一个暂时物件(QByteArray)出来没搞错的话这边会copy一份 然后马上被destructmessages指到的是一块被free掉的memory
作者: peterwu4 (notd)   2018-04-21 18:08:00
了解~
作者: AstralBrain   2018-04-21 18:08:00
啊 正确来说不是copy, 是encode
作者: uranusjr (←這人是超級笨蛋)   2018-04-21 18:09:00
toLocal8Bit 明明就回传 QByteArray 你为什么不乖乖接
作者: AstralBrain   2018-04-21 18:09:00
总之不会跟QString共用空间
楼主: wong0101 (wong0101)   2018-04-22 02:19:00
了解 感谢各位大大的指导!

Links booklink

Contact Us: admin [ a t ] ucptt.com