質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.49%
Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

2108閲覧

awaitを記述しないと非同期処理にならない理由

kyokio

総合スコア560

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2022/01/23 13:46

やりたいこと

Djangoで時間がかかる処理のリクエストがきた場合に、非同期処理を使用して処理の完了を待たずにレスポンスを返したいと思いました。
Django2.2を使用していましたが、Django3xでは非同期Viewに対応しているとのことなのでこのサイトを参考にして作ってみました。

urls.py/app/testviews.pyのtest関数が実行されるようになっています。

test.txtへの書き込みに20秒かかるとして、下記のように書きました。

views.py

1async def save(): 2 await asyncio.sleep(0.5) # 質問部分 3 with open('app/test.txt', encoding='utf-8', mode='w') as f: 4 print('書き込みを開始します') 5 times = 20 6 for i in range(times): 7 # プログレスバー 8 prog = 50*(i+1)//times 9 progress_bar = '#'*(prog) + ' '*(50-prog) 10 print("\r", f"[{progress_bar}] {i+1}", end="") 11 sleep(1) 12 f.write('test test') 13 print('\n書き込みを終了します') 14 f.close() 15 16 17async def test(request): 18 loop = asyncio.get_event_loop() 19 # loop.create_task(http_call_async()) 20 loop.create_task(save()) 21 context = { 22 'object': 'test' 23 } 24 print('start render') 25 return render(request, 'app/test.html', context) 26

質問内容

save関数にawaitを書かないと非同期処理にならない

上のコードで最初はawait asyncio.sleep(0.5)を書かずに実行していました。
すると、非同期処理にならずに、約20秒ほど待ってsave関数の処理が終わってからレスポンスが帰ってくるようになりました。

なぜ、await asyncio.sleep(0.5)を書かないと非同期処理にならないのでしょうか

await asyncio.sleep(0.5)をすることでCPUの空きが発生しそれを使用して他の処理を実行するようになるからで、これを書かないと他の処理が入るきっかけができない、という認識であっているのでしょうか。

補足情報(FW/ツールのバージョンなど)

MacOS
Djnaog==3.2

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

投稿2022/01/23 14:45

ppaul

総合スコア24666

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.49%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問