作者wong0101 (wong0101)
看板C_and_CPP
标题[问题] function用char**当参数
时间Sat Apr 21 15:57:07 2018
想请问板上的大大一个问题
下面有一段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
}
--
※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 42.73.134.127
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/C_and_CPP/M.1524297430.A.C39.html
※ 编辑: wong0101 (42.73.134.127), 04/21/2018 15:58:20
1F:→ wong0101: 目前自己的想法是(1)因为messages还会在stack中所以还是 04/21 16:42
2F:→ wong0101: 可以在func2中被存取的,(2)messages[0]指到的位置应该会 04/21 16:44
3F:→ wong0101: 有机会被盖掉,导致奇怪的问题 04/21 16:45
4F:推 peterwu4: 应该纯粹就是因为func1的messages是个矩阵,本身就是 04/21 17:33
5F:→ peterwu4: pointer,宣告成pointer的pointer,所以才这样子传递参 04/21 17:35
6F:→ peterwu4: 数的~ 04/21 17:35
7F:推 AstralBrain: 1)不会 2)会,QByteArray在toLocal8Bit()那行结束的时 04/21 17:41
8F:→ AstralBrain: 候就destruct掉了 04/21 17:41
9F:推 peterwu4: qt不熟,但是只要func1传入的字串被释放记忆体前,都不 04/21 17:54
10F:→ peterwu4: 会有问题,大家指到的位置都是s1,s2存放内容的矩阵位置 04/21 17:55
11F:推 AstralBrain: toLocal8Bit()会生一个暂时物件(QByteArray)出来 04/21 18:02
12F:→ AstralBrain: 没搞错的话这边会copy一份 然後马上被destruct 04/21 18:03
13F:→ AstralBrain: messages指到的是一块被free掉的memory 04/21 18:03
14F:推 peterwu4: 了解~ 04/21 18:08
15F:推 AstralBrain: 啊 正确来说不是copy, 是encode 04/21 18:08
16F:→ uranusjr: toLocal8Bit 明明就回传 QByteArray 你为什麽不乖乖接 04/21 18:09
17F:→ AstralBrain: 总之不会跟QString共用空间 04/21 18:09
18F:→ wong0101: 了解 感谢各位大大的指导! 04/22 02:19