c++ - 执行参数未提供预期结果

标签 c++ linux c++11 c++14

我正在实现两个将充当 ALU 和 CPU 的程序,CPU 将从文件中读取输入作为 3 个参数(num、operator、num)并将这些参数传递给 ALU.exe,然后 ALU.exe 将计算并返回结果参数已传递但仍未返回所需的输出

注意:-我本来打算只发布有问题的部分,但上次我在这里发布问题时,评论要求提供完整代码

CPU.exe

#include <iostream>
#include <unistd.h>
#include <fcntl.h>
#include <stdio.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <string>
#include <fstream>
#include <stdlib.h>
using namespace std;


int main () {
ifstream obj;
const char *path = "/home/ALU.exe";
obj.open("sample.txt",ios::app);
string arg1,arg2;
string op;


while(
getline(obj,arg1,',') && getline(obj,op,',') && getline(obj,arg2,'\n')
) {
pid_t pid = fork();


if(pid==0) {
char* args[3];
char a1[arg1.size()+1];
char a2[arg2.size()+1];
char o[op.size()+1];
arg1.copy(a1,arg1.size()+1);
a1[arg1.size()]='\0';
arg2.copy(a2,arg2.size()+1);
a2[arg2.size()]='\0';
op.copy(o,op.size()+1);
o[op.size()]='\0';
args[1]=a1;
args[2]=o;
args[3]=a2;
//args[0]=arg1.c_str();
//args[1]=op.c_str();
//args[2]=arg2.c_str();
execv(path,args);
}

wait();
}
return 0;
}

将参数发送到 ALU.exe 的段

while(
getline(obj,arg1,',') && getline(obj,op,',') && getline(obj,arg2,'\n')
) {
pid_t pid = fork();


if(pid==0) {
char* args[3];
char a1[arg1.size()+1];
char a2[arg2.size()+1];
char o[op.size()+1];
arg1.copy(a1,arg1.size()+1);
a1[arg1.size()]='\0';
arg2.copy(a2,arg2.size()+1);
a2[arg2.size()]='\0';
op.copy(o,op.size()+1);
o[op.size()]='\0';
args[1]=a1;
args[2]=o;
args[3]=a2;
//args[0]=arg1.c_str();
//args[1]=op.c_str();
//args[2]=arg2.c_str();
execv(path,args);
}

wait();
}

下面是ALU.cpp的代码

ALU.cpp

#include <iostream>
#include <unistd.h>
#include <fcntl.h>
#include <stdio.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <string>
#include <stdlib.h>
using namespace std;

int Operation(int a,char* op,int b) {

char operand = *op;
if(operand == '+') {
return a+b;
}
if(operand == '-') {
return a-b;
}
if(operand == '/'){
return a/b;
}
if(operand == '*'){
return a*b;
}
else {
cout << "invalid" << endl;
return -999;
}
}
int main (int argc,char* argv[]) {

//if(argc!=3) {
//cout << "Exit" << endl;
//return -9999;
//}

for(int i=1;i<argc;i++) {
cout << "Arg " << i << ": " << argv[i] << endl;
}
int arg1,arg2;
char* op;
arg1= atoi(argv[1]);
arg2= atoi(argv[3]);
op = argv[2];
int result = Operation(arg1,op,arg2);
cout << "result: " << result << endl;
return result;

}

样本文件包含这些数据

3,+,6
12,-,4
3,*,10

但是得到的结果如下

 invalid
invalid
result: -999
result: -999
invalid
result: -999

我已经调试了好几天了,但仍然找不到解决问题的办法很抱歉,如果我的英语流利程度有问题,这让我很难理解,或者我一直在做一些被 stackoverflow 社区反对的事情,但我已经尽力写了一个问题,让每个人都牢记一切在这里告诉我

编辑:

尝试打印参数会导致错误,所以这可能是类型转换的问题?

当我尝试

cout << a1 << o << a2 << endl;

这是我收到的错误

