{"id":326057,"date":"2021-07-06T15:00:53","date_gmt":"2021-07-06T15:00:53","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=326057"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=326057","title":{"rendered":"CancellationTokenSource \u0438 \u00ab\u0443\u0442\u0435\u0447\u043a\u0438 \u043f\u0430\u043c\u044f\u0442\u0438\u00bb"},"content":{"rendered":"\n<div class=\"post__text post__text_v2\" id=\"post-content-body\">\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/77f\/bf8\/29b\/77fbf829b7583edb1ea1b45991fc0a1f.png\" width=\"2338\" height=\"1318\"><figcaption><\/figcaption><\/figure>\n<p>\u0412\u0441\u0435\u043c \u043f\u0440\u0438\u0432\u0435\u0442!<\/p>\n<p>\u042f \u0440\u0430\u0431\u043e\u0442\u0430\u044e \u0432 \u0422\u0438\u043d\u044c\u043a\u043e\u0444\u0444, \u0432 \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u00ab\u0422\u0438\u043d\u044c\u043a\u043e\u0444\u0444 \u0422\u0435\u043b\u0435\u0444\u043e\u043d\u0438\u044f\u00bb. \u041d\u0430\u0448\u0430 \u043e\u0441\u043d\u043e\u0432\u043d\u0430\u044f \u0437\u0430\u0434\u0430\u0447\u0430 \u2014 \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u0430\u0446\u0438\u044f IP-\u0442\u0435\u043b\u0435\u0444\u043e\u043d\u0438\u0438 \u0432\u043d\u0443\u0442\u0440\u0438 \u043a\u043e\u043c\u043f\u0430\u043d\u0438\u0438 \u0438 \u0437\u0430 \u0435\u0435 \u043f\u0440\u0435\u0434\u0435\u043b\u0430\u043c\u0438. \u0412 \u0434\u0435\u043d\u044c \u0447\u0435\u0440\u0435\u0437 \u043d\u0430\u0441 \u043f\u0440\u043e\u0445\u043e\u0434\u0438\u0442 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u043e\u0432 \u0437\u0432\u043e\u043d\u043a\u043e\u0432. \u0412\u0441\u0435\u0439 \u044d\u0442\u043e\u0439 \u043a\u0443\u0445\u043d\u0435\u0439 \u0437\u0430\u043d\u0438\u043c\u0430\u044e\u0442\u0441\u044f \u043e\u043a\u043e\u043b\u043e 10 \u0441\u043b\u0443\u0436\u0431.&nbsp;<\/p>\n<p>\u0412 \u043a\u0430\u043a\u043e\u0439-\u0442\u043e \u043c\u043e\u043c\u0435\u043d\u0442 \u043c\u044b \u0441\u0442\u043e\u043b\u043a\u043d\u0443\u043b\u0438\u0441\u044c \u0441 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u043e\u0439: \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u0440\u0435\u043b\u0438\u0437\u0430 \u0441\u0435\u0440\u0432\u0438\u0441\u044b \u043e\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u044e\u0442\u0441\u044f \u043d\u0435\u043f\u0440\u0438\u043b\u0438\u0447\u043d\u043e \u0434\u043e\u043b\u0433\u043e. \u041d\u0430\u0441 \u044d\u0442\u043e \u043f\u0435\u0447\u0430\u043b\u0438\u043b\u043e, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043c\u044b \u043f\u0440\u0438\u043d\u044f\u043b\u0438 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u043f\u0440\u043e\u043a\u0438\u0434\u044b\u0432\u0430\u0442\u044c \u0432\u0435\u0437\u0434\u0435 \u0438 \u0432\u0441\u044e\u0434\u0443 CancellationToken.&nbsp;<\/p>\n<p>\u0427\u0443\u0442\u044c \u043f\u043e\u0437\u0436\u0435 \u0441\u0442\u043e\u043b\u043a\u043d\u0443\u043b\u0438\u0441\u044c \u0441 \u0434\u0440\u0443\u0433\u043e\u0439 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u043e\u0439: \u0432\u0441\u0435 \u043d\u0430\u0448\u0438 \u0441\u0435\u0440\u0432\u0438\u0441\u044b \u043d\u0430\u0447\u0430\u043b\u0438 \u043f\u043e\u0442\u0438\u0445\u043e\u043d\u044c\u043a\u0443 \u043f\u043e\u0436\u0438\u0440\u0430\u0442\u044c \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u0443\u044e \u043f\u0430\u043c\u044f\u0442\u044c. \u041d\u0435 \u0442\u0430\u043a \u0447\u0442\u043e\u0431\u044b \u0441\u043b\u0438\u0448\u043a\u043e\u043c \u0441\u0438\u043b\u044c\u043d\u043e \u0438 \u0431\u044b\u0441\u0442\u0440\u043e, \u043d\u043e \u0432 \u0446\u0435\u043b\u043e\u043c \u0432 \u043f\u0435\u0440\u0441\u043f\u0435\u043a\u0442\u0438\u0432\u0435 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u043d\u0435\u0434\u0435\u043b\u044c \u2014 \u0437\u0430\u043c\u0435\u0442\u043d\u043e.&nbsp;<\/p>\n<figure class=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/768\/984\/8cf\/7689848cf75af58061eef78f140dfbfb.png\" alt=\"\u041c\u0435\u0434\u043b\u0435\u043d\u043d\u043e\u0435 \u0438 \u0443\u0432\u0435\u0440\u0435\u043d\u043d\u043e\u0435 \u043f\u043e\u0436\u0438\u0440\u0430\u043d\u0438\u0435 \u043f\u0430\u043c\u044f\u0442\u0438 \u043d\u0430 \u043f\u0440\u043e\u0442\u044f\u0436\u0435\u043d\u0438\u0438 \u043d\u0435\u0434\u0435\u043b\u0438.\" title=\"\u041c\u0435\u0434\u043b\u0435\u043d\u043d\u043e\u0435 \u0438 \u0443\u0432\u0435\u0440\u0435\u043d\u043d\u043e\u0435 \u043f\u043e\u0436\u0438\u0440\u0430\u043d\u0438\u0435 \u043f\u0430\u043c\u044f\u0442\u0438 \u043d\u0430 \u043f\u0440\u043e\u0442\u044f\u0436\u0435\u043d\u0438\u0438 \u043d\u0435\u0434\u0435\u043b\u0438.\" width=\"1572\" height=\"563\"><figcaption>\u041c\u0435\u0434\u043b\u0435\u043d\u043d\u043e\u0435 \u0438 \u0443\u0432\u0435\u0440\u0435\u043d\u043d\u043e\u0435 \u043f\u043e\u0436\u0438\u0440\u0430\u043d\u0438\u0435 \u043f\u0430\u043c\u044f\u0442\u0438 \u043d\u0430 \u043f\u0440\u043e\u0442\u044f\u0436\u0435\u043d\u0438\u0438 \u043d\u0435\u0434\u0435\u043b\u0438.<\/figcaption><\/figure>\n<p>\u0412 \u043e\u0434\u0438\u043d \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u044b\u0439 \u0434\u0435\u043d\u044c \u0442\u0435\u0440\u043f\u0435\u043d\u0438\u0435 \u043b\u043e\u043f\u043d\u0443\u043b\u043e, \u0438 \u043c\u044b \u0441 \u0416\u0435\u043d\u0435\u0439 \u041c\u0438\u0448\u0443\u0441\u0442\u0438\u043d\u044b\u043c \u0438 <a href=\"https:\/\/habr.com\/ru\/users\/sansagol\/\">\u041a\u0438\u0440\u0438\u043b\u043b\u043e\u043c \u041c\u0430\u0440\u043a\u043e\u0432\u044b\u043c<\/a> \u043d\u0430\u043a\u0438\u043d\u0443\u043b\u0438\u0441\u044c \u043d\u0430 \u044d\u0442\u0443 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0443: \u0416\u0435\u043d\u044f \u0441 \u041a\u0438\u0440\u0438\u043b\u043b\u043e\u043c \u043b\u043e\u0432\u0438\u043b\u0438 \u0438 \u0430\u043d\u0430\u043b\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043b\u0438 \u0434\u0430\u043c\u043f\u044b, \u0430 \u044f \u0437\u0430\u043d\u0438\u043c\u0430\u043b\u0441\u044f \u043f\u043e\u0438\u0441\u043a\u043e\u043c \u043f\u0440\u0438\u0447\u0438\u043d \u0442\u0430\u043a\u043e\u0433\u043e \u043f\u043e\u0432\u0435\u0434\u0435\u043d\u0438\u044f.<\/p>\n<p>\u041e\u0441\u043e\u0431\u0435\u043d\u043d\u043e \u043e\u0442\u0447\u0435\u0442\u043b\u0438\u0432\u043e \u0432\u044b\u0434\u0435\u043b\u044f\u043b\u0441\u044f \u043e\u0434\u0438\u043d \u0441\u0435\u0440\u0432\u0438\u0441, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u043b\u0441\u044f \u043f\u043e \u0440\u0430\u0441\u043f\u0438\u0441\u0430\u043d\u0438\u044e \u0438 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u043b \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0443 \u0437\u0430\u043f\u0438\u0441\u0430\u043d\u043d\u044b\u0445 \u0437\u0432\u043e\u043d\u043a\u043e\u0432. \u0422\u0430\u043a \u043a\u0430\u043a \u0442\u0430\u043a\u0438\u0445 \u0437\u0430\u043f\u0438\u0441\u0435\u0439 \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u043c\u043d\u043e\u0433\u043e, \u0442\u043e \u0438\u0445 \u0430\u043d\u0430\u043b\u0438\u0437 \u0438 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u0437\u0430\u0442\u044f\u0433\u0438\u0432\u0430\u043b\u0438\u0441\u044c \u043d\u0430 \u0434\u043b\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0435 \u0432\u0440\u0435\u043c\u044f. \u0410 \u043f\u043e\u0441\u043b\u0435 \u0437\u0430\u0432\u0435\u0440\u0448\u0435\u043d\u0438\u044f \u043f\u0430\u043c\u044f\u0442\u044c \u043e\u0441\u0432\u043e\u0431\u043e\u0436\u0434\u0430\u043b\u0430\u0441\u044c. \u041f\u0440\u0438 \u044d\u0442\u043e\u043c \u043d\u0435\u043b\u044c\u0437\u044f \u0441\u043a\u0430\u0437\u0430\u0442\u044c, \u0447\u0442\u043e \u0432\u043d\u0443\u0442\u0440\u0438 \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u043b\u043e\u0441\u044c \u043a\u0430\u043a\u043e\u0435-\u0442\u043e \u0431\u043e\u043b\u044c\u0448\u043e\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b.<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/299\/464\/9a1\/2994649a1c37613f32847bf3ddaf8718.png\" alt=\"\u041f\u043e\u0442\u0440\u0435\u0431\u043b\u0435\u043d\u0438\u0435 \u043f\u0430\u043c\u044f\u0442\u0438 \u043f\u0440\u0438 \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0438 \u043e\u0434\u043d\u043e\u0439 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u0437\u0430\u043f\u0438\u0441\u0430\u043d\u043d\u044b\u0445 \u0437\u0432\u043e\u043d\u043a\u043e\u0432. GC \u0432\u044b\u0441\u0432\u043e\u0431\u043e\u0436\u0434\u0430\u0435\u0442 \u043e\u043a\u043e\u043b\u043e 6 \u0413\u0431 \u043f\u0430\u043c\u044f\u0442\u0438.\" title=\"\u041f\u043e\u0442\u0440\u0435\u0431\u043b\u0435\u043d\u0438\u0435 \u043f\u0430\u043c\u044f\u0442\u0438 \u043f\u0440\u0438 \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0438 \u043e\u0434\u043d\u043e\u0439 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u0437\u0430\u043f\u0438\u0441\u0430\u043d\u043d\u044b\u0445 \u0437\u0432\u043e\u043d\u043a\u043e\u0432. GC \u0432\u044b\u0441\u0432\u043e\u0431\u043e\u0436\u0434\u0430\u0435\u0442 \u043e\u043a\u043e\u043b\u043e 6 \u0413\u0431 \u043f\u0430\u043c\u044f\u0442\u0438.\" width=\"999\" height=\"670\"><figcaption>\u041f\u043e\u0442\u0440\u0435\u0431\u043b\u0435\u043d\u0438\u0435 \u043f\u0430\u043c\u044f\u0442\u0438 \u043f\u0440\u0438 \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0438 \u043e\u0434\u043d\u043e\u0439 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u0437\u0430\u043f\u0438\u0441\u0430\u043d\u043d\u044b\u0445 \u0437\u0432\u043e\u043d\u043a\u043e\u0432. GC \u0432\u044b\u0441\u0432\u043e\u0431\u043e\u0436\u0434\u0430\u0435\u0442 \u043e\u043a\u043e\u043b\u043e 6 \u0413\u0431 \u043f\u0430\u043c\u044f\u0442\u0438.<\/figcaption><\/figure>\n<p>\u0410 \u043f\u0430\u0440\u0443 \u043c\u0435\u0441\u044f\u0446\u0435\u0432 \u043d\u0430\u0437\u0430\u0434 \u043d\u0430\u0447\u0430\u043b\u0430\u0441\u044c \u0431\u0435\u0434\u0430: \u043e\u0434\u0438\u043d \u0438\u0437 \u0441\u0435\u0440\u0432\u0438\u0441\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u0442 \u043f\u043e \u0440\u0430\u0441\u043f\u0438\u0441\u0430\u043d\u0438\u044e \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0437\u0430\u0434\u0430\u0447\u0438, \u0432\u043d\u0435\u0437\u0430\u043f\u043d\u043e \u0441\u0442\u0430\u043b \u043d\u0435\u043f\u0440\u0438\u043b\u0438\u0447\u043d\u043e \u043f\u0440\u043e\u0436\u043e\u0440\u043b\u0438\u0432! \u041e\u043d \u043c\u043e\u0433 \u0437\u0430 \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u0439 \u043f\u0440\u043e\u043c\u0435\u0436\u0443\u0442\u043e\u043a \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0437\u0430\u0445\u0432\u0430\u0442\u0438\u0442\u044c 2\u20145 \u0413\u0411. \u0418 \u0442\u0443\u0442 \u0441\u0442\u0430\u043b\u043e \u044f\u0441\u043d\u043e, \u0447\u0442\u043e \u043f\u0440\u0438\u0448\u043b\u043e \u0432\u0440\u0435\u043c\u044f \u0441\u0442\u0440\u044f\u0445\u043d\u0443\u0442\u044c \u043f\u044b\u043b\u044c \u0441 dotMemory \u0438 WinDbg!&nbsp;<\/p>\n<p>\u0421\u043f\u043e\u0439\u043b\u0435\u0440 \u0434\u043b\u044f \u0442\u0435\u0445, \u043a\u043e\u043c\u0443 \u043b\u0435\u043d\u044c \u0447\u0438\u0442\u0430\u0442\u044c \u0438 \u0440\u0430\u0437\u0431\u0438\u0440\u0430\u0442\u044c\u0441\u044f: \u0432 CancellationTokenSource \u043d\u0435\u0442 \u0443\u0442\u0435\u0447\u0435\u043a \u2014 \u0435\u0441\u0442\u044c \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u0435\u0433\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f.<\/p>\n<p>\u041d\u0430\u0447\u0430\u043b\u0438 \u0441\u043d\u0438\u043c\u0430\u0442\u044c \u0434\u0430\u043c\u043f\u044b, \u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c. \u0412\u043e \u043c\u043d\u043e\u0433\u0438\u0445 \u0431\u044b\u043b\u0430 \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u0430\u044f \u043a\u0430\u0440\u0442\u0438\u043d\u0430: \u0434\u0430\u043c\u043f \u0432\u0435\u0441\u0438\u0442 \u043e\u043a\u043e\u043b\u043e 5 \u0413\u0411, \u0430 dotMemory \u0443\u043f\u043e\u0440\u043d\u043e \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442 \u0440\u0430\u0437\u043c\u0435\u0440 \u043a\u0443\u0447 \u0434\u043e 1\u20142 \u0413\u0411.  <\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/e74\/bd7\/27c\/e74bd727c53024df050c879635dd6093.png\" width=\"1294\" height=\"200\"><figcaption><\/figcaption><\/figure>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/6fb\/635\/292\/6fb6352920d94076107c900a3bae75b0.png\" width=\"1298\" height=\"211\"><figcaption><\/figcaption><\/figure>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d00\/46b\/b96\/d0046bb96c9b663040ba3b1a5281ce7f.png\" alt=\"\u0420\u0430\u0437\u043c\u0435\u0440 \u044d\u0442\u043e\u0433\u043e \u0434\u0430\u043c\u043f\u0430 \u043e\u043a\u043e\u043b\u043e 3,5 \u0413\u0431.\" title=\"\u0420\u0430\u0437\u043c\u0435\u0440 \u044d\u0442\u043e\u0433\u043e \u0434\u0430\u043c\u043f\u0430 \u043e\u043a\u043e\u043b\u043e 3,5 \u0413\u0431.\" width=\"1288\" height=\"216\"><figcaption>\u0420\u0430\u0437\u043c\u0435\u0440 \u044d\u0442\u043e\u0433\u043e \u0434\u0430\u043c\u043f\u0430 \u043e\u043a\u043e\u043b\u043e 3,5 \u0413\u0431.<\/figcaption><\/figure>\n<p>\u041d\u0443, \u0432\u0440\u043e\u0434\u0435 \u0432\u0441\u0435 \u043d\u043e\u0440\u043c\u0430\u043b\u044c\u043d\u043e, \u043d\u0438\u0447\u0435\u0433\u043e \u043a\u0440\u0438\u0442\u0438\u0447\u043d\u043e\u0433\u043e. \u041d\u043e \u0434\u0430\u043c\u043f-\u0442\u043e \u043e\u0433\u0440\u043e\u043c\u043d\u044b\u0439! \u0427\u0435\u043c \u0437\u0430\u043d\u044f\u0442\u0430 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u0430\u044f \u043f\u0430\u043c\u044f\u0442\u044c? \u0414\u0443\u043c\u0430\u043b\u0438, \u0447\u0442\u043e \u044d\u0442\u043e \u0441\u0435\u0440\u0432\u0435\u0440\u043d\u044b\u0439 \u0440\u0435\u0436\u0438\u043c \u0440\u0430\u0431\u043e\u0442\u044b GC (<a href=\"https:\/\/docs.microsoft.com\/ru-ru\/dotnet\/standard\/garbage-collection\/workstation-server-gc\"><u>\u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0435 \u0440\u0435\u0436\u0438\u043c\u043e\u0432<\/u><\/a>, <a href=\"https:\/\/docs.microsoft.com\/ru-ru\/dotnet\/core\/run-time-config\/garbage-collector#workstation-vs-server\"><u>\u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430<\/u><\/a>). \u041c\u0435\u043d\u044f\u043b\u0438, \u0436\u0434\u0430\u043b\u0438 \u2014 \u043d\u0435 \u043f\u043e\u043c\u043e\u0433\u0430\u0435\u0442.&nbsp;<\/p>\n<p>\u0416\u0435\u043d\u044f \u0443\u0436\u0435 \u0434\u043e\u043b\u0433\u043e\u0435 \u0432\u0440\u0435\u043c\u044f \u043d\u0430\u0431\u043b\u044e\u0434\u0430\u043b \u0437\u0430 \u043d\u0435\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u043e\u0439 \u043f\u0430\u043c\u044f\u0442\u044c\u044e \u0441\u0435\u0440\u0432\u0438\u0441\u043e\u0432, \u0438 \u0435\u0435 \u0440\u0430\u0437\u043c\u0435\u0440 \u043d\u0435 \u0434\u0430\u0432\u0430\u043b\u0438 \u0435\u043c\u0443 \u043f\u043e\u043a\u043e\u044f: \u043e\u043d \u043c\u043e\u0433 \u0434\u043e\u0441\u0442\u0438\u0433\u0430\u0442\u044c 8\u201410 \u0413\u0411. \u041f\u043e\u0447\u0435\u043c\u0443 \u043e\u043d\u0430 \u0442\u0430\u043a \u0440\u0430\u0441\u0442\u0435\u0442?<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/943\/559\/e36\/943559e36ceb4565965421e7d533bdd2.png\" alt=\"\u0420\u0430\u0437\u043c\u0435\u0440 \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u043e\u0439 \u0438 \u00ab\u043d\u0435 \u043e\u0447\u0435\u043d\u044c\u00bb \u043f\u0430\u043c\u044f\u0442\u0438.\" title=\"\u0420\u0430\u0437\u043c\u0435\u0440 \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u043e\u0439 \u0438 \u00ab\u043d\u0435 \u043e\u0447\u0435\u043d\u044c\u00bb \u043f\u0430\u043c\u044f\u0442\u0438.\" width=\"1159\" height=\"196\"><figcaption>\u0420\u0430\u0437\u043c\u0435\u0440 \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u043e\u0439 \u0438 \u00ab\u043d\u0435 \u043e\u0447\u0435\u043d\u044c\u00bb \u043f\u0430\u043c\u044f\u0442\u0438.<\/figcaption><\/figure>\n<p>\u0423\u0437\u043d\u0430\u0432 \u043e \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0435, \u043d\u0430\u0448 \u0440\u0443\u043a\u043e\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c \u043f\u043e\u0434\u0435\u043b\u0438\u043b\u0441\u044f \u043e\u043f\u044b\u0442\u043e\u043c: \u0432 \u0441\u043c\u0435\u0436\u043d\u043e\u043c \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u0431\u044b\u043b\u043e \u043f\u043e\u0434\u043e\u0431\u043d\u043e\u0435 \u2014 \u0442\u0430\u043c \u043d\u0435\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u0430\u044f \u043f\u0430\u043c\u044f\u0442\u044c \u0431\u044b\u043b\u0430 \u0437\u0430\u0431\u0438\u0442\u0430 \u0441\u0442\u0440\u043e\u043a\u0430\u043c\u0438 \u043e\u0442 \u0441\u0442\u043e\u0440\u043e\u043d\u043d\u0435\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438. \u0410 \u0447\u0442\u043e \u0436\u0435 \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0443 \u043d\u0430\u0441? \u041c\u044b \u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u0441\u044f \u043d\u0435\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u044b\u043c \u043a\u043b\u0438\u0435\u043d\u0442\u043e\u043c Oracle \u0438 \u0435\u0449\u0435 \u043e\u0434\u043d\u043e\u0439 \u0443\u0442\u0438\u043b\u0438\u0442\u043e\u0439, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0442\u043e\u0436\u0435 \u043c\u043e\u0436\u0435\u0442 \u043b\u0435\u0437\u0442\u044c \u0432 unmanged-\u043a\u043e\u0434. \u041d\u043e \u0441 \u043d\u0438\u043c\u0438 \u043d\u0438\u043a\u0430\u043a\u0438\u0445 \u043f\u0440\u043e\u0431\u043b\u0435\u043c \u043d\u0435 \u0431\u044b\u043b\u043e. \u041c\u044b \u0438\u0445 \u043d\u0435 \u043c\u0435\u043d\u044f\u043b\u0438, \u043d\u0435 \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u043b\u0438\u2026 \u0410 \u0432\u0434\u043e\u0431\u0430\u0432\u043e\u043a \u0435\u0449\u0435 \u0438 dotMemory \u0432\u043e\u0442 \u0442\u0430\u043a \u043f\u0440\u043e\u0441\u0442\u043e \u043d\u0435 \u0445\u043e\u0447\u0435\u0442 \u043d\u0430\u043c \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0442\u044c \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0435 \u043d\u0435\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u043e\u0439 \u043f\u0430\u043c\u044f\u0442\u0438.\u041d\u0430\u0441\u0442\u0430\u043b\u043e \u0432\u0440\u0435\u043c\u044f \u0434\u0440\u0443\u0433\u043e\u0433\u043e \u0433\u0435\u0440\u043e\u044f WinDbg. \u041d\u0435\u043c\u043d\u043e\u0433\u043e \u043f\u043e\u0431\u043e\u043b\u0442\u0430\u0432 \u0441 Google, \u044f \u043d\u0430\u0448\u0435\u043b \u0441\u0442\u0430\u0442\u0435\u0439\u043a\u0443: <a href=\"http:\/\/kate-butenko.blogspot.com\/2012\/07\/investigating-issues-with-unmanaged.html\"><u>Investigating issues with Unmanaged Memory. First steps<\/u><\/a>, \u0433\u0434\u0435 \u043f\u043e \u0448\u0430\u0433\u0430\u043c \u0440\u0430\u0441\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u0442\u0441\u044f, \u043a\u0430\u043a \u0437\u0430\u0433\u043b\u044f\u043d\u0443\u0442\u044c \u0432 \u0437\u0430\u0437\u0435\u0440\u043a\u0430\u043b\u044c\u0435 \u2014 \u0432 \u043d\u0435\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u0443\u044e \u043f\u0430\u043c\u044f\u0442\u044c. \u041f\u043e\u0447\u0438\u0442\u0430\u043b\u0438 \u0438 \u0441\u0434\u0435\u043b\u0430\u043b\u0438. \u041a\u0430\u0440\u0442\u0438\u043d\u0430 \u0443\u0434\u0438\u0432\u0438\u043b\u0430:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/871\/c8a\/f08\/871c8af089e63eada76344b326f59524.png\" width=\"579\" height=\"141\"><figcaption><\/figcaption><\/figure>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/391\/1df\/6f8\/3911df6f80a7d93ca7e6abe7a3873639.png\" width=\"576\" height=\"406\"><figcaption><\/figcaption><\/figure>\n<p>\u041a\u0430\u043a \u043f\u043e\u043d\u0438\u043c\u0430\u0435\u0442\u0435, \u0432\u043d\u0443\u0442\u0440\u0438 \u043e\u0448\u043c\u0435\u0442\u043a\u0438 SQL-\u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432, ORA-\u043e\u0448\u0438\u0431\u043e\u043a \u0438 \u0442\u0430\u043a \u0434\u0430\u043b\u0435\u0435. \u041d\u0430\u043f\u0440\u0430\u0448\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0434\u0438\u043d \u0432\u044b\u0432\u043e\u0434:<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/473\/0b7\/e78\/4730b7e7836b57179369966cbe3e11a7.jpg\" width=\"604\" height=\"404\"><figcaption><\/figcaption><\/figure>\n<p>\u041a\u0430\u0436\u0434\u044b\u0439 \u0440\u0430\u0437 \u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0442\u0430\u043a\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c \u043d\u0435\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u0443\u044e \u043f\u0430\u043c\u044f\u0442\u044c \u2014 \u043d\u0443 \u043e\u0447\u0435\u043d\u044c \u0434\u043e\u043b\u0433\u043e \u0438 \u043d\u0435\u0443\u0434\u043e\u0431\u043d\u043e. \u0422\u0443\u0442 \u0416\u0435\u043d\u044f \u0432\u0441\u043f\u043e\u043c\u043d\u0438\u043b \u043f\u0440\u043e \u043a\u043d\u0438\u0433\u0443 <a href=\"https:\/\/docs.microsoft.com\/en-us\/sysinternals\/resources\/windows-internals\"><u>Windows Internals<\/u><\/a>, \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u043d\u0435 \u0442\u0430\u043a \u0434\u0430\u0432\u043d\u043e \u043f\u0440\u043e\u0447\u0435\u043b, \u0433\u0434\u0435 \u0440\u0430\u0441\u0441\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f <a href=\"https:\/\/docs.microsoft.com\/en-us\/sysinternals\/downloads\/vmmap\"><u>\u043f\u0440\u043e VMMap<\/u><\/a>. VMMap \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0437\u0430\u0433\u043b\u044f\u043d\u0443\u0442\u044c \u0432 \u043d\u0435\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u0443\u044e \u043f\u0430\u043c\u044f\u0442\u044c \u043d\u0430 \u0436\u0438\u0432\u043e\u043c \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0435 \u0438 \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c, \u0447\u0442\u043e \u0437\u0430 \u0441\u0442\u0440\u043e\u043a\u0438 \u0442\u0430\u043c \u0445\u0440\u0430\u043d\u044f\u0442\u0441\u044f.<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/e23\/247\/436\/e2324743610a067f67edec22140d9da2.png\" alt=\"\u042d\u0442\u043e \u043f\u0440\u0438\u043c\u0435\u0440 \u0441 \u0438\u0441\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u043e\u0439 \u0432\u0435\u0440\u0441\u0438\u0438. \u041d\u043e \u043f\u043e\u0432\u0435\u0440\u044c\u0442\u0435: \u0432 \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u043a\u0443\u0447\u0435 \u0431\u044b\u043b\u043e \u043c\u043d\u043e\u0433\u043e \u0441\u0442\u0440\u043e\u043a, \u0441\u0432\u044f\u0437\u0430\u043d\u043d\u044b\u0445 \u0441 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u043d\u044b\u043c \u043a\u043e\u0434\u043e\u043c.\" title=\"\u042d\u0442\u043e \u043f\u0440\u0438\u043c\u0435\u0440 \u0441 \u0438\u0441\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u043e\u0439 \u0432\u0435\u0440\u0441\u0438\u0438. \u041d\u043e \u043f\u043e\u0432\u0435\u0440\u044c\u0442\u0435: \u0432 \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u043a\u0443\u0447\u0435 \u0431\u044b\u043b\u043e \u043c\u043d\u043e\u0433\u043e \u0441\u0442\u0440\u043e\u043a, \u0441\u0432\u044f\u0437\u0430\u043d\u043d\u044b\u0445 \u0441 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u043d\u044b\u043c \u043a\u043e\u0434\u043e\u043c.\" width=\"891\" height=\"399\"><figcaption>\u042d\u0442\u043e \u043f\u0440\u0438\u043c\u0435\u0440 \u0441 \u0438\u0441\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u043e\u0439 \u0432\u0435\u0440\u0441\u0438\u0438. \u041d\u043e \u043f\u043e\u0432\u0435\u0440\u044c\u0442\u0435: \u0432 \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u043a\u0443\u0447\u0435 \u0431\u044b\u043b\u043e \u043c\u043d\u043e\u0433\u043e \u0441\u0442\u0440\u043e\u043a, \u0441\u0432\u044f\u0437\u0430\u043d\u043d\u044b\u0445 \u0441 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u043d\u044b\u043c \u043a\u043e\u0434\u043e\u043c.<\/figcaption><\/figure>\n<p>\u041a\u0430\u043a \u044f \u0443\u0436\u0435 \u0433\u043e\u0432\u043e\u0440\u0438\u043b, \u0432\u043e \u0432\u0441\u0435\u0445 \u0441\u043d\u044f\u0442\u044b\u0445 \u0438\u0441\u0441\u043b\u0435\u0434\u0443\u0435\u043c\u044b\u0445 \u0441\u043d\u0438\u043c\u043a\u0430\u0445 \u0440\u0430\u0437\u043c\u0435\u0440 \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u044b\u0445 \u043a\u0443\u0447 \u0431\u044b\u043b \u043d\u0435\u0432\u0435\u043b\u0438\u043a. \u041d\u043e \u043e\u0442\u0432\u0435\u0442\u0430 \u043d\u0430 \u0432\u043e\u043f\u0440\u043e\u0441, \u043f\u043e\u0447\u0435\u043c\u0443 \u043d\u0435\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u0430\u044f \u043f\u0430\u043c\u044f\u0442\u044c \u043d\u0435 \u043e\u0441\u0432\u043e\u0431\u043e\u0436\u0434\u0430\u0435\u0442\u0441\u044f, \u043c\u044b \u0442\u0430\u043a \u0438 \u043d\u0435 \u043d\u0430\u0448\u043b\u0438. \u041e\u0434\u043d\u0430\u0436\u0434\u044b \u0443\u0434\u0430\u043b\u043e\u0441\u044c \u0441\u043d\u044f\u0442\u044c \u0434\u0430\u043c\u043f, \u0433\u0434\u0435 \u043f\u043e \u043a\u0443\u0447\u0435 \u0435\u0449\u0435 \u043d\u0435 \u0443\u0441\u043f\u0435\u043b \u043f\u0440\u043e\u0439\u0442\u0438\u0441\u044c GC.<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/2d8\/c81\/18f\/2d8c8118fa78c87c04401bf6ce202c4d.png\" width=\"1341\" height=\"317\"><figcaption><\/figcaption><\/figure>\n<p>\u0421\u0440\u0430\u0437\u0443 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043f\u0440\u0438\u0432\u043b\u0435\u043a\u043b\u0438 \u0434\u0432\u0435 \u043e\u0431\u043b\u0430\u0441\u0442\u0438 \u043f\u0430\u043c\u044f\u0442\u0438: \u0441\u043f\u0438\u0441\u043e\u043a \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 \u043d\u0430 600 \u041c\u0411 \u0438 17 \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440\u043e\u0432 CancellationTokenSource \u043d\u0430 3,5 \u0413\u0411.<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/93d\/09a\/a57\/93d09aa57e889df8ab4f37af6c794cec.png\" width=\"1355\" height=\"251\"><figcaption><\/figcaption><\/figure>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/117\/277\/fee\/117277fee54e20b4c79b8993ba9eed6a.png\" alt=\"\u041d\u0435\u0432\u0435\u0440\u043e\u044f\u0442\u043d\u044b\u0445 \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u0432 \u0442\u043e\u043a\u0435\u043d \u043e\u0442\u043c\u0435\u043d\u044b.\" title=\"\u041d\u0435\u0432\u0435\u0440\u043e\u044f\u0442\u043d\u044b\u0445 \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u0432 \u0442\u043e\u043a\u0435\u043d \u043e\u0442\u043c\u0435\u043d\u044b.\" width=\"1334\" height=\"386\"><figcaption>\u041d\u0435\u0432\u0435\u0440\u043e\u044f\u0442\u043d\u044b\u0445 \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u0432 \u0442\u043e\u043a\u0435\u043d \u043e\u0442\u043c\u0435\u043d\u044b.<\/figcaption><\/figure>\n<p>\u0427\u0442\u043e \u0436, \u0435\u0441\u0442\u044c \u0434\u0432\u0430 \u0432\u043e\u043f\u0440\u043e\u0441\u0430:<\/p>\n<ol>\n<li>\n<p>\u041f\u043e\u0447\u0435\u043c\u0443 \u0441\u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 \u0432 \u0441\u043f\u0438\u0441\u043a\u0435?  <\/p>\n<\/li>\n<li>\n<p>\u041f\u043e\u0447\u0435\u043c\u0443 \u0442\u0430\u043a\u043e\u0439 \u043e\u0433\u0440\u043e\u043c\u043d\u044b\u0439 CancellationTokenSource? <\/p>\n<\/li>\n<\/ol>\n<p>\u0421 \u043f\u0435\u0440\u0432\u043e\u0439 \u043e\u0431\u043b\u0430\u0441\u0442\u044c\u044e \u043f\u0430\u043c\u044f\u0442\u0438 \u0440\u0430\u0437\u043e\u0431\u0440\u0430\u043b\u0438\u0441\u044c \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u0431\u044b\u0441\u0442\u0440\u043e \u0438 \u043f\u0440\u043e\u0441\u0442\u043e, \u043d\u043e \u044d\u0442\u043e \u0431\u0443\u0434\u0435\u0442 \u043d\u0435\u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e \u0447\u0438\u0442\u0430\u0442\u0435\u043b\u044e, \u0442\u0430\u043a \u043a\u0430\u043a \u043a\u0430\u0441\u0430\u043b\u043e\u0441\u044c \u0431\u0438\u0437\u043d\u0435\u0441\u0430.<\/p>\n<p>\u0410 \u0432\u043e\u0442 \u0447\u0442\u043e \u043a\u0430\u0441\u0430\u0435\u0442\u0441\u044f \u0432\u0442\u043e\u0440\u043e\u0439 \u2014 \u0442\u0443\u0442 \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u0442\u0441\u044f \u0441\u0430\u043c\u043e\u0435 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e\u0435. \u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u043f\u043e\u043f\u0440\u043e\u0431\u0443\u0435\u043c \u0440\u0430\u0437\u043e\u0431\u0440\u0430\u0442\u044c\u0441\u044f, \u0447\u0442\u043e \u0436\u0435 \u0445\u0440\u0430\u043d\u0438\u0442 CancellationTokenSource \u0438 \u043a\u0430\u043a \u044d\u0442\u043e \u0442\u0443\u0434\u0430 \u043f\u043e\u043f\u0430\u0434\u0430\u0435\u0442? \u0418 \u043d\u0430\u0447\u043d\u0435\u043c, \u043a\u0430\u043a \u0438 \u043f\u043e\u043b\u0430\u0433\u0430\u0435\u0442\u0441\u044f, \u0441 \u0442\u0435\u043e\u0440\u0438\u0438.<\/p>\n<p><a href=\"https:\/\/docs.microsoft.com\/ru-ru\/dotnet\/api\/system.threading.cancellationtokensource\">CancellationTokenSource <\/a>\u2013 \u044d\u0442\u043e<\/p>\n<blockquote>\n<p>Signals to a CancellationToken that it should be canceled.  <\/p>\n<\/blockquote>\n<p>\u0415\u0441\u043b\u0438 \u0433\u043e\u0432\u043e\u0440\u0438\u0442\u044c \u043f\u0440\u043e\u0441\u0442\u044b\u043c \u044f\u0437\u044b\u043a\u043e\u043c, \u0442\u043e \u044d\u0442\u0430 \u0448\u0442\u0443\u043a\u0430 \u0441\u043e\u0437\u0434\u0430\u0435\u0442 <a href=\"https:\/\/docs.microsoft.com\/en-us\/dotnet\/api\/system.threading.cancellationtoken?view=net-5.0\"><u>CancellationToken<\/u><\/a>, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043c\u043e\u0436\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0434\u043b\u044f \u043e\u0442\u043c\u0435\u043d\u044b \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u0438. \u041e\u0431\u044b\u0447\u043d\u043e \u043c\u044b \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0442\u043e\u043a\u0435\u043d\u0430 \u043e\u0442\u043c\u0435\u043d\u044b, \u0438 \u0435\u0441\u043b\u0438 \u043e\u043d \u043e\u0442\u043c\u0435\u043d\u0435\u043d, \u0442\u043e \u043f\u0440\u0435\u0440\u044b\u0432\u0430\u0435\u043c \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u0438\u043b\u0438 \u043a\u0438\u0434\u0430\u0435\u043c \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435. \u0421\u0430\u043c \u0442\u043e\u043a\u0435\u043d \u043f\u0435\u0440\u0435\u0432\u0435\u0441\u0442\u0438 \u0432 \u043e\u0442\u043c\u0435\u043d\u0451\u043d\u043d\u043e\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u043c\u043e\u0436\u0435\u0442 \u0435\u0433\u043e \u0440\u043e\u0434\u0438\u0442\u0435\u043b\u044c (Source). \u0412\u0441\u0435 \u043f\u0440\u043e\u0441\u0442\u043e.&nbsp;<\/p>\n<p>\u041d\u043e \u043a\u0430\u043a \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u044d\u0442\u0430 \u0441\u0432\u044f\u0437\u043a\u0430? \u041f\u043e\u0447\u0435\u043c\u0443 \u0432 \u0438\u0442\u043e\u0433\u0435 \u0443 \u043d\u0430\u0441 \u043e\u0434\u0438\u043d CancellationTokenSource \u0437\u0430\u043d\u044f\u043b \u0431\u043e\u043b\u0435\u0435 3 \u0413\u0411? \u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u0437\u0430\u0433\u043b\u044f\u043d\u0435\u043c \u0432\u043d\u0443\u0442\u0440\u044c, \u0447\u0442\u043e \u0436\u0435 \u0442\u0430\u043c \u0442\u0430\u043a\u043e\u0435 \u0445\u0440\u0430\u043d\u0438\u0442\u0441\u044f?<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/05f\/10e\/1ac\/05f10e1ac4936eef2e022b47a268fe62.png\" width=\"1317\" height=\"458\"><figcaption><\/figcaption><\/figure>\n<p>\u0412 \u0441\u0430\u043c\u043e\u043c Source \u0445\u0440\u0430\u043d\u0438\u0442\u0441\u044f \u043c\u0430\u0441\u0441\u0438\u0432 <a href=\"https:\/\/referencesource.microsoft.com\/#mscorlib\/system\/threading\/CancellationTokenSource.cs,33e870abd2d82e74,references\"><u>CancellationCallbackInfo<\/u><\/a> \u0441 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0435\u0439 \u043e \u043a\u0430\u043a\u043e\u043c-\u0442\u043e \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0438, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0432\u044b\u0437\u0432\u0430\u0442\u044c \u043f\u0440\u0438 \u0441\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u043d\u0438\u0438 \u043e\u0442\u043c\u0435\u043d\u044b. \u041e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u043e\u0431\u044a\u0435\u043a\u0442, \u0434\u043b\u044f \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u043d\u0443\u0436\u043d\u043e \u0432\u044b\u0437\u0432\u0430\u0442\u044c \u043c\u0435\u0442\u043e\u0434, \u2014 \u044d\u0442\u043e\u2026 OracleCommand. \u0415\u0441\u043b\u0438 \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0432\u0441\u0435 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435 \u043e\u0431\u044a\u0435\u043a\u0442\u044b \u043c\u0430\u0441\u0441\u0438\u0432\u0430, \u0442\u043e \u0432\u0441\u0435 \u043e\u043d\u0438 \u0432\u044b\u0433\u043b\u044f\u0434\u044f\u0442 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e. \u0410 \u0447\u0442\u043e \u043b\u0435\u0436\u0438\u0442 \u0432\u043e \u0432\u0442\u043e\u0440\u043e\u043c \u043f\u043e \u0432\u0435\u043b\u0438\u0447\u0438\u043d\u0435 CancellationTokenSource?<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/5a0\/9d6\/308\/5a09d6308b4e5b708dc126240cbc386a.png\" width=\"1345\" height=\"583\"><figcaption><\/figcaption><\/figure>\n<p>\u0412\u0441\u0435 \u0442\u043e \u0436\u0435 \u0441\u0430\u043c\u043e\u0435, \u0442\u043e\u043b\u044c\u043a\u043e \u0437\u0430\u043f\u0440\u043e\u0441 \u0434\u0440\u0443\u0433\u043e\u0439. \u0422\u0435\u043f\u0435\u0440\u044c \u043e\u0441\u0442\u0430\u043b\u043e\u0441\u044c \u043f\u043e\u043d\u044f\u0442\u044c, \u043a\u0430\u043a \u043a\u0430\u043a\u043e\u0439-\u0442\u043e OracleCommand, \u0441 \u043a\u043e\u0442\u043e\u0440\u044b\u043c \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u043d\u0438\u043a\u0442\u043e \u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442, \u043f\u043e\u043f\u0430\u0434\u0430\u0435\u0442 \u0432 <\/p>\n<pre><code>m_registeredCallbacksLists -&gt; CancellationCallbackInfo -&gt; StateForCallback \u2013&gt; _target<\/code><\/pre>\n<p>\u0412\u0440\u044f\u0434 \u043b\u0438 \u0435\u0441\u0442\u044c \u043a\u0430\u043a\u0430\u044f-\u0442\u043e \u043c\u0430\u0433\u0438\u044f, \u043d\u043e \u043f\u043e\u043a\u0430 \u043d\u0435\u043f\u043e\u043d\u044f\u0442\u043d\u043e. \u042f \u0440\u0435\u0448\u0438\u043b \u043d\u0430\u0447\u0430\u0442\u044c \u0441 \u0438\u0441\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u043d\u0438\u044f \u0438\u0441\u0445\u043e\u0434\u043d\u0438\u043a\u043e\u0432 CancellationTokenSource, \u0430 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e \u2014 \u043d\u0430\u0439\u0442\u0438 \u043c\u0435\u0441\u0442\u043e, \u0433\u0434\u0435 \u0441\u043e\u0437\u0434\u0430\u0435\u0442\u0441\u044f \u044d\u0442\u043e\u0442 \u0441\u0430\u043c\u044b\u0439 CancellationCallbackInfo \u0438 StateForCallback. \u041a\u0441\u0442\u0430\u0442\u0438, StateForCallback \u2014 \u044d\u0442\u043e \u0434\u0435\u043b\u0435\u0433\u0430\u0442, \u043a\u0430\u043a \u0432\u0438\u0434\u043d\u043e \u0438\u0437 \u0434\u0432\u0443\u0445 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0438\u0445 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0439, \u0430 \u0437\u043d\u0430\u0447\u0438\u0442, _target \u2014 \u044d\u0442\u043e \u043a\u0430\u043a\u043e\u0435-\u0442\u043e \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0435\u0435 \u043f\u043e\u043b\u0435, \u0433\u0434\u0435 \u0445\u0440\u0430\u043d\u0438\u0442\u0441\u044f \u043e\u0431\u044a\u0435\u043a\u0442, \u043c\u0435\u0442\u043e\u0434 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u0438 \u00ab\u0441\u043e\u0445\u0440\u0430\u043d\u0435\u043d\u00bb \u0432 \u0434\u0435\u043b\u0435\u0433\u0430\u0442\u0435. \u041f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f, \u0447\u0442\u043e \u0433\u0434\u0435-\u0442\u043e \u043a\u0430\u043a\u043e\u0439-\u0442\u043e \u043c\u0435\u0442\u043e\u0434 \u0438\u0437 OracleCommand \u043f\u0435\u0440\u0435\u0434\u0430\u0435\u0442\u0441\u044f \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0434\u0435\u043b\u0435\u0433\u0430\u0442\u0430. \u0418\u0449\u0435\u043c, \u0433\u0434\u0435 \u0441\u043e\u0437\u0434\u0430\u0435\u0442\u0441\u044f CancellationCallbackInfo \u0438 StateForCallback. \u041e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c \u2014 \u0432 CancellationTokenSource.InternalRegister.<\/p>\n<p>\u0421\u0430\u043c \u043c\u0435\u0442\u043e\u0434 InternalRegister \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0438\u0437 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u043f\u0435\u0440\u0435\u0433\u0440\u0443\u0437\u043e\u043a CancellationToken.Register. \u0421\u043e\u0433\u043b\u0430\u0441\u043d\u043e <a href=\"https:\/\/docs.microsoft.com\/en-us\/dotnet\/api\/System.Threading.CancellationToken.Register?view=netframework-4.7.2\"><u>\u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438<\/u><\/a>, \u044d\u0442\u043e\u0442 \u043c\u0435\u0442\u043e\u0434 \u043f\u0440\u0435\u0434\u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d \u0434\u043b\u044f:<\/p>\n<blockquote>\n<p>Registers a delegate that will be called when this CancellationToken is canceled.<\/p>\n<\/blockquote>\n<p>\u0421 \u044d\u0442\u0438\u043c \u0432\u0441\u0435 \u044f\u0441\u043d\u043e, \u043d\u043e \u0433\u0434\u0435 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0430\u0446\u0438\u044f? \u041e\u0442\u0432\u0435\u0442 \u043d\u0430 \u044d\u0442\u043e\u0442 \u0432\u043e\u043f\u0440\u043e\u0441 \u0440\u0435\u0448\u0438\u043b \u0438\u0441\u043a\u0430\u0442\u044c \u0432 \u043b\u043e\u0431 \u2014 \u043f\u0440\u044f\u043c\u044b\u043c\u0438 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0430\u043c\u0438 \u043f\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f\u043c \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u043c\u044b\u0445 \u043c\u0435\u0442\u043e\u0434\u043e\u0432, \u043a\u0443\u0434\u0430 \u043f\u0435\u0440\u0435\u0434\u0430\u0435\u0442\u0441\u044f CancellationToken. \u041c\u043e\u0439 \u043f\u043e\u0438\u0441\u043a \u043d\u0430\u0447\u0430\u043b\u0441\u044f \u0441 \u043f\u0435\u0440\u0432\u043e\u0433\u043e \u043c\u0435\u0442\u043e\u0434\u0430, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0432\u044b\u0445\u043e\u0434\u0438\u0442 \u0437\u0430 \u043f\u0440\u0435\u0434\u0435\u043b\u044b \u043d\u0430\u0448\u0435\u0433\u043e \u043a\u043e\u0434\u0430:<\/p>\n<pre><code class=\"cs\">System.Data.Entity.QueryableExtensions.ToListAsync(query, cancellationToken.Value).<\/code><\/pre>\n<p>\u0414\u0430\u043b\u0435\u0435 \u0441\u043b\u0435\u0434\u0443\u0435\u0442 \u0441\u043a\u0443\u0447\u043d\u043e\u0435 \u00ab\u043f\u0440\u043e\u0442\u044b\u043a\u0438\u0432\u0430\u043d\u0438\u0435\u00bb \u043f\u043e \u0432\u044b\u0437\u043e\u0432\u0430\u043c. \u0421\u0440\u0430\u0437\u0443 \u043f\u0435\u0440\u0435\u0439\u0434\u0443 \u043a \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e\u043c\u0443. \u0412 \u043a\u0430\u043a\u043e\u0439-\u0442\u043e \u043c\u043e\u043c\u0435\u043d\u0442 IDE \u0432\u044b\u0434\u0430\u043b\u0430 \u0441\u043f\u0438\u0441\u043e\u043a \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0439 \u043c\u0435\u0442\u043e\u0434\u0430, \u043d\u043e Oracle \u0432\u043d\u0443\u0442\u0440\u0438 \u043d\u0435 \u0431\u044b\u043b\u043e.  <\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d4b\/adf\/d73\/d4badfd733dd8404f4dafda28c4c6526.png\" width=\"974\" height=\"251\"><figcaption><\/figcaption><\/figure>\n<p>\u041d\u0430\u043f\u043e\u043c\u043d\u044e: \u0443 \u043d\u0430\u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043d\u0435\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u044b\u0439 \u043a\u043b\u0438\u0435\u043d\u0442 \u0441 \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u043e\u0439 \u043e\u0431\u0435\u0440\u0442\u043a\u043e\u0439. \u0412 \u0441\u043f\u0438\u0441\u043a\u0435 \u043d\u0438\u0447\u0435\u0433\u043e \u043f\u043e\u0445\u043e\u0436\u0435\u0433\u043e \u043d\u0430 \u0441\u043b\u043e\u0432\u043e Oracle \u043d\u0435\u0442, \u043d\u0443 \u0434\u0430 \u043b\u0430\u0434\u043d\u043e. \u041f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u043c, \u043a\u0430\u043a \u0441\u0434\u0435\u043b\u0430\u043d\u043e \u0443 \u0434\u0440\u0443\u0433\u0438\u0445 \u2014 \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0432 Postgre-\u043a\u043b\u0438\u0435\u043d\u0442\u0435:<\/p>\n<pre><code class=\"cs\">public override Task&lt;bool&gt; ReadAsync(CancellationToken cancellationToken) {     CheckClosed();      if (cancellationToken.IsCancellationRequested)         return Task.FromCanceled&lt;bool&gt;(cancellationToken);      var fastRead = TryFastRead();     if (fastRead.HasValue)         return fastRead.Value ? PGUtil.TrueTask : PGUtil.FalseTask;      using (NoSynchronizationContextScope.Enter())         return Read(true); }<\/code><\/pre>\n<p>\u0427\u0442\u043e, \u043d\u0435\u0443\u0436\u0435\u043b\u0438 \u043a\u043e\u043d\u0435\u0446? \u041d\u043e \u0432\u0435\u0434\u044c \u043e\u0442\u0432\u0435\u0442\u0430 \u043d\u0430 \u0432\u043e\u043f\u0440\u043e\u0441, \u043a\u0430\u043a \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0430\u0446\u0438\u044f, \u044f \u043d\u0435 \u043d\u0430\u0448\u0435\u043b. \u0420\u0435\u0448\u0438\u043b \u043f\u043e\u0438\u0441\u043a\u0430\u0442\u044c \u0432\u044b\u0437\u043e\u0432 \u043c\u0435\u0442\u043e\u0434\u0430 Register \u0432\u043e \u0432\u0441\u0435\u0445 \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b\u0445 \u0441\u0438\u043c\u0432\u043e\u043b\u0430\u0445 \u0438 \u0438\u0441\u0445\u043e\u0434\u043d\u0438\u043a\u0430\u0445 \u0432 \u043f\u0440\u043e\u0435\u043a\u0442\u0435. \u0418\u2026 \u041a\u0430\u0436\u0435\u0442\u0441\u044f, \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u043e\u0441\u044c.<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/b13\/3dc\/21f\/b133dc21f0736979097efee065eab255.png\" alt=\"\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u044b \u043f\u043e\u0438\u0441\u043a\u0430 \u043f\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u0443 \u0432\u044b\u0437\u043e\u0432\u0430 \u043c\u0435\u0442\u043e\u0434\u0430 \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0430\u0446\u0438\u0438.\" title=\"\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u044b \u043f\u043e\u0438\u0441\u043a\u0430 \u043f\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u0443 \u0432\u044b\u0437\u043e\u0432\u0430 \u043c\u0435\u0442\u043e\u0434\u0430 \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0430\u0446\u0438\u0438.\" width=\"566\" height=\"247\"><figcaption>\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u044b \u043f\u043e\u0438\u0441\u043a\u0430 \u043f\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u0443 \u0432\u044b\u0437\u043e\u0432\u0430 \u043c\u0435\u0442\u043e\u0434\u0430 \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0430\u0446\u0438\u0438.<\/figcaption><\/figure>\n<p>Oracle-\u043a\u043b\u0438\u0435\u043d\u0442\u0430 \u044f \u0432\u0441\u0435 \u0440\u0430\u0432\u043d\u043e \u043d\u0435 \u043d\u0430\u0448\u0435\u043b, \u043d\u043e \u043d\u0430\u0448\u0435\u043b \u043e\u0447\u0435\u043d\u044c \u043f\u043e\u0445\u043e\u0436\u0435\u0435 \u0432 Postgre. \u0421\u043a\u043e\u0440\u0435\u0435 \u0436\u0435 \u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c, \u0447\u0442\u043e \u0442\u0430\u043c \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442:<\/p>\n<pre><code class=\"cs\">async ValueTask&lt;NpgsqlDataReader&gt; ExecuteReaderAsync(CommandBehavior behavior, bool async, CancellationToken cancellationToken) {     var connector = CheckReadyAndGetConnector();     connector.StartUserAction(this);     try     {         using (cancellationToken.Register(cmd =&gt; ((NpgsqlCommand)cmd!).Cancel(), this))         {             ValidateParameters(connector.TypeMapper);              switch (IsExplicitlyPrepared)             {             case true:                 Debug.Assert(_connectorPreparedOn != null);                 if (_connectorPreparedOn != connector)                 {                     \/\/ The command was prepared, but since then the connect .......<\/code><\/pre>\n<p>\u041c\u0435\u0442\u043e\u0434 \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u0431\u043e\u043b\u044c\u0448\u043e\u0439, \u043d\u043e \u0442\u043e\u043a\u0435\u043d \u043e\u0442\u043c\u0435\u043d\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u0432 \u043e\u0434\u043d\u043e\u043c \u043c\u0435\u0441\u0442\u0435 \u2014 \u0432 \u0441\u0430\u043c\u043e\u043c \u043d\u0430\u0447\u0430\u043b\u0435. \u0422\u043e \u0435\u0441\u0442\u044c \u043c\u044b \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0438\u0440\u0443\u0435\u043c \u043c\u0435\u0442\u043e\u0434 \u043e\u0442\u043c\u0435\u043d\u044b \u00ab\u043a\u043e\u043c\u0430\u043d\u0434\u044b\u00bb. \u0417\u043d\u0430\u0447\u0438\u0442, \u043d\u0435\u0447\u0442\u043e \u043f\u043e\u0434\u043e\u0431\u043d\u043e\u0435 \u0434\u043e\u043b\u0436\u043d\u043e \u0431\u044b\u0442\u044c \u0438 \u0432 Oracle-\u043a\u043b\u0438\u0435\u043d\u0442\u0435. \u041d\u043e \u043f\u043e\u0438\u0441\u043a \u043d\u0435 \u0434\u0430\u0432\u0430\u043b \u043d\u0438\u043a\u0430\u043a\u043e\u0439 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0438.&nbsp;<\/p>\n<p>\u0412\u044b\u0445\u043e\u0434 \u043e\u0434\u0438\u043d \u2014 \u0434\u0435\u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u044f. \u041f\u043e\u0441\u043b\u0435 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u043a\u043b\u0438\u043a\u043e\u0432 \u043f\u043e\u043b\u0443\u0447\u0438\u043b \u00ab\u0438\u0441\u0445\u043e\u0434\u043d\u044b\u0439\u00bb \u043a\u043e\u0434 \u043d\u0430 C#. \u041d\u043e \u0432\u043e\u0442 \u043e\u043f\u044f\u0442\u044c \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430: \u0432\u043d\u0443\u0442\u0440\u0438 \u2014 \u043d\u0438 \u0441\u043b\u043e\u0432\u0430 \u043d\u0438 \u043f\u0440\u043e Task, \u043d\u0438 \u043f\u0440\u043e Async, \u043d\u0438 \u043f\u0440\u043e CancellationToken. \u0422\u043e \u0435\u0441\u0442\u044c \u043a\u043b\u0438\u0435\u043d\u0442 \u043e\u043a\u0430\u0437\u0430\u043b\u0441\u044f \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u043e \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u043c (\u0432\u043e\u0442 \u044d\u0442\u043e \u043e\u0442\u043a\u0440\u044b\u0442\u0438\u0435). \u041e\u0434\u043d\u0430\u043a\u043e, \u0435\u0441\u043b\u0438 \u0432\u043d\u0438\u043c\u0430\u0442\u0435\u043b\u044c\u043d\u0435\u0435 \u043f\u043e\u0438\u0441\u043a\u0430\u0442\u044c, \u0441\u043b\u043e\u0432\u043e Cancel \u0432\u0441\u0435-\u0442\u0430\u043a\u0438 \u0432\u0441\u0442\u0440\u0435\u0447\u0430\u0435\u0442\u0441\u044f:<\/p>\n<pre><code class=\"cs\">public override void Cancel() {     int errCode = 0;        if (ConfigBaseClass.m_TraceLevel != 0)         OraTrace.Trace(1U, \" (ENTRY) OracleCommand::Cancel()\\n\");          if (this.m_connection == null)         throw new InvalidOperationException();        this.CheckConStatus();     try     { .......<\/code><\/pre>\n<p>\u0415\u0449\u0435 \u043f\u0430\u0440\u0430 \u043a\u043b\u0438\u043a\u043e\u0432 \u043f\u0440\u0438\u0432\u043e\u0434\u0438\u0442 \u043d\u0430\u0441 \u0432 \u0431\u0430\u0437\u043e\u0432\u044b\u0439 \u043a\u043b\u0430\u0441\u0441 DbCommand \u0438 \u0432 \u043c\u0435\u0442\u043e\u0434 ExecuteDbDataReaderAsync:  <\/p>\n<pre><code class=\"cs\">\/\/\/ \u0411\u043e\u043b\u044c\u0448\u043e\u0439 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b\u0439 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u0439 protected virtual Task&lt;DbDataReader&gt; ExecuteDbDataReaderAsync(     CommandBehavior behavior,     CancellationToken cancellationToken) {     if (cancellationToken.IsCancellationRequested)         return ADP.CreatedTaskWithCancellation&lt;DbDataReader&gt;();      CancellationTokenRegistration tokenRegistration = new CancellationTokenRegistration();      if (cancellationToken.CanBeCanceled)         tokenRegistration = cancellationToken.Register(new Action(this.CancelIgnoreFailure));      try     {         return Task.FromResult&lt;DbDataReader&gt;(this.ExecuteReader(behavior));     }     catch (Exception ex)     {         tokenRegistration.Dispose();         return ADP.CreatedTaskWithException&lt;DbDataReader&gt;(ex);     } }<\/code><\/pre>\n<p>\u0418 \u0432\u043e\u0442 \u043e\u043d\u0430 \u2014 \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0430\u0446\u0438\u044f!<\/p>\n<pre><code class=\"cs\">tokenRegistration = cancellationToken.Register(new Action(this.CancelIgnoreFailure));<\/code><\/pre>\n<p>\u041d\u043e \u043f\u043e\u0447\u0435\u043c\u0443 \u044f \u043d\u0435 \u043f\u043e\u043f\u0430\u043b \u0441\u044e\u0434\u0430 \u0432 \u0441\u0430\u043c\u043e\u043c \u043d\u0430\u0447\u0430\u043b\u0435? \u041a\u0430\u043a\u043e\u0439 \u0436\u0435 \u0432\u0441\u0435-\u0442\u0430\u043a\u0438 \u0441\u0442\u0435\u043a \u0432\u044b\u0437\u043e\u0432\u0430? \u0422\u043e\u0447\u043a\u0438 \u043e\u0441\u0442\u0430\u043d\u043e\u0432\u0430 \u0438 IDE \u043d\u0430\u043c \u0432 \u043f\u043e\u043c\u043e\u0449\u044c. \u0412\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u044d\u0442\u043e \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0442\u0430\u043a:  <\/p>\n<details class=\"spoiler\">\n<summary>\u0414\u043b\u0438\u043d\u043d\u044b\u0439 stack trace<\/summary>\n<div class=\"spoiler__content\">\n<pre><code class=\"cs\">IDbAsyncEnumerableExtensions.ToListAsync&lt;ObjectDao&gt;() async IDbAsyncEnumerableExtensions.ForEachAsync&lt;ObjectDao&gt;() LazyAsyncEnumerator&lt;ObjectDao&gt;.MoveNextAsync() LazyAsyncEnumerator&lt;ObjectDao&gt;.FirstMoveNextAsync() AsyncTaskMethodBuilder&lt;bool&gt;.Start&lt;System.Data.Entity.Internal.LazyAsyncEnumerator&lt;ObjectDao&gt;.&lt;FirstMoveNextAsync&gt;d__9&gt;() LazyAsyncEnumerator&lt;ObjectDao&gt;.&lt;FirstMoveNextAsync&gt;d__9.MoveNext() ObjectQuery&lt;ObjectDao&gt;.&lt;System.Data.Entity.Infrastructure.IDbAsyncEnumerable&lt;T&gt;.GetAsyncEnumerator&gt;b__32_0() ObjectQuery&lt;ObjectDao&gt;.GetResultsAsync() ObjectQuery&lt;ObjectDao&gt;.GetResultsAsync() AsyncTaskMethodBuilder&lt;ObjectResult&lt;ObjectDao&gt;&gt;.Start&lt;System.Data.Entity.Core.Objects.ObjectQuery&lt;ObjectDao&gt;.&lt;GetResultsAsync&gt;d__43&gt;() ObjectQuery&lt;ObjectDao&gt;.&lt;GetResultsAsync&gt;d__43.MoveNext() DefaultExecutionStrategy.ExecuteAsync&lt;System.Data.Entity.Core.Objects.ObjectResult&lt;ObjectDao&gt;&gt;() ObjectQuery&lt;ObjectDao&gt;.&lt;&gt;c__DisplayClass43_0.&lt;GetResultsAsync&gt;b__0() ObjectContext.ExecuteInTransactionAsync&lt;System.Data.Entity.Core.Objects.ObjectResult&lt;ObjectDao&gt;&gt;() AsyncTaskMethodBuilder&lt;ObjectResult&lt;ObjectDao&gt;&gt;.Start&lt;System.Data.Entity.Core.Objects.ObjectContext.&lt;ExecuteInTransactionAsync&gt;d__156&lt;System.Data.Entity.Core.Objects.ObjectResult&lt;ObjectDao&gt;&gt;&gt;() ObjectContext.&lt;ExecuteInTransactionAsync&gt;d__156&lt;ObjectResult&lt;ObjectDao&gt;&gt;.MoveNext() ObjectQuery&lt;ObjectDao&gt;.&lt;&gt;c__DisplayClass43_0.&lt;GetResultsAsync&gt;b__1() ObjectQueryExecutionPlan.ExecuteAsync&lt;ObjectDao&gt;() AsyncTaskMethodBuilder&lt;ObjectResult&lt;ObjectDao&gt;&gt;.Start&lt;System.Data.Entity.Core.Objects.Internal.ObjectQueryExecutionPlan.&lt;ExecuteAsync&gt;d__10&lt;ObjectDao&gt;&gt;() ObjectQueryExecutionPlan.&lt;ExecuteAsync&gt;d__10&lt;ObjectDao&gt;.MoveNext() EntityCommandDefinition.ExecuteStoreCommandsAsync() AsyncTaskMethodBuilder&lt;DbDataReader&gt;.Start&lt;System.Data.Entity.Core.EntityClient.Internal.EntityCommandDefinition.&lt;ExecuteStoreCommandsAsync&gt;d__26&gt;() EntityCommandDefinition.&lt;ExecuteStoreCommandsAsync&gt;d__26.MoveNext() DbCommand.ExecuteReaderAsync() InterceptableDbCommand.ExecuteDbDataReaderAsync() DbCommandDispatcher.ReaderAsync() InternalDispatcher&lt;IDbCommandInterceptor&gt;.DispatchAsync&lt;System.Data.Common.DbCommand, System.Data.Entity.Infrastructure.Interception.DbCommandInterceptionContext&lt;System.Data.Common.DbDataReader&gt;, System.Data.Common.DbDataReader&gt;() DbCommandDispatcher.&lt;&gt;c.&lt;ReaderAsync&gt;b__9_0() DbCommand.ExecuteReaderAsync() DbCommand.ExecuteDbDataReaderAsync() CancellationToken.Register()<\/code><\/pre>\n<\/div>\n<\/details>\n<p>\u0414\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u0434\u0430\u043b\u0435\u043a\u043e \u0438 \u043d\u0435\u044f\u0432\u043d\u043e. \u0413\u043b\u0430\u0432\u043d\u043e\u0435, \u0447\u0442\u043e \u043c\u044b \u0440\u0430\u0437\u043e\u0431\u0440\u0430\u043b\u0438\u0441\u044c!  <\/p>\n<h2>\u0412\u044b\u0432\u043e\u0434\u044b<\/h2>\n<ol>\n<li>\n<p>\u041f\u0440\u043e\u0432\u0435\u0440\u044f\u0442\u044c, \u043e\u0442\u043c\u0435\u043d\u0435\u043d \u043b\u0438 CancellationToken, \u0438 \u043a\u0438\u0434\u0430\u0442\u044c \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u0438\u043b\u0438 \u043a\u0430\u043a\u0438\u043c-\u0442\u043e \u043e\u0431\u0440\u0430\u0437\u043e\u043c \u0437\u0430\u0432\u0435\u0440\u0448\u0430\u0442\u044c \u0446\u0438\u043a\u043b.<\/p>\n<\/li>\n<li>\n<p>\u0420\u0435\u0433\u0438\u0441\u0442\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0441\u0432\u043e\u0439 \u043c\u0435\u0442\u043e\u0434 \u043e\u0442\u043c\u0435\u043d\u044b \u0438\u043b\u0438 \u0437\u0430\u0432\u0435\u0440\u0448\u0435\u043d\u0438\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0432 CancellationToken. \u0420\u0435\u0433\u0438\u0441\u0442\u0440\u0430\u0446\u0438\u044f \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0447\u0435\u0440\u0435\u0437 \u043f\u0435\u0440\u0435\u0434\u0430\u0447\u0443 \u0434\u0435\u043b\u0435\u0433\u0430\u0442\u0430, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u0432 \u0441\u0435\u0431\u0435 \u0441\u0441\u044b\u043b\u043a\u0443 \u043d\u0430 \u043e\u0431\u044a\u0435\u043a\u0442.<\/p>\n<\/li>\n<\/ol>\n<p>\u0412 \u043d\u0430\u0448\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u0441\u044f \u0432\u0442\u043e\u0440\u043e\u0439 \u0441\u043f\u043e\u0441\u043e\u0431. \u0412 \u0441\u0430\u043c\u043e\u043c \u043e\u0431\u044a\u0435\u043a\u0442\u0435 OracleCommand \u0445\u0440\u0430\u043d\u0438\u0442\u0441\u044f SQL-\u0437\u0430\u043f\u0440\u043e\u0441 \u0438 \u043e\u0442\u0432\u0435\u0442. \u0414\u0435\u0442\u0430\u043b\u044c\u043d\u043e \u0440\u0430\u0431\u043e\u0442\u0443 \u043d\u0435\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u043e\u0433\u043e \u043a\u043b\u0438\u0435\u043d\u0442\u0430 \u044f \u043d\u0435 \u0438\u0437\u0443\u0447\u0430\u043b, \u043d\u043e \u043d\u0430\u0432\u0435\u0440\u043d\u044f\u043a\u0430 \u0432\u044b\u0434\u0435\u043b\u044f\u0435\u0442\u0441\u044f \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0443\u0447\u0430\u0441\u0442\u043e\u043a \u043f\u0430\u043c\u044f\u0442\u0438 \u043f\u043e\u0434 \u043e\u0442\u0432\u0435\u0442 \u0441\u0435\u0440\u0432\u0435\u0440\u0430 \u0411\u0414. \u0421\u0445\u0435\u043c\u0430 \u0440\u0430\u0431\u043e\u0442\u044b \u0442\u0430\u043a\u0430\u044f:<\/p>\n<ol>\n<li>\n<p>\u0421\u043e\u0437\u0434\u0430\u0435\u043c CancellationTokenSource.<\/p>\n<\/li>\n<li>\n<p>\u041d\u0430\u0447\u0438\u043d\u0430\u0435\u043c \u0446\u0438\u043a\u043b \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u0437\u0430\u043f\u0438\u0441\u0435\u0439 \u0437\u0432\u043e\u043d\u043a\u043e\u0432.<\/p>\n<ol>\n<li>\n<p>\u0421\u043e\u0437\u0434\u0430\u0435\u043c OracleCommand \u0441 \u043d\u043e\u0432\u044b\u043c \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u043c.<\/p>\n<\/li>\n<li>\n<p>\u041f\u0435\u0440\u0435\u0434\u0430\u0435\u043c CancellationToken OracleCommand \u043f\u0440\u0438 \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0438 \u043e\u0447\u0435\u0440\u0435\u0434\u043d\u043e\u0433\u043e \u0437\u0430\u043f\u0440\u043e\u0441\u0430.<\/p>\n<\/li>\n<li>\n<p>OracleCommand \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0438\u0440\u0443\u0435\u0442 \u0441\u0432\u043e\u0439 \u043c\u0435\u0442\u043e\u0434 Cancel() \u0432 CancellationToken, \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u044f \u0441\u0441\u044b\u043b\u043a\u0443 \u043d\u0430 \u0441\u0435\u0431\u044f \u0432 \u0434\u0435\u043b\u0435\u0433\u0430\u0442\u0435.  <\/p>\n<\/li>\n<li>\n<p>\u0412\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442\u0441\u044f \u0437\u0430\u043f\u0440\u043e\u0441, \u0432\u044b\u0434\u0435\u043b\u044f\u0435\u0442\u0441\u044f \u043f\u0430\u043c\u044f\u0442\u044c \u043f\u043e\u0434 \u043e\u0442\u0432\u0435\u0442.  <\/p>\n<\/li>\n<li>\n<p>\u0412\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442\u0441\u044f \u043f\u043e\u043b\u0435\u0437\u043d\u0430\u044f \u043d\u0430\u0433\u0440\u0443\u0437\u043a\u0430 \u0434\u043b\u044f \u043e\u0447\u0435\u0440\u0435\u0434\u043d\u043e\u0439 \u0437\u0430\u043f\u0438\u0441\u0438.  <\/p>\n<\/li>\n<\/ol>\n<\/li>\n<li>\n<p>\u0427\u0435\u0440\u0435\u0437 N \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439 \u0437\u0430\u0432\u0435\u0440\u0448\u0430\u0435\u043c \u0446\u0438\u043a\u043b.  <\/p>\n<\/li>\n<li>\n<p>\u0417\u0430\u0432\u0435\u0440\u0448\u0430\u0435\u043c \u043f\u0440\u043e\u0446\u0435\u0441\u0441 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438.  <\/p>\n<\/li>\n<li>\n<p>\u0412\u044b\u0437\u044b\u0432\u0430\u0435\u043c \u0437\u0430\u0432\u0435\u0440\u0448\u0435\u043d\u0438\u0435 CancellationTokenSource.  <\/p>\n<\/li>\n<li>\n<p>\u0412\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043e\u0442\u043c\u0435\u043d\u0430 \u0434\u043b\u044f <strong>\u041a\u0410\u0416\u0414\u041e\u0419<\/strong> \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0430\u0446\u0438\u0438 OracleCommand.  <\/p>\n<\/li>\n<\/ol>\n<p>\u0418\u043b\u0438 \u0432\u043e\u0442 \u0435\u0449\u0435 \u043f\u0440\u0438\u043c\u0435\u0440 \u00ab\u0431\u0435\u0441\u043a\u043e\u043d\u0435\u0447\u043d\u043e\u0433\u043e\u00bb \u0446\u0438\u043a\u043b\u0430, \u0433\u0434\u0435 \u043a\u0430\u0436\u0434\u044b\u0435 15 \u0441\u0435\u043a\u0443\u043d\u0434 \u0438\u0437 \u0411\u0414 \u0434\u043e\u0441\u0442\u0430\u044e\u0442\u0441\u044f \u0437\u0430\u043f\u0438\u0441\u0438 \u0438 \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u044e\u0442\u0441\u044f \u043d\u0430 \u0430\u043a\u0442\u0443\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u044c:  <\/p>\n<pre><code class=\"cs\">private async Task UpdateRuleAsync(CancellationToken ct) {     do     {     \tif (ct.IsCancellationRequested)     \t{     \t\treturn;     \t}     \t\/\/\u0412\u044b\u0431\u0438\u0440\u0430\u0435\u043c \u0438\u0437 \u0411\u0414 \u0432\u0441\u0435 \u043f\u0440\u0430\u0432\u0438\u043b\u0430 \u043f\u043e \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u044e \u0441\u0435\u0440\u0432\u0438\u0441\u0430 (5-10 \u0437\u0430\u043f\u0438\u0441\u0435\u0439).     \tvar daos = await _repository.FindAllAsync(x =&gt; x.ServiceName.Equals(_serviceName, StringComparison.OrdinalIgnoreCase), innerCts.Token).ConfigureAwait(false);     \tvar rules = daos.Select(x =&gt; new ManualRuleDto(x)).ToArray();      \t\/\/\u0415\u0441\u043b\u0438 \u043f\u0440\u0430\u0432\u0438\u043b\u0430 \u0438\u0437\u043c\u0435\u043d\u0438\u043b\u0438\u0441\u044c, \u0442\u043e \u043f\u0440\u0438\u043c\u0435\u043d\u044f\u0435\u043c \u0438\u0445     \tif (!oldRules.IsEqual(rules))     \t{     \t\toldRules = rules;     \t\tUpdate(rules);     \t}          \tawait Task.Delay(15000, ct).ConfigureAwait(false);     } while (!ct.IsCancellationRequested); } <\/code><\/pre>\n<p>\u0422\u043e \u0435\u0441\u0442\u044c \u0432 CancellationTokenSource \u0431\u0443\u0434\u0443\u0442 \u0445\u0440\u0430\u043d\u0438\u0442\u044c\u0441\u044f \u0432\u0441\u0435 \u043e\u0431\u044a\u0435\u043a\u0442\u044b, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0437\u0430\u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0438\u0440\u043e\u0432\u0430\u043b\u0438 \u0441\u0432\u043e\u0439 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u043c\u0435\u0442\u043e\u0434 \u043e\u0442\u043c\u0435\u043d\u044b\/\u0437\u0430\u0432\u0435\u0440\u0448\u0435\u043d\u0438\u044f, \u0434\u043e \u043e\u043a\u043e\u043d\u0447\u0430\u043d\u0438\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u044d\u0442\u0438\u043c CancellationTokenSource.  <\/p>\n<h2>\u0420\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u0430\u0446\u0438\u0438<\/h2>\n<ol>\n<li>\n<p>\u041d\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0439\u0442\u0435 \u041e\u0414\u0418\u041d CancellationTokenSource, \u0435\u0441\u043b\u0438 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0441\u043e\u0432\u0435\u0440\u0448\u0438\u0442\u044c \u0433\u0430\u0440\u0430\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u0435 \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u0438 \u0431\u043e\u043b\u044c\u0448\u043e\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0440\u0430\u0437, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 \u0432 \u0446\u0438\u043a\u043b\u0435.<\/p>\n<\/li>\n<li>\n<p>\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0439\u0442\u0435 CancellationTokenSource \u0434\u043b\u044f \u0434\u0435\u0442\u0435\u0440\u043c\u0438\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0445 \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u0439, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0434\u043e\u043b\u0436\u043d\u044b \u0437\u0430\u043a\u043e\u043d\u0447\u0438\u0442\u044c\u0441\u044f \u0432 \u043a\u0430\u043a\u043e\u0435-\u0442\u043e \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u043d\u043e\u0435 \u0432\u0440\u0435\u043c\u044f.<\/p>\n<\/li>\n<li>\n<p>\u0410 \u0435\u0441\u043b\u0438 \u043e\u0447\u0435\u043d\u044c \u043d\u0443\u0436\u043d\u043e \u043e\u0442\u043a\u0430\u0437\u0430\u0442\u044c\u0441\u044f \u043e\u0442 \u043f. 1, \u0442\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0439\u0442\u0435 \u0434\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0439 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 \u0441\u0432\u043e\u0439 CancellationTokenSource \u0438 \u0441\u0432\u044f\u0437\u044b\u0432\u0430\u0439\u0442\u0435 \u0435\u0433\u043e \u0441 \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u043c \u0447\u0435\u0440\u0435\u0437 <a href=\"https:\/\/docs.microsoft.com\/en-us\/dotnet\/api\/system.threading.cancellationtokensource.createlinkedtokensource?view=netframework-4.7.2\"><u>CreateLinkedTokenSource.<\/u><\/a><\/p>\n<\/li>\n<li>\n<p>\u041d\u0435\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u044b\u0439 Oracle Client \u2014 \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u0439 \u0432\u043d\u0443\u0442\u0440\u0438.<\/p>\n<\/li>\n<\/ol>\n<p>\u041d\u0430\u0434\u0435\u044e\u0441\u044c, \u0431\u044b\u043b\u043e \u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u0441\u043a\u0443\u0447\u043d\u043e \ud83d\ude09<\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/267\/7dc\/522\/2677dc522bf20b4e9941145dbd0a1fa1.png\" width=\"1617\" height=\"956\"><figcaption><\/figcaption><\/figure>\n<\/div>\n<p> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/company\/tinkoff\/blog\/546604\/\"> https:\/\/habr.com\/ru\/company\/tinkoff\/blog\/546604\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"\n<div class=\"post__text post__text_v2\" id=\"post-content-body\">\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u0412\u0441\u0435\u043c \u043f\u0440\u0438\u0432\u0435\u0442!<\/p>\n<p>\u042f \u0440\u0430\u0431\u043e\u0442\u0430\u044e \u0432 \u0422\u0438\u043d\u044c\u043a\u043e\u0444\u0444, \u0432 \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u00ab\u0422\u0438\u043d\u044c\u043a\u043e\u0444\u0444 \u0422\u0435\u043b\u0435\u0444\u043e\u043d\u0438\u044f\u00bb. \u041d\u0430\u0448\u0430 \u043e\u0441\u043d\u043e\u0432\u043d\u0430\u044f \u0437\u0430\u0434\u0430\u0447\u0430 \u2014 \u043e\u0440\u0433\u0430\u043d\u0438\u0437\u0430\u0446\u0438\u044f IP-\u0442\u0435\u043b\u0435\u0444\u043e\u043d\u0438\u0438 \u0432\u043d\u0443\u0442\u0440\u0438 \u043a\u043e\u043c\u043f\u0430\u043d\u0438\u0438 \u0438 \u0437\u0430 \u0435\u0435 \u043f\u0440\u0435\u0434\u0435\u043b\u0430\u043c\u0438. \u0412 \u0434\u0435\u043d\u044c \u0447\u0435\u0440\u0435\u0437 \u043d\u0430\u0441 \u043f\u0440\u043e\u0445\u043e\u0434\u0438\u0442 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u043e\u0432 \u0437\u0432\u043e\u043d\u043a\u043e\u0432. \u0412\u0441\u0435\u0439 \u044d\u0442\u043e\u0439 \u043a\u0443\u0445\u043d\u0435\u0439 \u0437\u0430\u043d\u0438\u043c\u0430\u044e\u0442\u0441\u044f \u043e\u043a\u043e\u043b\u043e 10 \u0441\u043b\u0443\u0436\u0431.&nbsp;<\/p>\n<p>\u0412 \u043a\u0430\u043a\u043e\u0439-\u0442\u043e \u043c\u043e\u043c\u0435\u043d\u0442 \u043c\u044b \u0441\u0442\u043e\u043b\u043a\u043d\u0443\u043b\u0438\u0441\u044c \u0441 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u043e\u0439: \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u0440\u0435\u043b\u0438\u0437\u0430 \u0441\u0435\u0440\u0432\u0438\u0441\u044b \u043e\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u044e\u0442\u0441\u044f \u043d\u0435\u043f\u0440\u0438\u043b\u0438\u0447\u043d\u043e \u0434\u043e\u043b\u0433\u043e. \u041d\u0430\u0441 \u044d\u0442\u043e \u043f\u0435\u0447\u0430\u043b\u0438\u043b\u043e, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043c\u044b \u043f\u0440\u0438\u043d\u044f\u043b\u0438 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u043f\u0440\u043e\u043a\u0438\u0434\u044b\u0432\u0430\u0442\u044c \u0432\u0435\u0437\u0434\u0435 \u0438 \u0432\u0441\u044e\u0434\u0443 CancellationToken.&nbsp;<\/p>\n<p>\u0427\u0443\u0442\u044c \u043f\u043e\u0437\u0436\u0435 \u0441\u0442\u043e\u043b\u043a\u043d\u0443\u043b\u0438\u0441\u044c \u0441 \u0434\u0440\u0443\u0433\u043e\u0439 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u043e\u0439: \u0432\u0441\u0435 \u043d\u0430\u0448\u0438 \u0441\u0435\u0440\u0432\u0438\u0441\u044b \u043d\u0430\u0447\u0430\u043b\u0438 \u043f\u043e\u0442\u0438\u0445\u043e\u043d\u044c\u043a\u0443 \u043f\u043e\u0436\u0438\u0440\u0430\u0442\u044c \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u0443\u044e \u043f\u0430\u043c\u044f\u0442\u044c. \u041d\u0435 \u0442\u0430\u043a \u0447\u0442\u043e\u0431\u044b \u0441\u043b\u0438\u0448\u043a\u043e\u043c \u0441\u0438\u043b\u044c\u043d\u043e \u0438 \u0431\u044b\u0441\u0442\u0440\u043e, \u043d\u043e \u0432 \u0446\u0435\u043b\u043e\u043c \u0432 \u043f\u0435\u0440\u0441\u043f\u0435\u043a\u0442\u0438\u0432\u0435 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u043d\u0435\u0434\u0435\u043b\u044c \u2014 \u0437\u0430\u043c\u0435\u0442\u043d\u043e.&nbsp;<\/p>\n<figure class=\"\"><figcaption>\u041c\u0435\u0434\u043b\u0435\u043d\u043d\u043e\u0435 \u0438 \u0443\u0432\u0435\u0440\u0435\u043d\u043d\u043e\u0435 \u043f\u043e\u0436\u0438\u0440\u0430\u043d\u0438\u0435 \u043f\u0430\u043c\u044f\u0442\u0438 \u043d\u0430 \u043f\u0440\u043e\u0442\u044f\u0436\u0435\u043d\u0438\u0438 \u043d\u0435\u0434\u0435\u043b\u0438.<\/figcaption><\/figure>\n<p>\u0412 \u043e\u0434\u0438\u043d \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u044b\u0439 \u0434\u0435\u043d\u044c \u0442\u0435\u0440\u043f\u0435\u043d\u0438\u0435 \u043b\u043e\u043f\u043d\u0443\u043b\u043e, \u0438 \u043c\u044b \u0441 \u0416\u0435\u043d\u0435\u0439 \u041c\u0438\u0448\u0443\u0441\u0442\u0438\u043d\u044b\u043c \u0438 <a href=\"https:\/\/habr.com\/ru\/users\/sansagol\/\">\u041a\u0438\u0440\u0438\u043b\u043b\u043e\u043c \u041c\u0430\u0440\u043a\u043e\u0432\u044b\u043c<\/a> \u043d\u0430\u043a\u0438\u043d\u0443\u043b\u0438\u0441\u044c \u043d\u0430 \u044d\u0442\u0443 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0443: \u0416\u0435\u043d\u044f \u0441 \u041a\u0438\u0440\u0438\u043b\u043b\u043e\u043c \u043b\u043e\u0432\u0438\u043b\u0438 \u0438 \u0430\u043d\u0430\u043b\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043b\u0438 \u0434\u0430\u043c\u043f\u044b, \u0430 \u044f \u0437\u0430\u043d\u0438\u043c\u0430\u043b\u0441\u044f \u043f\u043e\u0438\u0441\u043a\u043e\u043c \u043f\u0440\u0438\u0447\u0438\u043d \u0442\u0430\u043a\u043e\u0433\u043e \u043f\u043e\u0432\u0435\u0434\u0435\u043d\u0438\u044f.<\/p>\n<p>\u041e\u0441\u043e\u0431\u0435\u043d\u043d\u043e \u043e\u0442\u0447\u0435\u0442\u043b\u0438\u0432\u043e \u0432\u044b\u0434\u0435\u043b\u044f\u043b\u0441\u044f \u043e\u0434\u0438\u043d \u0441\u0435\u0440\u0432\u0438\u0441, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u043b\u0441\u044f \u043f\u043e \u0440\u0430\u0441\u043f\u0438\u0441\u0430\u043d\u0438\u044e \u0438 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u043b \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0443 \u0437\u0430\u043f\u0438\u0441\u0430\u043d\u043d\u044b\u0445 \u0437\u0432\u043e\u043d\u043a\u043e\u0432. \u0422\u0430\u043a \u043a\u0430\u043a \u0442\u0430\u043a\u0438\u0445 \u0437\u0430\u043f\u0438\u0441\u0435\u0439 \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u043c\u043d\u043e\u0433\u043e, \u0442\u043e \u0438\u0445 \u0430\u043d\u0430\u043b\u0438\u0437 \u0438 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0430 \u0437\u0430\u0442\u044f\u0433\u0438\u0432\u0430\u043b\u0438\u0441\u044c \u043d\u0430 \u0434\u043b\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0435 \u0432\u0440\u0435\u043c\u044f. \u0410 \u043f\u043e\u0441\u043b\u0435 \u0437\u0430\u0432\u0435\u0440\u0448\u0435\u043d\u0438\u044f \u043f\u0430\u043c\u044f\u0442\u044c \u043e\u0441\u0432\u043e\u0431\u043e\u0436\u0434\u0430\u043b\u0430\u0441\u044c. \u041f\u0440\u0438 \u044d\u0442\u043e\u043c \u043d\u0435\u043b\u044c\u0437\u044f \u0441\u043a\u0430\u0437\u0430\u0442\u044c, \u0447\u0442\u043e \u0432\u043d\u0443\u0442\u0440\u0438 \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u043b\u043e\u0441\u044c \u043a\u0430\u043a\u043e\u0435-\u0442\u043e \u0431\u043e\u043b\u044c\u0448\u043e\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b.<\/p>\n<figure class=\"full-width\"><figcaption>\u041f\u043e\u0442\u0440\u0435\u0431\u043b\u0435\u043d\u0438\u0435 \u043f\u0430\u043c\u044f\u0442\u0438 \u043f\u0440\u0438 \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0438 \u043e\u0434\u043d\u043e\u0439 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u0437\u0430\u043f\u0438\u0441\u0430\u043d\u043d\u044b\u0445 \u0437\u0432\u043e\u043d\u043a\u043e\u0432. GC \u0432\u044b\u0441\u0432\u043e\u0431\u043e\u0436\u0434\u0430\u0435\u0442 \u043e\u043a\u043e\u043b\u043e 6 \u0413\u0431 \u043f\u0430\u043c\u044f\u0442\u0438.<\/figcaption><\/figure>\n<p>\u0410 \u043f\u0430\u0440\u0443 \u043c\u0435\u0441\u044f\u0446\u0435\u0432 \u043d\u0430\u0437\u0430\u0434 \u043d\u0430\u0447\u0430\u043b\u0430\u0441\u044c \u0431\u0435\u0434\u0430: \u043e\u0434\u0438\u043d \u0438\u0437 \u0441\u0435\u0440\u0432\u0438\u0441\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u0442 \u043f\u043e \u0440\u0430\u0441\u043f\u0438\u0441\u0430\u043d\u0438\u044e \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0437\u0430\u0434\u0430\u0447\u0438, \u0432\u043d\u0435\u0437\u0430\u043f\u043d\u043e \u0441\u0442\u0430\u043b \u043d\u0435\u043f\u0440\u0438\u043b\u0438\u0447\u043d\u043e \u043f\u0440\u043e\u0436\u043e\u0440\u043b\u0438\u0432! \u041e\u043d \u043c\u043e\u0433 \u0437\u0430 \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u0439 \u043f\u0440\u043e\u043c\u0435\u0436\u0443\u0442\u043e\u043a \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0437\u0430\u0445\u0432\u0430\u0442\u0438\u0442\u044c 2\u20145 \u0413\u0411. \u0418 \u0442\u0443\u0442 \u0441\u0442\u0430\u043b\u043e \u044f\u0441\u043d\u043e, \u0447\u0442\u043e \u043f\u0440\u0438\u0448\u043b\u043e \u0432\u0440\u0435\u043c\u044f \u0441\u0442\u0440\u044f\u0445\u043d\u0443\u0442\u044c \u043f\u044b\u043b\u044c \u0441 dotMemory \u0438 WinDbg!&nbsp;<\/p>\n<p>\u0421\u043f\u043e\u0439\u043b\u0435\u0440 \u0434\u043b\u044f \u0442\u0435\u0445, \u043a\u043e\u043c\u0443 \u043b\u0435\u043d\u044c \u0447\u0438\u0442\u0430\u0442\u044c \u0438 \u0440\u0430\u0437\u0431\u0438\u0440\u0430\u0442\u044c\u0441\u044f: \u0432 CancellationTokenSource \u043d\u0435\u0442 \u0443\u0442\u0435\u0447\u0435\u043a \u2014 \u0435\u0441\u0442\u044c \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u0435\u0433\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f.<\/p>\n<p>\u041d\u0430\u0447\u0430\u043b\u0438 \u0441\u043d\u0438\u043c\u0430\u0442\u044c \u0434\u0430\u043c\u043f\u044b, \u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c. \u0412\u043e \u043c\u043d\u043e\u0433\u0438\u0445 \u0431\u044b\u043b\u0430 \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u0430\u044f \u043a\u0430\u0440\u0442\u0438\u043d\u0430: \u0434\u0430\u043c\u043f \u0432\u0435\u0441\u0438\u0442 \u043e\u043a\u043e\u043b\u043e 5 \u0413\u0411, \u0430 dotMemory \u0443\u043f\u043e\u0440\u043d\u043e \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442 \u0440\u0430\u0437\u043c\u0435\u0440 \u043a\u0443\u0447 \u0434\u043e 1\u20142 \u0413\u0411.  <\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<figure class=\"full-width\"><figcaption>\u0420\u0430\u0437\u043c\u0435\u0440 \u044d\u0442\u043e\u0433\u043e \u0434\u0430\u043c\u043f\u0430 \u043e\u043a\u043e\u043b\u043e 3,5 \u0413\u0431.<\/figcaption><\/figure>\n<p>\u041d\u0443, \u0432\u0440\u043e\u0434\u0435 \u0432\u0441\u0435 \u043d\u043e\u0440\u043c\u0430\u043b\u044c\u043d\u043e, \u043d\u0438\u0447\u0435\u0433\u043e \u043a\u0440\u0438\u0442\u0438\u0447\u043d\u043e\u0433\u043e. \u041d\u043e \u0434\u0430\u043c\u043f-\u0442\u043e \u043e\u0433\u0440\u043e\u043c\u043d\u044b\u0439! \u0427\u0435\u043c \u0437\u0430\u043d\u044f\u0442\u0430 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u0430\u044f \u043f\u0430\u043c\u044f\u0442\u044c? \u0414\u0443\u043c\u0430\u043b\u0438, \u0447\u0442\u043e \u044d\u0442\u043e \u0441\u0435\u0440\u0432\u0435\u0440\u043d\u044b\u0439 \u0440\u0435\u0436\u0438\u043c \u0440\u0430\u0431\u043e\u0442\u044b GC (<a href=\"https:\/\/docs.microsoft.com\/ru-ru\/dotnet\/standard\/garbage-collection\/workstation-server-gc\"><u>\u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0435 \u0440\u0435\u0436\u0438\u043c\u043e\u0432<\/u><\/a>, <a href=\"https:\/\/docs.microsoft.com\/ru-ru\/dotnet\/core\/run-time-config\/garbage-collector#workstation-vs-server\"><u>\u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430<\/u><\/a>). \u041c\u0435\u043d\u044f\u043b\u0438, \u0436\u0434\u0430\u043b\u0438 \u2014 \u043d\u0435 \u043f\u043e\u043c\u043e\u0433\u0430\u0435\u0442.&nbsp;<\/p>\n<p>\u0416\u0435\u043d\u044f \u0443\u0436\u0435 \u0434\u043e\u043b\u0433\u043e\u0435 \u0432\u0440\u0435\u043c\u044f \u043d\u0430\u0431\u043b\u044e\u0434\u0430\u043b \u0437\u0430 \u043d\u0435\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u043e\u0439 \u043f\u0430\u043c\u044f\u0442\u044c\u044e \u0441\u0435\u0440\u0432\u0438\u0441\u043e\u0432, \u0438 \u0435\u0435 \u0440\u0430\u0437\u043c\u0435\u0440 \u043d\u0435 \u0434\u0430\u0432\u0430\u043b\u0438 \u0435\u043c\u0443 \u043f\u043e\u043a\u043e\u044f: \u043e\u043d \u043c\u043e\u0433 \u0434\u043e\u0441\u0442\u0438\u0433\u0430\u0442\u044c 8\u201410 \u0413\u0411. \u041f\u043e\u0447\u0435\u043c\u0443 \u043e\u043d\u0430 \u0442\u0430\u043a \u0440\u0430\u0441\u0442\u0435\u0442?<\/p>\n<figure class=\"full-width\"><figcaption>\u0420\u0430\u0437\u043c\u0435\u0440 \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u043e\u0439 \u0438 \u00ab\u043d\u0435 \u043e\u0447\u0435\u043d\u044c\u00bb \u043f\u0430\u043c\u044f\u0442\u0438.<\/figcaption><\/figure>\n<p>\u0423\u0437\u043d\u0430\u0432 \u043e \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0435, \u043d\u0430\u0448 \u0440\u0443\u043a\u043e\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c \u043f\u043e\u0434\u0435\u043b\u0438\u043b\u0441\u044f \u043e\u043f\u044b\u0442\u043e\u043c: \u0432 \u0441\u043c\u0435\u0436\u043d\u043e\u043c \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u0431\u044b\u043b\u043e \u043f\u043e\u0434\u043e\u0431\u043d\u043e\u0435 \u2014 \u0442\u0430\u043c \u043d\u0435\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u0430\u044f \u043f\u0430\u043c\u044f\u0442\u044c \u0431\u044b\u043b\u0430 \u0437\u0430\u0431\u0438\u0442\u0430 \u0441\u0442\u0440\u043e\u043a\u0430\u043c\u0438 \u043e\u0442 \u0441\u0442\u043e\u0440\u043e\u043d\u043d\u0435\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438. \u0410 \u0447\u0442\u043e \u0436\u0435 \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0443 \u043d\u0430\u0441? \u041c\u044b \u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u0441\u044f \u043d\u0435\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u044b\u043c \u043a\u043b\u0438\u0435\u043d\u0442\u043e\u043c Oracle \u0438 \u0435\u0449\u0435 \u043e\u0434\u043d\u043e\u0439 \u0443\u0442\u0438\u043b\u0438\u0442\u043e\u0439, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0442\u043e\u0436\u0435 \u043c\u043e\u0436\u0435\u0442 \u043b\u0435\u0437\u0442\u044c \u0432 unmanged-\u043a\u043e\u0434. \u041d\u043e \u0441 \u043d\u0438\u043c\u0438 \u043d\u0438\u043a\u0430\u043a\u0438\u0445 \u043f\u0440\u043e\u0431\u043b\u0435\u043c \u043d\u0435 \u0431\u044b\u043b\u043e. \u041c\u044b \u0438\u0445 \u043d\u0435 \u043c\u0435\u043d\u044f\u043b\u0438, \u043d\u0435 \u043e\u0431\u043d\u043e\u0432\u043b\u044f\u043b\u0438\u2026 \u0410 \u0432\u0434\u043e\u0431\u0430\u0432\u043e\u043a \u0435\u0449\u0435 \u0438 dotMemory \u0432\u043e\u0442 \u0442\u0430\u043a \u043f\u0440\u043e\u0441\u0442\u043e \u043d\u0435 \u0445\u043e\u0447\u0435\u0442 \u043d\u0430\u043c \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0442\u044c \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u043c\u043e\u0435 \u043d\u0435\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u043e\u0439 \u043f\u0430\u043c\u044f\u0442\u0438.\u041d\u0430\u0441\u0442\u0430\u043b\u043e \u0432\u0440\u0435\u043c\u044f \u0434\u0440\u0443\u0433\u043e\u0433\u043e \u0433\u0435\u0440\u043e\u044f WinDbg. \u041d\u0435\u043c\u043d\u043e\u0433\u043e \u043f\u043e\u0431\u043e\u043b\u0442\u0430\u0432 \u0441 Google, \u044f \u043d\u0430\u0448\u0435\u043b \u0441\u0442\u0430\u0442\u0435\u0439\u043a\u0443: <a href=\"http:\/\/kate-butenko.blogspot.com\/2012\/07\/investigating-issues-with-unmanaged.html\"><u>Investigating issues with Unmanaged Memory. First steps<\/u><\/a>, \u0433\u0434\u0435 \u043f\u043e \u0448\u0430\u0433\u0430\u043c \u0440\u0430\u0441\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u0442\u0441\u044f, \u043a\u0430\u043a \u0437\u0430\u0433\u043b\u044f\u043d\u0443\u0442\u044c \u0432 \u0437\u0430\u0437\u0435\u0440\u043a\u0430\u043b\u044c\u0435 \u2014 \u0432 \u043d\u0435\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u0443\u044e \u043f\u0430\u043c\u044f\u0442\u044c. \u041f\u043e\u0447\u0438\u0442\u0430\u043b\u0438 \u0438 \u0441\u0434\u0435\u043b\u0430\u043b\u0438. \u041a\u0430\u0440\u0442\u0438\u043d\u0430 \u0443\u0434\u0438\u0432\u0438\u043b\u0430:<\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u041a\u0430\u043a \u043f\u043e\u043d\u0438\u043c\u0430\u0435\u0442\u0435, \u0432\u043d\u0443\u0442\u0440\u0438 \u043e\u0448\u043c\u0435\u0442\u043a\u0438 SQL-\u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432, ORA-\u043e\u0448\u0438\u0431\u043e\u043a \u0438 \u0442\u0430\u043a \u0434\u0430\u043b\u0435\u0435. \u041d\u0430\u043f\u0440\u0430\u0448\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0434\u0438\u043d \u0432\u044b\u0432\u043e\u0434:<\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u041a\u0430\u0436\u0434\u044b\u0439 \u0440\u0430\u0437 \u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0442\u0430\u043a\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c \u043d\u0435\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u0443\u044e \u043f\u0430\u043c\u044f\u0442\u044c \u2014 \u043d\u0443 \u043e\u0447\u0435\u043d\u044c \u0434\u043e\u043b\u0433\u043e \u0438 \u043d\u0435\u0443\u0434\u043e\u0431\u043d\u043e. \u0422\u0443\u0442 \u0416\u0435\u043d\u044f \u0432\u0441\u043f\u043e\u043c\u043d\u0438\u043b \u043f\u0440\u043e \u043a\u043d\u0438\u0433\u0443 <a href=\"https:\/\/docs.microsoft.com\/en-us\/sysinternals\/resources\/windows-internals\"><u>Windows Internals<\/u><\/a>, \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u043d\u0435 \u0442\u0430\u043a \u0434\u0430\u0432\u043d\u043e \u043f\u0440\u043e\u0447\u0435\u043b, \u0433\u0434\u0435 \u0440\u0430\u0441\u0441\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f <a href=\"https:\/\/docs.microsoft.com\/en-us\/sysinternals\/downloads\/vmmap\"><u>\u043f\u0440\u043e VMMap<\/u><\/a>. VMMap \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0437\u0430\u0433\u043b\u044f\u043d\u0443\u0442\u044c \u0432 \u043d\u0435\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u0443\u044e \u043f\u0430\u043c\u044f\u0442\u044c \u043d\u0430 \u0436\u0438\u0432\u043e\u043c \u043f\u0440\u043e\u0446\u0435\u0441\u0441\u0435 \u0438 \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c, \u0447\u0442\u043e \u0437\u0430 \u0441\u0442\u0440\u043e\u043a\u0438 \u0442\u0430\u043c \u0445\u0440\u0430\u043d\u044f\u0442\u0441\u044f.<\/p>\n<figure class=\"full-width\"><figcaption>\u042d\u0442\u043e \u043f\u0440\u0438\u043c\u0435\u0440 \u0441 \u0438\u0441\u043f\u0440\u0430\u0432\u043b\u0435\u043d\u043d\u043e\u0439 \u0432\u0435\u0440\u0441\u0438\u0438. \u041d\u043e \u043f\u043e\u0432\u0435\u0440\u044c\u0442\u0435: \u0432 \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u043a\u0443\u0447\u0435 \u0431\u044b\u043b\u043e \u043c\u043d\u043e\u0433\u043e \u0441\u0442\u0440\u043e\u043a, \u0441\u0432\u044f\u0437\u0430\u043d\u043d\u044b\u0445 \u0441 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u043d\u044b\u043c \u043a\u043e\u0434\u043e\u043c.<\/figcaption><\/figure>\n<p>\u041a\u0430\u043a \u044f \u0443\u0436\u0435 \u0433\u043e\u0432\u043e\u0440\u0438\u043b, \u0432\u043e \u0432\u0441\u0435\u0445 \u0441\u043d\u044f\u0442\u044b\u0445 \u0438\u0441\u0441\u043b\u0435\u0434\u0443\u0435\u043c\u044b\u0445 \u0441\u043d\u0438\u043c\u043a\u0430\u0445 \u0440\u0430\u0437\u043c\u0435\u0440 \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u044b\u0445 \u043a\u0443\u0447 \u0431\u044b\u043b \u043d\u0435\u0432\u0435\u043b\u0438\u043a. \u041d\u043e \u043e\u0442\u0432\u0435\u0442\u0430 \u043d\u0430 \u0432\u043e\u043f\u0440\u043e\u0441, \u043f\u043e\u0447\u0435\u043c\u0443 \u043d\u0435\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u0430\u044f \u043f\u0430\u043c\u044f\u0442\u044c \u043d\u0435 \u043e\u0441\u0432\u043e\u0431\u043e\u0436\u0434\u0430\u0435\u0442\u0441\u044f, \u043c\u044b \u0442\u0430\u043a \u0438 \u043d\u0435 \u043d\u0430\u0448\u043b\u0438. \u041e\u0434\u043d\u0430\u0436\u0434\u044b \u0443\u0434\u0430\u043b\u043e\u0441\u044c \u0441\u043d\u044f\u0442\u044c \u0434\u0430\u043c\u043f, \u0433\u0434\u0435 \u043f\u043e \u043a\u0443\u0447\u0435 \u0435\u0449\u0435 \u043d\u0435 \u0443\u0441\u043f\u0435\u043b \u043f\u0440\u043e\u0439\u0442\u0438\u0441\u044c GC.<\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u0421\u0440\u0430\u0437\u0443 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043f\u0440\u0438\u0432\u043b\u0435\u043a\u043b\u0438 \u0434\u0432\u0435 \u043e\u0431\u043b\u0430\u0441\u0442\u0438 \u043f\u0430\u043c\u044f\u0442\u0438: \u0441\u043f\u0438\u0441\u043e\u043a \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 \u043d\u0430 600 \u041c\u0411 \u0438 17 \u044d\u043a\u0437\u0435\u043c\u043f\u043b\u044f\u0440\u043e\u0432 CancellationTokenSource \u043d\u0430 3,5 \u0413\u0411.<\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<figure class=\"full-width\"><figcaption>\u041d\u0435\u0432\u0435\u0440\u043e\u044f\u0442\u043d\u044b\u0445 \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u0432 \u0442\u043e\u043a\u0435\u043d \u043e\u0442\u043c\u0435\u043d\u044b.<\/figcaption><\/figure>\n<p>\u0427\u0442\u043e \u0436, \u0435\u0441\u0442\u044c \u0434\u0432\u0430 \u0432\u043e\u043f\u0440\u043e\u0441\u0430:<\/p>\n<ol>\n<li>\n<p>\u041f\u043e\u0447\u0435\u043c\u0443 \u0441\u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 \u0432 \u0441\u043f\u0438\u0441\u043a\u0435?  <\/p>\n<\/li>\n<li>\n<p>\u041f\u043e\u0447\u0435\u043c\u0443 \u0442\u0430\u043a\u043e\u0439 \u043e\u0433\u0440\u043e\u043c\u043d\u044b\u0439 CancellationTokenSource? <\/p>\n<\/li>\n<\/ol>\n<p>\u0421 \u043f\u0435\u0440\u0432\u043e\u0439 \u043e\u0431\u043b\u0430\u0441\u0442\u044c\u044e \u043f\u0430\u043c\u044f\u0442\u0438 \u0440\u0430\u0437\u043e\u0431\u0440\u0430\u043b\u0438\u0441\u044c \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u0431\u044b\u0441\u0442\u0440\u043e \u0438 \u043f\u0440\u043e\u0441\u0442\u043e, \u043d\u043e \u044d\u0442\u043e \u0431\u0443\u0434\u0435\u0442 \u043d\u0435\u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e \u0447\u0438\u0442\u0430\u0442\u0435\u043b\u044e, \u0442\u0430\u043a \u043a\u0430\u043a \u043a\u0430\u0441\u0430\u043b\u043e\u0441\u044c \u0431\u0438\u0437\u043d\u0435\u0441\u0430.<\/p>\n<p>\u0410 \u0432\u043e\u0442 \u0447\u0442\u043e \u043a\u0430\u0441\u0430\u0435\u0442\u0441\u044f \u0432\u0442\u043e\u0440\u043e\u0439 \u2014 \u0442\u0443\u0442 \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u0442\u0441\u044f \u0441\u0430\u043c\u043e\u0435 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e\u0435. \u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u043f\u043e\u043f\u0440\u043e\u0431\u0443\u0435\u043c \u0440\u0430\u0437\u043e\u0431\u0440\u0430\u0442\u044c\u0441\u044f, \u0447\u0442\u043e \u0436\u0435 \u0445\u0440\u0430\u043d\u0438\u0442 CancellationTokenSource \u0438 \u043a\u0430\u043a \u044d\u0442\u043e \u0442\u0443\u0434\u0430 \u043f\u043e\u043f\u0430\u0434\u0430\u0435\u0442? \u0418 \u043d\u0430\u0447\u043d\u0435\u043c, \u043a\u0430\u043a \u0438 \u043f\u043e\u043b\u0430\u0433\u0430\u0435\u0442\u0441\u044f, \u0441 \u0442\u0435\u043e\u0440\u0438\u0438.<\/p>\n<p><a href=\"https:\/\/docs.microsoft.com\/ru-ru\/dotnet\/api\/system.threading.cancellationtokensource\">CancellationTokenSource <\/a>\u2013 \u044d\u0442\u043e<\/p>\n<blockquote>\n<p>Signals to a CancellationToken that it should be canceled.  <\/p>\n<\/blockquote>\n<p>\u0415\u0441\u043b\u0438 \u0433\u043e\u0432\u043e\u0440\u0438\u0442\u044c \u043f\u0440\u043e\u0441\u0442\u044b\u043c \u044f\u0437\u044b\u043a\u043e\u043c, \u0442\u043e \u044d\u0442\u0430 \u0448\u0442\u0443\u043a\u0430 \u0441\u043e\u0437\u0434\u0430\u0435\u0442 <a href=\"https:\/\/docs.microsoft.com\/en-us\/dotnet\/api\/system.threading.cancellationtoken?view=net-5.0\"><u>CancellationToken<\/u><\/a>, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043c\u043e\u0436\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0434\u043b\u044f \u043e\u0442\u043c\u0435\u043d\u044b \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u0438. \u041e\u0431\u044b\u0447\u043d\u043e \u043c\u044b \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0442\u043e\u043a\u0435\u043d\u0430 \u043e\u0442\u043c\u0435\u043d\u044b, \u0438 \u0435\u0441\u043b\u0438 \u043e\u043d \u043e\u0442\u043c\u0435\u043d\u0435\u043d, \u0442\u043e \u043f\u0440\u0435\u0440\u044b\u0432\u0430\u0435\u043c \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u0435 \u0438\u043b\u0438 \u043a\u0438\u0434\u0430\u0435\u043c \u0438\u0441\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435. \u0421\u0430\u043c \u0442\u043e\u043a\u0435\u043d \u043f\u0435\u0440\u0435\u0432\u0435\u0441\u0442\u0438 \u0432 \u043e\u0442\u043c\u0435\u043d\u0451\u043d\u043d\u043e\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u043c\u043e\u0436\u0435\u0442 \u0435\u0433\u043e \u0440\u043e\u0434\u0438\u0442\u0435\u043b\u044c (Source). \u0412\u0441\u0435 \u043f\u0440\u043e\u0441\u0442\u043e.&nbsp;<\/p>\n<p>\u041d\u043e \u043a\u0430\u043a \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u044d\u0442\u0430 \u0441\u0432\u044f\u0437\u043a\u0430? \u041f\u043e\u0447\u0435\u043c\u0443 \u0432 \u0438\u0442\u043e\u0433\u0435 \u0443 \u043d\u0430\u0441 \u043e\u0434\u0438\u043d CancellationTokenSource \u0437\u0430\u043d\u044f\u043b \u0431\u043e\u043b\u0435\u0435 3 \u0413\u0411? \u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u0437\u0430\u0433\u043b\u044f\u043d\u0435\u043c \u0432\u043d\u0443\u0442\u0440\u044c, \u0447\u0442\u043e \u0436\u0435 \u0442\u0430\u043c \u0442\u0430\u043a\u043e\u0435 \u0445\u0440\u0430\u043d\u0438\u0442\u0441\u044f?<\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u0412 \u0441\u0430\u043c\u043e\u043c Source \u0445\u0440\u0430\u043d\u0438\u0442\u0441\u044f \u043c\u0430\u0441\u0441\u0438\u0432 <a href=\"https:\/\/referencesource.microsoft.com\/#mscorlib\/system\/threading\/CancellationTokenSource.cs,33e870abd2d82e74,references\"><u>CancellationCallbackInfo<\/u><\/a> \u0441 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0435\u0439 \u043e \u043a\u0430\u043a\u043e\u043c-\u0442\u043e \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0438, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u0432\u044b\u0437\u0432\u0430\u0442\u044c \u043f\u0440\u0438 \u0441\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u043d\u0438\u0438 \u043e\u0442\u043c\u0435\u043d\u044b. \u041e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u043e\u0431\u044a\u0435\u043a\u0442, \u0434\u043b\u044f \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u043d\u0443\u0436\u043d\u043e \u0432\u044b\u0437\u0432\u0430\u0442\u044c \u043c\u0435\u0442\u043e\u0434, \u2014 \u044d\u0442\u043e\u2026 OracleCommand. \u0415\u0441\u043b\u0438 \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0432\u0441\u0435 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435 \u043e\u0431\u044a\u0435\u043a\u0442\u044b \u043c\u0430\u0441\u0441\u0438\u0432\u0430, \u0442\u043e \u0432\u0441\u0435 \u043e\u043d\u0438 \u0432\u044b\u0433\u043b\u044f\u0434\u044f\u0442 \u043e\u0434\u0438\u043d\u0430\u043a\u043e\u0432\u043e. \u0410 \u0447\u0442\u043e \u043b\u0435\u0436\u0438\u0442 \u0432\u043e \u0432\u0442\u043e\u0440\u043e\u043c \u043f\u043e \u0432\u0435\u043b\u0438\u0447\u0438\u043d\u0435 CancellationTokenSource?<\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u0412\u0441\u0435 \u0442\u043e \u0436\u0435 \u0441\u0430\u043c\u043e\u0435, \u0442\u043e\u043b\u044c\u043a\u043e \u0437\u0430\u043f\u0440\u043e\u0441 \u0434\u0440\u0443\u0433\u043e\u0439. \u0422\u0435\u043f\u0435\u0440\u044c \u043e\u0441\u0442\u0430\u043b\u043e\u0441\u044c \u043f\u043e\u043d\u044f\u0442\u044c, \u043a\u0430\u043a \u043a\u0430\u043a\u043e\u0439-\u0442\u043e OracleCommand, \u0441 \u043a\u043e\u0442\u043e\u0440\u044b\u043c \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u043d\u0438\u043a\u0442\u043e \u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442, \u043f\u043e\u043f\u0430\u0434\u0430\u0435\u0442 \u0432 <\/p>\n<pre><code>m_registeredCallbacksLists -&gt; CancellationCallbackInfo -&gt; StateForCallback \u2013&gt; _target<\/code><\/pre>\n<p>\u0412\u0440\u044f\u0434 \u043b\u0438 \u0435\u0441\u0442\u044c \u043a\u0430\u043a\u0430\u044f-\u0442\u043e \u043c\u0430\u0433\u0438\u044f, \u043d\u043e \u043f\u043e\u043a\u0430 \u043d\u0435\u043f\u043e\u043d\u044f\u0442\u043d\u043e. \u042f \u0440\u0435\u0448\u0438\u043b \u043d\u0430\u0447\u0430\u0442\u044c \u0441 \u0438\u0441\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u043d\u0438\u044f \u0438\u0441\u0445\u043e\u0434\u043d\u0438\u043a\u043e\u0432 CancellationTokenSource, \u0430 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e \u2014 \u043d\u0430\u0439\u0442\u0438 \u043c\u0435\u0441\u0442\u043e, \u0433\u0434\u0435 \u0441\u043e\u0437\u0434\u0430\u0435\u0442\u0441\u044f \u044d\u0442\u043e\u0442 \u0441\u0430\u043c\u044b\u0439 CancellationCallbackInfo \u0438 StateForCallback. \u041a\u0441\u0442\u0430\u0442\u0438, StateForCallback \u2014 \u044d\u0442\u043e \u0434\u0435\u043b\u0435\u0433\u0430\u0442, \u043a\u0430\u043a \u0432\u0438\u0434\u043d\u043e \u0438\u0437 \u0434\u0432\u0443\u0445 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0438\u0445 \u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0439, \u0430 \u0437\u043d\u0430\u0447\u0438\u0442, _target \u2014 \u044d\u0442\u043e \u043a\u0430\u043a\u043e\u0435-\u0442\u043e \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0435\u0435 \u043f\u043e\u043b\u0435, \u0433\u0434\u0435 \u0445\u0440\u0430\u043d\u0438\u0442\u0441\u044f \u043e\u0431\u044a\u0435\u043a\u0442, \u043c\u0435\u0442\u043e\u0434 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u0438 \u00ab\u0441\u043e\u0445\u0440\u0430\u043d\u0435\u043d\u00bb \u0432 \u0434\u0435\u043b\u0435\u0433\u0430\u0442\u0435. \u041f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f, \u0447\u0442\u043e \u0433\u0434\u0435-\u0442\u043e \u043a\u0430\u043a\u043e\u0439-\u0442\u043e \u043c\u0435\u0442\u043e\u0434 \u0438\u0437 OracleCommand \u043f\u0435\u0440\u0435\u0434\u0430\u0435\u0442\u0441\u044f \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0434\u0435\u043b\u0435\u0433\u0430\u0442\u0430. \u0418\u0449\u0435\u043c, \u0433\u0434\u0435 \u0441\u043e\u0437\u0434\u0430\u0435\u0442\u0441\u044f CancellationCallbackInfo \u0438 StateForCallback. \u041e\u043a\u0430\u0437\u0430\u043b\u043e\u0441\u044c \u2014 \u0432 CancellationTokenSource.InternalRegister.<\/p>\n<p>\u0421\u0430\u043c \u043c\u0435\u0442\u043e\u0434 InternalRegister \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0438\u0437 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u043f\u0435\u0440\u0435\u0433\u0440\u0443\u0437\u043e\u043a CancellationToken.Register. \u0421\u043e\u0433\u043b\u0430\u0441\u043d\u043e <a href=\"https:\/\/docs.microsoft.com\/en-us\/dotnet\/api\/System.Threading.CancellationToken.Register?view=netframework-4.7.2\"><u>\u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438<\/u><\/a>, \u044d\u0442\u043e\u0442 \u043c\u0435\u0442\u043e\u0434 \u043f\u0440\u0435\u0434\u043d\u0430\u0437\u043d\u0430\u0447\u0435\u043d \u0434\u043b\u044f:<\/p>\n<blockquote>\n<p>Registers a delegate that will be called when this CancellationToken is canceled.<\/p>\n<\/blockquote>\n<p>\u0421 \u044d\u0442\u0438\u043c \u0432\u0441\u0435 \u044f\u0441\u043d\u043e, \u043d\u043e \u0433\u0434\u0435 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0430\u0446\u0438\u044f? \u041e\u0442\u0432\u0435\u0442 \u043d\u0430 \u044d\u0442\u043e\u0442 \u0432\u043e\u043f\u0440\u043e\u0441 \u0440\u0435\u0448\u0438\u043b \u0438\u0441\u043a\u0430\u0442\u044c \u0432 \u043b\u043e\u0431 \u2014 \u043f\u0440\u044f\u043c\u044b\u043c\u0438 \u043f\u0435\u0440\u0435\u0445\u043e\u0434\u0430\u043c\u0438 \u043f\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f\u043c \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u043c\u044b\u0445 \u043c\u0435\u0442\u043e\u0434\u043e\u0432, \u043a\u0443\u0434\u0430 \u043f\u0435\u0440\u0435\u0434\u0430\u0435\u0442\u0441\u044f CancellationToken. \u041c\u043e\u0439 \u043f\u043e\u0438\u0441\u043a \u043d\u0430\u0447\u0430\u043b\u0441\u044f \u0441 \u043f\u0435\u0440\u0432\u043e\u0433\u043e \u043c\u0435\u0442\u043e\u0434\u0430, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0432\u044b\u0445\u043e\u0434\u0438\u0442 \u0437\u0430 \u043f\u0440\u0435\u0434\u0435\u043b\u044b \u043d\u0430\u0448\u0435\u0433\u043e \u043a\u043e\u0434\u0430:<\/p>\n<pre><code class=\"cs\">System.Data.Entity.QueryableExtensions.ToListAsync(query, cancellationToken.Value).<\/code><\/pre>\n<p>\u0414\u0430\u043b\u0435\u0435 \u0441\u043b\u0435\u0434\u0443\u0435\u0442 \u0441\u043a\u0443\u0447\u043d\u043e\u0435 \u00ab\u043f\u0440\u043e\u0442\u044b\u043a\u0438\u0432\u0430\u043d\u0438\u0435\u00bb \u043f\u043e \u0432\u044b\u0437\u043e\u0432\u0430\u043c. \u0421\u0440\u0430\u0437\u0443 \u043f\u0435\u0440\u0435\u0439\u0434\u0443 \u043a \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e\u043c\u0443. \u0412 \u043a\u0430\u043a\u043e\u0439-\u0442\u043e \u043c\u043e\u043c\u0435\u043d\u0442 IDE \u0432\u044b\u0434\u0430\u043b\u0430 \u0441\u043f\u0438\u0441\u043e\u043a \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0439 \u043c\u0435\u0442\u043e\u0434\u0430, \u043d\u043e Oracle \u0432\u043d\u0443\u0442\u0440\u0438 \u043d\u0435 \u0431\u044b\u043b\u043e.  <\/p>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u041d\u0430\u043f\u043e\u043c\u043d\u044e: \u0443 \u043d\u0430\u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043d\u0435\u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u044b\u0439 \u043a\u043b\u0438\u0435\u043d\u0442 \u0441 \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c\u043e\u0439 \u043e\u0431\u0435\u0440\u0442\u043a\u043e\u0439. \u0412 \u0441\u043f\u0438\u0441\u043a\u0435 \u043d\u0438\u0447\u0435\u0433\u043e \u043f\u043e\u0445\u043e\u0436\u0435\u0433\u043e \u043d\u0430 \u0441\u043b\u043e\u0432\u043e Oracle \u043d\u0435\u0442, \u043d\u0443 \u0434\u0430 \u043b\u0430\u0434\u043d\u043e. \u041f\u043e\u0441\u043c\u043e\u0442\u0440\u0438\u043c, \u043a\u0430\u043a \u0441\u0434\u0435\u043b\u0430\u043d\u043e \u0443 \u0434\u0440\u0443\u0433\u0438\u0445 \u2014 \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0432 Postgre-\u043a\u043b\u0438\u0435\u043d\u0442\u0435:<\/p>\n<pre><code class=\"cs\">public override Task&lt;bool&gt; ReadAsync(CancellationToken cancellationToken) {     CheckClosed();      if (cancellationToken.IsCancellationRequested)         return Task.FromCanceled&lt;bool&gt;(cancellationToken);      var fastRead = TryFastRead();     if (fastRead.HasValue)         return fastRead.Value ? PGUtil.TrueTask : PGUtil.FalseTask;      using (NoSynchronizationContextScope.Enter())         return Read(true); }<\/code><\/pre>\n<p>\u0427\u0442\u043e, \u043d\u0435\u0443\u0436\u0435\u043b\u0438 \u043a\u043e\u043d\u0435\u0446? \u041d\u043e \u0432\u0435\u0434\u044c \u043e\u0442\u0432\u0435\u0442\u0430 \u043d\u0430 \u0432\u043e\u043f\u0440\u043e\u0441, \u043a\u0430\u043a \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0430\u0446\u0438\u044f, \u044f \u043d\u0435 \u043d\u0430\u0448\u0435\u043b. \u0420\u0435\u0448\u0438\u043b \u043f\u043e\u0438\u0441\u043a\u0430\u0442\u044c \u0432\u044b\u0437\u043e\u0432 \u043c\u0435\u0442\u043e\u0434\u0430 Register \u0432\u043e \u0432\u0441\u0435\u0445 \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b\u0445 \u0441\u0438\u043c\u0432\u043e\u043b\u0430\u0445 \u0438 \u0438\u0441\u0445\u043e\u0434\u043d\u0438\u043a\u0430\u0445 \u0432 \u043f\u0440\u043e\u0435\u043a\u0442\u0435. \u0418\u2026 \u041a\u0430\u0436\u0435\u0442\u0441\u044f, \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u043e\u0441\u044c.<\/p>\n<figure class=\"full-width\"><figcaption>\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u044b \u043f\u043e\u0438\u0441\u043a\u0430 \u043f\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u0443 \u0432\u044b\u0437\u043e\u0432\u0430 \u043c\u0435\u0442\u043e\u0434\u0430 \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0430\u0446\u0438\u0438.<\/figcaption><\/figure>\n<p>Oracle-\u043a\u043b\u0438\u0435\u043d\u0442\u0430 \u044f \u0432\u0441\u0435 \u0440\u0430\u0432\u043d\u043e \u043d\u0435 \u043d\u0430\u0448\u0435\u043b, \u043d\u043e \u043d\u0430\u0448\u0435\u043b \u043e\u0447\u0435\u043d\u044c \u043f\u043e\u0445\u043e\u0436\u0435\u0435 \u0432 Postgre. \u0421\u043a\u043e\u0440\u0435\u0435 \u0436\u0435 \u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c, \u0447\u0442\u043e \u0442\u0430\u043c \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442:<\/p>\n<pre><code class=\"cs\">async ValueTask&lt;NpgsqlDataReader&gt; ExecuteReaderAsync(CommandBehavior behavior, bool async, CancellationToken cancellationToken) {     var connector = CheckReadyAndGetConnector();     connector.StartUserAction(this);     try     {         using (cancellationToken.Register(cmd =&gt; ((NpgsqlCommand)cmd!).Cancel(), this))         {             ValidateParameters(connector.TypeMapper);              switch (IsExplicitlyPrepared)             {             case true:                 Debug.Assert(_connectorPreparedOn != null);                 if (_connectorPreparedOn != connector)                 {                     \/\/ The command was prepared, but since then the connect .......<\/code><\/pre>\n<p>\u041c\u0435\u0442\u043e\u0434 \u0434\u043e\u0432\u043e\u043b\u044c\u043d\u043e \u0431\u043e\u043b\u044c\u0448\u043e\u0439, \u043d\u043e \u0442\u043e\u043a\u0435\u043d \u043e\u0442\u043c\u0435\u043d\u044b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u0432 \u043e\u0434\u043d\u043e\u043c \u043c\u0435\u0441\u0442\u0435 \u2014 \u0432 \u0441\u0430\u043c\u043e\u043c \u043d\u0430\u0447\u0430\u043b\u0435. \u0422\u043e \u0435\u0441\u0442\u044c \u043c\u044b \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0438\u0440\u0443\u0435\u043c \u043c\u0435\u0442\u043e\u0434 \u043e\u0442\u043c\u0435\u043d\u044b \u00ab\u043a\u043e\u043c\u0430\u043d\u0434\u044b\u00bb. \u0417\u043d\u0430\u0447\u0438\u0442, \u043d\u0435\u0447\u0442\u043e \u043f\u043e\u0434\u043e\u0431\u043d\u043e\u0435 \u0434\u043e\u043b\u0436\u043d\u043e \u0431\u044b\u0442\u044c \u0438 \u0432 Oracle-\u043a\u043b\u0438\u0435\u043d\u0442\u0435. \u041d\u043e \u043f\u043e\u0438\u0441\u043a \u043d\u0435 \u0434\u0430\u0432\u0430\u043b \u043d\u0438\u043a\u0430\u043a\u043e\u0439 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0438.&nbsp;<\/p>\n<p>\u0412\u044b\u0445\u043e\u0434 \u043e\u0434\u0438\u043d \u2014 \u0434\u0435\u043a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u044f. \u041f\u043e\u0441\u043b\u0435 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u043a\u043b\u0438\u043a\u043e\u0432 \u043f\u043e\u043b\u0443\u0447\u0438\u043b \u00ab\u0438\u0441\u0445\u043e\u0434\u043d\u044b\u0439\u00bb \u043a\u043e\u0434 \u043d\u0430 C#. \u041d\u043e \u0432\u043e\u0442 \u043e\u043f\u044f\u0442\u044c \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430: \u0432\u043d\u0443\u0442\u0440\u0438 \u2014 \u043d\u0438 \u0441\u043b\u043e\u0432\u0430 \u043d\u0438 \u043f\u0440\u043e Task, \u043d\u0438 \u043f\u0440\u043e Async, \u043d\u0438 \u043f\u0440\u043e CancellationToken. \u0422\u043e \u0435\u0441\u0442\u044c \u043a\u043b\u0438\u0435\u043d\u0442 \u043e\u043a\u0430\u0437\u0430\u043b\u0441\u044f \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u043e \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u043d\u044b\u043c (\u0432\u043e\u0442 \u044d\u0442\u043e \u043e\u0442\u043a\u0440\u044b\u0442\u0438\u0435). \u041e\u0434\u043d\u0430\u043a\u043e, \u0435\u0441\u043b\u0438 \u0432\u043d\u0438\u043c\u0430\u0442\u0435\u043b\u044c\u043d\u0435\u0435 \u043f\u043e\u0438\u0441\u043a\u0430\u0442\u044c, \u0441\u043b\u043e\u0432\u043e Cancel \u0432\u0441\u0435-\u0442\u0430\u043a\u0438 \u0432\u0441\u0442\u0440\u0435\u0447\u0430\u0435\u0442\u0441\u044f:<\/p>\n<pre><code class=\"cs\">public override void Cancel() {     int errCode = 0;        if (ConfigBaseClass.m_TraceLevel != 0)         OraTrace.Trace(1U, \" (ENTRY) OracleCommand::Cancel()\\n\");          if (this.m_connection == null)         throw new InvalidOperationException();        this.CheckConStatus();     try     { .......<\/code><\/pre>\n<p>\u0415\u0449\u0435 \u043f\u0430\u0440\u0430 \u043a\u043b\u0438\u043a\u043e\u0432 \u043f\u0440\u0438\u0432\u043e\u0434\u0438\u0442 \u043d\u0430\u0441 \u0432 \u0431\u0430\u0437\u043e\u0432\u044b\u0439 \u043a\u043b\u0430\u0441\u0441 DbCommand \u0438 \u0432 \u043c\u0435\u0442\u043e\u0434 ExecuteDbDataReaderAsync:  <\/p>\n<pre><code class=\"cs\">\/\/\/ \u0411\u043e\u043b\u044c\u0448\u043e\u0439 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b\u0439 \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u0439 protected virtual Task&lt;DbDataReader&gt; ExecuteDbDataReaderAsync(     CommandBehavior behavior,     CancellationToken cancellationToken) {     if (cancellationToken.IsCancellationRequested)         return ADP.CreatedTaskWithCancellation&lt;DbDataReader&gt;();      CancellationTokenRegistration tokenRegistration = new CancellationTokenRegistration();      if (cancellationToken.CanBeCanceled)         tokenRegistration = cancellationToken.Register(new Action(this.CancelIgnoreFailure));      try     {         return Task.FromResult&lt;DbDataRea<\/code><\/pre>\n<\/div>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-326057","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/326057","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=326057"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/326057\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=326057"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=326057"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=326057"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}