Не удается восстановить после переполнения стека в графическом интерфейсе - PullRequest
0 голосов
/ 08 января 2019

Мой код выполняется в течение двух минут, затем выдает эту ошибку:

Неустранимая ошибка 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()
...