3b��*c�����s
10�����p
*** Error in `12��-c�����s
4c�����p
*** Error in `3b��+c�����s
6c�����p
*** Error in `b���b��xd��-���*c��10���b��xd��S�b���b��xd��-���
*** Error in `c���b��xd��-���-c��4c���b��xd��S�c���b��xd��-���
*** Error in `./a.out': free(): invalid pointer: 0xbfb162b0 ***
./a.out': free(): invalid pointer: 0xbfb162b0 ***
b���b��xd��-���*c��10���b��xd��S�b���b��xd��-���
b���b��xd��-���*c��10���b��xd��S�b���b��xd��-���
*** Error in `*** Error in `./a.out': free(): invalid pointer: 0xbfb162b0 ***
./a.out': free(): invalid pointer: 0xbfb162b0 ***
======= Backtrace: =========
/lib/i386-linux-gnu/libc.so.6(+0x67377)[0xb7bf8377]
/lib/i386-linux-gnu/libc.so.6(+0x6d2f7)[0xb7bfe2f7]
/lib/i386-linux-gnu/libc.so.6(+0x6dc31)[0xb7bfec31]
/usr/lib/i386-linux-gnu/libstdc++.so.6(_ZdlPv+0x18)[0xb7dd2d88]
/usr/lib/i386-linux-gnu/libstdc++.so.6(_ZNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEED1Ev+0x25)[0xb7e6c985]
./a.out[0x8048f5a]
/lib/i386-linux-gnu/libc.so.6(__libc_start_main+0xf7)[0xb7ba9637]
./a.out[0x8048b11]
======= Memory map: ========
08048000-0804a000 r-xp 00000000 08:01 1052404    /home/f178082/a.out
0804a000-0804b000 r--p 00001000 08:01 1052404    /home/f178082/a.out
0804b000-0804c000 rw-p 00002000 08:01 1052404    /home/f178082/a.out
09621000-09646000 rw-p 00000000 00:00 0          [heap]
b7a00000-b7a21000 rw-p 00000000 00:00 0 
b7a21000-b7b00000 ---p 00000000 00:00 0 
b7b39000-b7b3c000 rw-p 00000000 00:00 0 
b7b3c000-b7b8f000 r-xp 00000000 08:01 393657     /lib/i386-linux-gnu/libm-2.23.so
b7b8f000-b7b90000 r--p 00052000 08:01 393657     /lib/i386-linux-gnu/libm-2.23.so
b7b90000-b7b91000 rw-p 00053000 08:01 393657     /lib/i386-linux-gnu/libm-2.23.so
b7b91000-b7d41000 r-xp 00000000 08:01 393587     /lib/i386-linux-gnu/libc-2.23.so
b7d41000-b7d43000 r--p 001af000 08:01 393587     /lib/i386-linux-gnu/libc-2.23.so
b7d43000-b7d44000 rw-p 001b1000 08:01 393587     /lib/i386-linux-gnu/libc-2.23.so
b7d44000-b7d47000 rw-p 00000000 00:00 0 
b7d47000-b7d63000 r-xp 00000000 08:01 393625     /lib/i386-linux-gnu/libgcc_s.so.1
b7d63000-b7d64000 rw-p 0001b000 08:01 393625     /lib/i386-linux-gnu/libgcc_s.so.1
b7d64000-b7ed1000 r-xp 00000000 08:01 785415     /usr/lib/i386-linux-gnu/libstdc++.so.6.0.21
b7ed1000-b7ed2000 ---p 0016d000 08:01 785415     /usr/lib/i386-linux-gnu/libstdc++.so.6.0.21
b7ed2000-b7ed7000 r--p 0016d000 08:01 785415     /usr/lib/i386-linux-gnu/libstdc++.so.6.0.21
b7ed7000-b7ed8000 rw-p 00172000 08:01 785415     /usr/lib/i386-linux-gnu/libstdc++.so.6.0.21
b7ed8000-b7edb000 rw-p 00000000 00:00 0 
b7ef0000-b7ef1000 rw-p 00000000 00:00 0 
b7ef1000-b7ef2000 rw-p 00000000 00:00 0 
b7ef2000-b7ef5000 r--p 00000000 00:00 0          [vvar]
b7ef5000-b7ef7000 r-xp 00000000 00:00 0          [vdso]
b7ef7000-b7f1a000 r-xp 00000000 08:01 393559     /lib/i386-linux-gnu/ld-2.23.so
b7f1a000-b7f1b000 r--p 00022000 08:01 393559     /lib/i386-linux-gnu/ld-2.23.so
b7f1b000-b7f1c000 rw-p 00023000 08:01 393559     /lib/i386-linux-gnu/ld-2.23.so
bfaf8000-bfb19000 rw-p 00000000 00:00 0          [stack]
======= Backtrace: =========
/lib/i386-linux-gnu/libc.so.6(+0x67377)[0xb7bf8377]
/lib/i386-linux-gnu/libc.so.6(+0x6d2f7)[0xb7bfe2f7]
/lib/i386-linux-gnu/libc.so.6(+0x6dc31)[0xb7bfec31]
/usr/lib/i386-linux-gnu/libstdc++.so.6(_ZdlPv+0x18)[0xb7dd2d88]
/usr/lib/i386-linux-gnu/libstdc++.so.6(_ZNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEED1Ev+0x25)[0xb7e6c985]
./a.out[0x8048f5a]
/lib/i386-linux-gnu/libc.so.6(__libc_start_main+0xf7)[0xb7ba9637]
./a.out[0x8048b11]
======= Memory map: ========
08048000-0804a000 r-xp 00000000 08:01 1052404    /home/f178082/a.out
0804a000-0804b000 r--p 00001000 08:01 1052404    /home/f178082/a.out
0804b000-0804c000 rw-p 00002000 08:01 1052404    /home/f178082/a.out
09621000-09646000 rw-p 00000000 00:00 0          [heap]
b7a00000-b7a21000 rw-p 00000000 00:00 0 
b7a21000-b7b00000 ---p 00000000 00:00 0 
b7b39000-b7b3c000 rw-p 00000000 00:00 0 
b7b3c000-b7b8f000 r-xp 00000000 08:01 393657     /lib/i386-linux-gnu/libm-2.23.so
b7b8f000-b7b90000 r--p 00052000 08:01 393657     /lib/i386-linux-gnu/libm-2.23.so
b7b90000-b7b91000 rw-p 00053000 08:01 393657     /lib/i386-linux-gnu/libm-2.23.so
b7b91000-b7d41000 r-xp 00000000 08:01 393587     /lib/i386-linux-gnu/libc-2.23.so
b7d41000-b7d43000 r--p 001af000 08:01 393587     /lib/i386-linux-gnu/libc-2.23.so
b7d43000-b7d44000 rw-p 001b1000 08:01 393587     /lib/i386-linux-gnu/libc-2.23.so
b7d44000-b7d47000 rw-p 00000000 00:00 0 
b7d47000-b7d63000 r-xp 00000000 08:01 393625     /lib/i386-linux-gnu/libgcc_s.so.1
b7d63000-b7d64000 rw-p 0001b000 08:01 393625     /lib/i386-linux-gnu/libgcc_s.so.1
b7d64000-b7ed1000 r-xp 00000000 08:01 785415     /usr/lib/i386-linux-gnu/libstdc++.so.6.0.21
b7ed1000-b7ed2000 ---p 0016d000 08:01 785415     /usr/lib/i386-linux-gnu/libstdc++.so.6.0.21
b7ed2000-b7ed7000 r--p 0016d000 08:01 785415     /usr/lib/i386-linux-gnu/libstdc++.so.6.0.21
b7ed7000-b7ed8000 rw-p 00172000 08:01 785415     /usr/lib/i386-linux-gnu/libstdc++.so.6.0.21
b7ed8000-b7edb000 rw-p 00000000 00:00 0 
b7ef0000-b7ef1000 rw-p 00000000 00:00 0 
b7ef1000-b7ef2000 rw-p 00000000 00:00 0 
b7ef2000-b7ef5000 r--p 00000000 00:00 0          [vvar]
b7ef5000-b7ef7000 r-xp 00000000 00:00 0          [vdso]
b7ef7000-b7f1a000 r-xp 00000000 08:01 393559     /lib/i386-linux-gnu/ld-2.23.so
b7f1a000-b7f1b000 r--p 00022000 08:01 393559     /lib/i386-linux-gnu/ld-2.23.so
b7f1b000-b7f1c000 rw-p 00023000 08:01 393559     /lib/i386-linux-gnu/ld-2.23.so
bfaf8000-bfb19000 rw-p 00000000 00:00 0          [stack]
======= Backtrace: =========
/lib/i386-linux-gnu/libc.so.6======= Backtrace: =========
/lib/i386-linux-gnu/libc.so.6(+0x67377)[0xb7bf8377]
/lib/i386-linux-gnu/libc.so.6(+0x67377)[0xb7bf8377]
/lib/i386-linux-gnu/libc.so.6(+0x6d2f7)[0xb7bfe2f7]
/lib/i386-linux-gnu/libc.so.6(+0x6d2f7)[0xb7bfe2f7]
/lib/i386-linux-gnu/libc.so.6(+0x6dc31)[0xb7bfec31]
(+0x6dc31)[0xb7bfec31]
/usr/lib/i386-linux-gnu/libstdc++.so.6(_ZdlPv+0x18)[0xb7dd2d88]
/usr/lib/i386-linux-gnu/libstdc++.so.6/usr/lib/i386-linux-gnu/libstdc++.so.6(_ZdlPv+0x18)[0xb7dd2d88]
/usr/lib/i386-linux-gnu/libstdc++.so.6(_ZNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEED1Ev+0x25)[0xb7e6c985]
./a.out[0x8048f5a]
/lib/i386-linux-gnu/libc.so.6(_ZNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEED1Ev+0x25)[0xb7e6c985]
./a.out[0x8048f5a]
/lib/i386-linux-gnu/libc.so.6(__libc_start_main+0xf7)[0xb7ba9637]
./a.out[0x8048b11]
======= Memory map: ========
08048000-0804a000 r-xp 00000000 08:01 1052404    /home/f178082/a.out
0804a000-0804b000 r--p 00001000 08:01 1052404    /home/f178082/a.out
0804b000-0804c000 rw-p 00002000 08:01 1052404    /home/f178082/a.out
09621000-09646000 rw-p 00000000 00:00 0          [heap]
b7a00000-b7a21000 rw-p 00000000 00:00 0 
b7a21000-b7b00000 ---p 00000000 00:00 0 
b7b39000-b7b3c000 rw-p 00000000 00:00 0 
b7b3c000-b7b8f000 r-xp 00000000 08:01 393657     /lib/i386-linux-gnu/libm-2.23.so
b7b8f000-b7b90000 r--p 00052000 08:01 393657     /lib/i386-linux-gnu/libm-2.23.so
b7b90000-b7b91000 rw-p 00053000 08:01 393657     /lib/i386-linux-gnu/libm-2.23.so
b7b91000-b7d41000 r-xp 00000000 08:01 393587     /lib/i386-linux-gnu/libc-2.23.so
b7d41000-b7d43000 r--p 001af000 08:01 393587     /lib/i386-linux-gnu/libc-2.23.so
b7d43000-b7d44000 rw-p 001b1000 08:01 393587     /lib/i386-linux-gnu/libc-2.23.so
b7d44000-b7d47000 rw-p 00000000 00:00 0 
b7d47000-b7d63000 r-xp 00000000 08:01 393625     /lib/i386-linux-gnu/libgcc_s.so.1
b7d63000-b7d64000 rw-p 0001b000 08:01 393625     /lib/i386-linux-gnu/libgcc_s.so.1
b7d64000-b7ed1000 r-xp 00000000 08:01 785415     /usr/lib/i386-linux-gnu/libstdc++.so.6.0.21
b7ed1000-b7ed2000 ---p 0016d000 08:01 785415     /usr/lib/i386-linux-gnu/libstdc++.so.6.0.21
b7ed2000-b7ed7000 r--p 0016d000 08:01 785415     /usr/lib/i386-linux-gnu/libstdc++.so.6.0.21
b7ed7000-b7ed8000 rw-p 00172000 08:01 785415     /usr/lib/i386-linux-gnu/libstdc++.so.6.0.21
b7ed8000-b7edb000 rw-p 00000000 00:00 0 
b7ef0000-b7ef1000 rw-p 00000000 00:00 0 
b7ef1000-b7ef2000 rw-p 00000000 00:00 0 
b7ef2000-b7ef5000 r--p 00000000 00:00 0          [vvar]
b7ef5000-b7ef7000 r-xp 00000000 00:00 0          [vdso]
b7ef7000-b7f1a000 r-xp 00000000 08:01 393559     /lib/i386-linux-gnu/ld-2.23.so
b7f1a000-b7f1b000 r--p 00022000 08:01 393559     /lib/i386-linux-gnu/ld-2.23.so
b7f1b000-b7f1c000 rw-p 00023000 08:01 393559     /lib/i386-linux-gnu/ld-2.23.so
bfaf8000-bfb19000 rw-p 00000000 00:00 0          [stack]

我在这里做错了什么?

最佳答案

您不应该传递 3 个参数,而是四个。请记住,第一个参数(argv[0],因为数组是从零开始的)应该是程序名称。而且您还必须以 NULL 终止数组。

所以你必须做:

const char *args[5];

args[0]=path;
args[1]=arg1.c_str();
args[2]=op.c_str();
args[3]=arg2.c_str();
args[4]=NULL;

编辑:

我也忘记了 execv() 是有问题的。它声明为 int execv(const char *pathname, char *const argv[]); 而不是 int execv(const char *pathname, const char *const argv[]); 所以这是可以使用指针转换的少数情况之一:

 execv(path, (char **)args);

或者将 args[] 放在一起并使用 execl():

 execl(path, path,  arg1.c_str(), op.c_str(), arg2.c_str(), NULL);

关于c++ - 执行参数未提供预期结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59342303/

相关文章:

c++11 - 是所有数据成员都初始化为 0 还是由自动调用的构造函数分配随机值?

c++ - 在只读场景中何时需要以空字符结尾的字符串?

c++ - Dlib。如何解决实时的优化约束?地标融合的想法?

c++ - 一次加载大块 csv 而不是使用 getline 的方法?

c++ - 迭代器有什么意义?

c++ - 将流绑定(bind)到自身

c++ - 有没有办法获取容器模板类型以将其与另一个 value_type 重用?

c - 加入任何终止的线程

linux - 安装 respinned/customized centos 时出错

linux - 列出第二个字母为 'c' 的文件 (Linux)