执行参数未提供预期结果

Exec arguments not providing expected results

本文关键字:结果 参数 执行      更新时间:2023-10-16

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

注意:-我打算只发布有问题的片段,但上次我在这里发布问题时,评论要求整个代码

中央处理器.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()]='';
arg2.copy(a2,arg2.size()+1);
a2[arg2.size()]='';
op.copy(o,op.size()+1);
o[op.size()]='';
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()]='';
arg2.copy(a2,arg2.size()+1);
a2[arg2.size()]='';
op.copy(o,op.size()+1);
o[op.size()]='';
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

铝.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

我已经调试了几天,但仍然找不到任何问题来解决我的问题,我已经搜索了以前的问题,在堆栈溢出上出现这样的问题,但仍然没有成功,这就是我在这里问这个问题的原因,我很抱歉我的英语流利度有问题,很难理解,或者我一直在做一些被堆栈溢出社区皱眉的事情,但我已经尽力写每个人都在这里告诉我一个牢记一切的问题

编辑:

尝试打印出参数会导致错误,所以这是类型转换的问题,那么也许?

当我尝试

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 个参数,而是传递 4 个参数。请记住,第一个参数(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);