Мой код выполняется в течение двух минут, затем выдает эту ошибку:
Неустранимая ошибка Python: невозможно восстановить после переполнения стека.
Текущий поток 0x000001d4 (сначала самый последний вызов):
Я использую wxpython и беру данные из последовательного порта ('COM9'), которые у меня бесконечные данные. Я использую wx.Timer
и list.append
.
Чтобы избежать переполнения стека, я удаляю свой список, используя таймер. В течение 2 минут я запускаю код, все хорошо. Но несмотря на то, что я удаляю список, а длина моего списка составляет всего 76, мое приложение зависает и не продолжается.
Может быть, мне стоит попробовать wxCallAfter
и wxCallLater
или «многопоточность и обработка» в wx, но в wx многопоточность и обработка не рекомендуются).
Или, может быть, я не должен использовать append.list
и удалить его позже? Если проблема из-за моей структуры данных, что я должен использовать вместо этого?
# -*- coding: utf-8 -*-
import wx
from gui import *
#import _pickle as pickle
import pickle
import serial
import matplotlib.pyplot as plt
import matplotlib.pyplot
import numpy as np
import matplotlib.animation as animation
from test.test_zipfile import StoredBadCrcTests
import time
print("0")
ser = serial.Serial('COM9',9600)
fig, ax= plt.subplots()
x=[]
y=[]
x1=[]
x2=[]
y1=[]
y2=[]
i=0
storage=[]
class selam ( MyFrame1 ):
print("1")
def __init__( self, parent ):
MyFrame1.__init__ ( self, parent)
print("here")
self.m_timer1 = wx.Timer()
self.m_timer1.SetOwner( self, 1 )
self.m_timer2 = wx.Timer()
self.m_timer2.SetOwner( self, 2 )
self.m_timer3 = wx.Timer()
self.m_timer3.SetOwner( self, 3 )
self.m_timer4 = wx.Timer()
self.m_timer4.SetOwner( self, 4 )
# Connect Events
self.Bind( wx.EVT_TIMER, self.timer1, id=1 )
self.Bind( wx.EVT_TIMER, self.timer2, id=2 )
self.Bind( wx.EVT_TIMER, self.timer3, id=3 )
self.Bind( wx.EVT_TIMER, self.timer4, id=4 )
def __del__( self ):
pass
def tgl1( self, event ):
if self.m_timer1.IsRunning():
self.m_timer1.Stop()
print("timer 1 stopped")
else:
print("tgl_timer 1 starting...")
self.m_timer1.Start( 1000 )
def tgl2( self, event ):
if self.m_timer2.IsRunning():
self.m_timer2.Stop()
plt.close()
print("timer 2 stopped")
else:
print("tgl_timer 2 starting...")
self.m_timer2.Start( 501 )
def tgl3( self, event ):
if self.m_timer3.IsRunning():
self.m_timer3.Stop()
plt.close()
print("timer 3 stopped")
else:
print("tgl_timer 3 starting...")
self.m_timer3.Start( 2000 )
def tgl4( self, event ):
if self.m_timer4.IsRunning():
self.m_timer4.Stop()
plt.close()
print("timer 4 stopped")
else:
print("tgl_timer 4 starting...")
self.m_timer4.Start( 1000 )
########## data and all code has to written inside of timer(1,2,3,4..)
def timer1( self, event ):
print("1")
for line in ser:
storage.append(line)
#===================================================================
# f1 = open('C:\\Users\\GCS-User\\Desktop\\obj_pi','wb')
# pickle.dump(line,f1)
#
# f2=open('C:\\Users\\GCS-User\\Desktop\\obj_pi','rb')
# print(pickle.load(f2))
#===================================================================
def timer2( self, event ):
print("22")
del storage[:]
def timer3( self, event ):
print("333")
def timer4( self, event ):
print("4444")
def sV_sat(i):
#print("a")
for line in storage:
print("b")
print("storage_len:",len(storage))
data = line.split(b",")
#print("data_0:",data[0])
if data[0] == b'$GNGGA':
print("c")
altitude=data[9]
timm=data[1]
tim=float(timm)
tim=tim+30000
hour = tim//10000
minute = (tim//100)%100
second = tim%100
zaman = hour*3600 + minute*60 + second
altitude=float(altitude)
x.append(zaman)
y.append(altitude)
ax.plot(x,y)
ani8 = animation.FuncAnimation(fig,sV_sat)
plt.show()
if __name__ == "__main__":
app = wx.App(0)
frame = selam(None)
frame.Show()
app.MainLoop()