wiringPi 的分段错误
Segmentation fault with wiringPi
我对编码相当陌生,我一直在尝试编写一些东西来在按下连接到我的 RasPi 上的 GPIO 引脚的按钮时将占位符写入文本文档:
//Write date function//
void record() {
ofstream myFile;
myFile.open("report.txt");
myFile << "Input at SPAM \n";
myFile.close();
}
//myRead function//
void myRead(int i){
if((digitalRead(4) == HIGH) && (i<5)) {
record();
digitalWrite(14, HIGH);
delay(500);
digitalWrite(14, LOW);
++i;
delay(500);
myRead(i);
}
else{
if((digitalRead(4) != HIGH) && (i<5)){
myRead(i);
}
}
}
int main() {
wiringPiSetup();
pinMode(12, OUTPUT);
pinMode(14, OUTPUT);
pinMode(4, INPUT);
digitalWrite(12, HIGH);
digitalWrite(14, LOW);
myRead(1);
digitalWrite(14, HIGH);
delay(5000);
digitalWrite(14, LOW);
return 0;
}
代码编译时没有任何抱怨,但是如果我在没有 sudo
命令的终端中 运行 它,我会收到 "segmentation fault" 错误。
当我使用 sudo
命令 运行 它时,程序几乎立即启动然后结束。
供参考:
- 引脚 12 正在为面包板上的分压器供电。
- 引脚 4 应从该分频器获取输入。
- 每当引脚 4 上有输入时,引脚 14 会导致 LED 点亮。
每当我 运行 程序并非常快速地按下分压器上的按钮时,如果我按住按钮,LED 就会亮起。
我如何才能正确地将它传送到 运行 而不会在它开始时立即停止?
我认为 myRead
有几个可能的问题。
一个小的重写可以是:
void myRead(int i)
{
if((digitalRead(4) == HIGH) && (i<5)) {
record();
digitalWrite(14, HIGH);
delay(500);
digitalWrite(14, LOW);
++i;
delay(500);
myRead(i);
} else if((digitalRead(4) != HIGH) && (i<5)) {
myRead(i);
}
}
请注意,您有两次调用 digitalRead
-- 这可能会导致问题,因为第一个 return 与 HIGH
不同,第二个可能 return HIGH
,意思是两个条件都不成立。
您在备用分支中使用与原始调用相同的 i
调用 myRead
。如果 digitalRead
return 与 HIGH
不同的次数足够多,您的堆栈将很快填满并且您将遇到段错误。
我将提出一个不同的版本,应该相同(除非我有任何误解):
void myRead(int i)
{
// as long as i is less than 5
while (i < 5) {
// busy wait for digitalRead(4) to be HIGH
while (digitalRead(4) != HIGH);
// do the main thing
record();
digitalWrite(14, HIGH);
delay(500);
digitalWrite(14, LOW);
++i;
delay(500);
}
}
另请注意,这只是普通的 C,而不是 C++(好吧,从技术上讲,它是有效的 C++,但它没有使用 C++)
我对编码相当陌生,我一直在尝试编写一些东西来在按下连接到我的 RasPi 上的 GPIO 引脚的按钮时将占位符写入文本文档:
//Write date function//
void record() {
ofstream myFile;
myFile.open("report.txt");
myFile << "Input at SPAM \n";
myFile.close();
}
//myRead function//
void myRead(int i){
if((digitalRead(4) == HIGH) && (i<5)) {
record();
digitalWrite(14, HIGH);
delay(500);
digitalWrite(14, LOW);
++i;
delay(500);
myRead(i);
}
else{
if((digitalRead(4) != HIGH) && (i<5)){
myRead(i);
}
}
}
int main() {
wiringPiSetup();
pinMode(12, OUTPUT);
pinMode(14, OUTPUT);
pinMode(4, INPUT);
digitalWrite(12, HIGH);
digitalWrite(14, LOW);
myRead(1);
digitalWrite(14, HIGH);
delay(5000);
digitalWrite(14, LOW);
return 0;
}
代码编译时没有任何抱怨,但是如果我在没有 sudo
命令的终端中 运行 它,我会收到 "segmentation fault" 错误。
当我使用 sudo
命令 运行 它时,程序几乎立即启动然后结束。
供参考:
- 引脚 12 正在为面包板上的分压器供电。
- 引脚 4 应从该分频器获取输入。
- 每当引脚 4 上有输入时,引脚 14 会导致 LED 点亮。
每当我 运行 程序并非常快速地按下分压器上的按钮时,如果我按住按钮,LED 就会亮起。
我如何才能正确地将它传送到 运行 而不会在它开始时立即停止?
我认为 myRead
有几个可能的问题。
一个小的重写可以是:
void myRead(int i)
{
if((digitalRead(4) == HIGH) && (i<5)) {
record();
digitalWrite(14, HIGH);
delay(500);
digitalWrite(14, LOW);
++i;
delay(500);
myRead(i);
} else if((digitalRead(4) != HIGH) && (i<5)) {
myRead(i);
}
}
请注意,您有两次调用 digitalRead
-- 这可能会导致问题,因为第一个 return 与 HIGH
不同,第二个可能 return HIGH
,意思是两个条件都不成立。
您在备用分支中使用与原始调用相同的 i
调用 myRead
。如果 digitalRead
return 与 HIGH
不同的次数足够多,您的堆栈将很快填满并且您将遇到段错误。
我将提出一个不同的版本,应该相同(除非我有任何误解):
void myRead(int i)
{
// as long as i is less than 5
while (i < 5) {
// busy wait for digitalRead(4) to be HIGH
while (digitalRead(4) != HIGH);
// do the main thing
record();
digitalWrite(14, HIGH);
delay(500);
digitalWrite(14, LOW);
++i;
delay(500);
}
}
另请注意,这只是普通的 C,而不是 C++(好吧,从技术上讲,它是有效的 C++,但它没有使用 C++)