Какова форма массива, 'удаляют'?

Вы можете использовать command=someFunction для кнопок проверки и кнопки отправки, а затем в someFunction() вам нужно написать, что вы хотите сделать, когда нажимаете эту кнопку.

Попробуйте:

from tkinter import *
from tkinter import Tk
from tkinter.filedialog import askopenfilename

win = Tk()

win.title("Spatialization of DSSAT model")

w = 160
h = 100

ws = win.winfo_screenwidth()
hs = win.winfo_screenheight()

x = (ws/2) - (w/2)
y = (hs/2) - (h/2)

win.geometry('%dx%d+%d+%d' % (w, h, x, y))

def forCheckbutton1():
    filename1 = askopenfilename()
    print(filename1)

def forCheckbutton2():
    filename2 = askopenfilename()
    print(filename2)

def forMuButton1():
    win.destroy()

def var_states():
    print("soil: %d, \nweather:%d" % (MyVar1.get(), MyVar2.get()))

MyLabel1 = Label(win, text="Select:")
MyLabel1.grid(row=0, column=0, sticky=W)

MyVar1 = IntVar()
MyVar2 = IntVar()

MyCheckbutton1 = Checkbutton(win, text="soil", variable=MyVar1, command=forCheckbutton1)
MyCheckbutton1.grid(row=1, column=0, sticky=W)
MyCheckbutton2 = Checkbutton(win, text="weather", variable=MyVar2, command=forCheckbutton2)
MyCheckbutton2.grid(row=2, column=0, sticky=W)

MyButton1 = Button(win, text="Submit", width=10, command=forMuButton1)
MyButton1.grid(row=3, column=0)

win.mainloop()

, и для отображения информации вы можете добавить кадр и показать нужную информацию в кадре.

17
задан Sam 10 August 2014 в 14:19
поделиться

5 ответов

Форма удаления в виде массива:

delete [] data;

Изменить: Но, как указывали другие, вы не должны вызывать delete для данных, определенных таким образом :

int data[5];

Вы должны вызывать его только тогда, когда вы выделяете память с помощью new следующим образом:

int *data = new int[5];
46
ответ дан 30 November 2019 в 10:06
поделиться

Вы либо хотите:

int *data = new int[5];
... // time passes, stuff happens to data[]
delete[] data;

, либо

int data[5];
... // time passes, stuff happens to data[]
// note no delete of data

Общее правило: применять удалить только к памяти, полученной из new . Если использовалась форма массива new , тогда вы должны использовать форму массива delete для сопоставления. Если использовалось размещение new , то вы либо вообще не вызываете delete , либо используете соответствующее размещение delete .

Поскольку переменная int data [5] - это статически распределенный массив, его нельзя передать ни в какой форме оператора delete .

18
ответ дан 30 November 2019 в 10:06
поделиться

Показанный код имеет массив либо в стеке, либо в инициализированной части сегмента данных, то есть вы не освобождаете его (что, как упоминалось другими, было бы "undefined поведение ".) Если бы он был в" бесплатном магазине ", вы бы сделали это с помощью delete [] data .

2
ответ дан 30 November 2019 в 10:06
поделиться

Так же, как RichieHindle сказал выше, когда вы хотите освободить пространство, динамически выделяемое для массива, указанного в data , вы должны поставить две скобки [] между зарезервированным словом удаляем и указатель на начало выделенного пространства. Поскольку data может указывать на один int в памяти, а также на первый элемент в массиве, это единственный способ сообщить компилятору, что вы хотите удалить весь фрагмент. памяти. Если вы не сделаете это должным образом, поведение будет «неопределенным» (Страуструп, Язык программирования C ++ ).

0
ответ дан 30 November 2019 в 10:06
поделиться

Как сказал другой, вы должны использовать векторную форму удаления:

void some_func(size_t n)
{
  int* data = new int[n];

  . . . // do stuff with the array

  delete [] data; // Explicitly free memory
}

Будьте очень осторожны, потому что некоторые компиляторы не предупреждают вас.

] Более того, очень редко возникает необходимость в использовании вектора new / delete. Подумайте, можно ли изменить ваш код для использования std :: vector:

void some_func(size_t n)
{
  std::vector<int> data(n);

  . . . // do stuff with the array

} // memory held by data will be freed here automatically

И если вы имеете дело с памятью в локальной области, подумайте об использовании STLSoft auto_buffer , который будет выделяться из внутреннего буфера (хранящегося в стеке как часть экземпляра), если это возможно, переходя в кучу, только если это невозможно:

void some_func(size_t n)
{
  stlsoft::auto_buffer<int, 10> data(n); // only allocates if n > 10

  . . . // do stuff with the array

} // memory held by data will be freed here automatically, if any was allocated

Прочтите подробнее об auto_buffer .

5
ответ дан 30 November 2019 в 10:06
поделиться
Другие вопросы по тегам:

Похожие вопросы: