常量 char* 的字符串构造函数更改常量 char* 的值?
String constructor of constant char* changes value of constant char*?
当前一期
const char* 的值似乎正在变为无意义的值。
错误代码示例
下面代码的目的是创建一个值为 basedir 的字符串。这个过程应该保持 basedir 的值不变;然而,它莫名其妙地发生了变化。
ProcessInfo get_process(int pid, const char* basedir) {
cout<<basedir<<endl;
string basedir_str=basedir;
cout<<basedir<<endl;
....}
当前输出
./proc/16224/task
▒▒v▒=+
const char* 到字符串赋值有什么问题?
如何设置Basedir
正在通过调用 "parent" 函数 get_all_processes.
分配变量 basedir
父函数
vector<ProcessInfo> get_all_processes(const char* basedir) {
DIR* dir;
struct dirent *entry;
vector<ProcessInfo> totalProcesses;
//check to see if basedir can be opened
if((dir =opendir(basedir))!=NULL){
while((entry = readdir(dir)) != NULL ){
int pid = atoi (entry->d_name);
if(pid <=0){
continue;
}
else{
ProcessInfo currentProcess = get_process(pid, basedir); //<--call to get_process
totalProcesses.push_back(currentProcess);
}
}
closedir(dir);
}
return totalProcesses;
}
调用父函数
myProcessInfo.threads=get_all_processes(threadList_fileName);
//threadList_filename='./proc/[pid]/task', in this case pid =16224
解决方案
消除临时 const char* threadList_fileName 并更改 get_all_processes 函数的参数。
myProcessInfo.threads=get_all_processes(("./proc/"+pid_str+"/task").c_str());
看起来变量 "basedir" 已经指向您不再拥有的内存。巧合的是,它仍然保留您分配给它的值。通过为字符串 "basedir_str" 分配内存,该内存将被其他数据重用和覆盖。所以你的问题出在函数 "get_process".
之外
如何分配"basedir"?
当前一期
const char* 的值似乎正在变为无意义的值。
错误代码示例
下面代码的目的是创建一个值为 basedir 的字符串。这个过程应该保持 basedir 的值不变;然而,它莫名其妙地发生了变化。
ProcessInfo get_process(int pid, const char* basedir) {
cout<<basedir<<endl;
string basedir_str=basedir;
cout<<basedir<<endl;
....}
当前输出
./proc/16224/task
▒▒v▒=+
const char* 到字符串赋值有什么问题?
如何设置Basedir
正在通过调用 "parent" 函数 get_all_processes.
分配变量 basedir父函数
vector<ProcessInfo> get_all_processes(const char* basedir) {
DIR* dir;
struct dirent *entry;
vector<ProcessInfo> totalProcesses;
//check to see if basedir can be opened
if((dir =opendir(basedir))!=NULL){
while((entry = readdir(dir)) != NULL ){
int pid = atoi (entry->d_name);
if(pid <=0){
continue;
}
else{
ProcessInfo currentProcess = get_process(pid, basedir); //<--call to get_process
totalProcesses.push_back(currentProcess);
}
}
closedir(dir);
}
return totalProcesses;
}
调用父函数
myProcessInfo.threads=get_all_processes(threadList_fileName);
//threadList_filename='./proc/[pid]/task', in this case pid =16224
解决方案
消除临时 const char* threadList_fileName 并更改 get_all_processes 函数的参数。
myProcessInfo.threads=get_all_processes(("./proc/"+pid_str+"/task").c_str());
看起来变量 "basedir" 已经指向您不再拥有的内存。巧合的是,它仍然保留您分配给它的值。通过为字符串 "basedir_str" 分配内存,该内存将被其他数据重用和覆盖。所以你的问题出在函数 "get_process".
之外如何分配"basedir"?