「Programming Python 4th Edition」(O'REILLY) P.466に
以下のコードを実行すると
本来tmp.set(5)で6番目のRadiobuttonが選択された状態で初回表示されるはずだが
radio1()終了時にtmp.__del__()が呼ばれて
tmpに保持されている値がunsetされることにより
Radiobuttonの初回表示が狂う
(global行のコメントアウトをやめると正しく動作するようになる)
といったことが書いてあり、実際にコードを実行すると確かにそのようになるのですが
tmp.__del__()が呼び出される理由が理解できません。
__del__()が呼び出されるのはオブジェクトへの参照がなくなった時であって
tmpの値(IntVarオブジェクト)はRadiobuttonのコンストラクタに渡されており、Radiobuttonオブジェクト内部で参照され続けるので、__del__()が呼ばれることはないはずだ、と素人考えでは思えるのですが。
お分かりになる方が居らっしゃればどうか教えて下さい。
------------------------------------------------------------
from tkinter import *
root = Tk()
def radio1():
>>>>#global tmp
>>>>tmp = IntVar()
>>>>for i in range(10):
>>>>>>>>rad = Radiobutton(root, text=str(i), value=i, variable=tmp)
>>>>>>>>rad.pack(side=LEFT)
>>>>tmp.set(5)
radio1()
root.mainloop()
(>>>>は空白に読み替えてください)
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
tkinter のソースを読んでみるとよくわかると思いますが、
tkinter は Tcl/Tk という言語への橋渡しをしているに過ぎないんですよ。
Python で Tk() とか IntVar() とか書くたびに
それが Tcl の命令に変換されて実行されるだけなんです。
例えば tmp = IntVar() を実行すると、
Tcl 側で PY_VAR1 という変数が作られます。
次に tmp がスコープを抜けると参照がゼロになるので GC が発動します。
その時に tmp.__del__ が呼ばれて Tcl 側にある PY_VAR1 を破棄します。
つまり tmp というのは Tcl 側に存在する変数を管理するオブジェクトなわけです。
そのオブジェクトの破棄イコール Tcl 変数の破棄になっているので
表示がおかしくなるわけです。
ちなみに、
> Radiobuttonのコンストラクタに渡されており、
> Radiobuttonオブジェクト内部で参照され続けるので...
とありますが、Radiobuttonオブジェクトへの参照も
ゼロになっていることを忘れていませんか?
もっとも、Radiobuttonオブジェクトが破棄されても、
Tcl 側のラジオボタンを消すようにはなっていませんが。
No.1
- 回答日時:
結論だけ簡単に書くと、variable=tmp によって tmp の参照数は増えていないので
radio1() を抜けるところで tmp の寿命が尽きると判定されていて、結果 tmp.__del__ が
呼び出されるということになっています。
実装を事細かには書けないのですが、
>Radiobuttonオブジェクト内部で参照され続けるので
この前提が間違っているということです。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) エクセルVBAでオブジェクトが必要です 2 2022/09/10 16:37
- その他(プログラミング・Web制作) pythonにおける単方向リストの実装について 4 2022/07/13 12:34
- Excel(エクセル) エクセルのマクロについて教えてください。 1 2023/02/06 13:01
- その他(プログラミング・Web制作) pythonのグローバル変数 2 2022/11/25 18:02
- C言語・C++・C# 質問です 下記のコードを分かりやすく解説お願いします 初心者です #include ‹stdio.h 3 2022/05/26 22:03
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 2 2023/05/23 16:28
- その他(プログラミング・Web制作) python コードについて(初学者です) 3 2023/07/20 14:44
- Visual Basic(VBA) vba 重複データ合算 5 2023/07/05 18:55
- C言語・C++・C# C言語プログラム変更 2 2022/12/21 15:03
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 1 2023/01/23 09:24
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
worksheetFunctionクラスのVloo...
-
エクセルのVBAの標準モジュール...
-
実行時エラー 3265「要求された...
-
「Columns("A:C")」の列文字を...
-
エクセルマクロエラー「'Cells'...
-
Excelでフィルタをかけると警告...
-
VBAで Set wb = Sheets(1).Cop...
-
VBAで既に開いている別アプリケ...
-
ある文字列が全て数字であるか...
-
テキストボックス中の文字列の...
-
オブジェクトが見つかりません
-
ASP レコードセットしたオブジ...
-
[VBA]CDOメッセージ送信エラー
-
Cモジュールが落ちる現象について
-
上下の位置揃えについて
-
EXCEL VBA オートシェイプナン...
-
Visual Basic.NETのエラー("オ...
-
DelphiのTListについて
-
エクセルVBA 他ブックのシート...
-
VBScriptでファイルの日時順(降...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
worksheetFunctionクラスのVloo...
-
「Columns("A:C")」の列文字を...
-
実行時エラー 3265「要求された...
-
エクセルのVBAの標準モジュール...
-
VBAで既に開いている別アプリケ...
-
VBAで Set wb = Sheets(1).Cop...
-
テキストボックス中の文字列の...
-
PowerPointVBAでスライドマスタ...
-
エクセルマクロエラー「'Cells'...
-
VBAからPDFファイルにパスワー...
-
Excelでフィルタをかけると警告...
-
オブジェクトが見つかりません
-
ある文字列が全て数字であるか...
-
EXCEL VBA オートシェイプナン...
-
[VBA]CDOメッセージ送信エラー
-
VBAで作成するメール(開封確認...
-
VBAについてです。 初心者です...
-
VBA:オートシェイプの線の長...
-
VBで引数にDictionaryオブジェ...
-
AccessVBAで「dim dbs as datab...
おすすめ情報