René's URL Explorer Experiment


Title: When IterableWrapper iterates up to the middle of list, System.AccessViolationException occurs. by JakeJP · Pull Request #2280 · pythonnet/pythonnet · GitHub

Open Graph Title: When IterableWrapper iterates up to the middle of list, System.AccessViolationException occurs. by JakeJP · Pull Request #2280 · pythonnet/pythonnet

X Title: When IterableWrapper iterates up to the middle of list, System.AccessViolationException occurs. by JakeJP · Pull Request #2280 · pythonnet/pythonnet

Description: System.AccessViolationException occurs when iteration quits in the middle of list before reaching the end. Environment Pythonnet version: 3.0.3 Python version: 3.12.0 Operating System: Windows 11 .NET Runtime: .NET Framework 4.8 Reproduce the problem I'm trying to pass a list from python to .NET method via List Codec. mylist = ["a","b","c"] dotnet.method( mylist ) Conversion(decode) is successful and mylist is wrapped by ListWrapper. .NET code receives the list like this. void method( IList mylist ) { mylist.First( s => s == "b" ); // <- here the crash with System.AccessViolationException } Using Enumerator of mylist, if enumerated to the end of the list, nothing bad happens. However if iteration didn't go to the end of the list, AccessViolationException is thrown. This case happens in the following code: mylist.First( s => s == "b" ); // iteration stops at the 2nd item similarly foreach( var item in mylist ) { if( item == "b" ) break; // iteration stops at the 2nd item } mylist.Contains("b"); // iteration stops at the 2nd item mylist.Any( s => s == "b"); // iteration stops at the 2nd item The following code doesn't throw exception becuase it always iterates to the end of the list. mylist.ToList(); mylist.ToArray(); Exception occurs because PyIter(ator) object is Dispose(d) outside of GIL protection only when iteration ends before reaching the end ( before MoveNext() returns null ). In such a case, code process just slips out of GIL enclosure as the nature of C# scope and yield return and break. solution for now original code is like this: public IEnumerator GetEnumerator() { PyIter iterObject; using (Py.GIL()) { iterObject = PyIter.GetIter(pyObject); } using var _ = iterObject; while (true) { using var GIL = Py.GIL(); if (!iterObject.MoveNext()) { iterObject.Dispose(); break; } yield return iterObject.Current.As()!; } } using var _ = iterObject; above the while loop is the problematic line. Before iteration reaches the end, the executing process is somewhere out of the using scope. When c# caller process stops iteration(Enumeration) for some reason, c# suddely calls using var _ = iterObject; 's closing process which is iterObject.Dispose(). But here iterObject is not inside of GIL() protection. This is why exception occurs. Solution is to make sure iterObject.Dispose() is always inside of GIL protection and always executed whatever the caller process abandons the enumeration in the middle. My suggestion is to use try catch pattern. Without catching any exception it may look odd. But this is one solution to make sure the execution of Dispose and GIL scope surrounding always. public IEnumerator GetEnumerator() { PyIter iterObject; using (Py.GIL()) { iterObject = PyIter.GetIter(pyObject); } try { while (true) { using var _ = Py.GIL(); if (!iterObject.MoveNext()) { break; } yield return iterObject.Current.As()!; } } finally { using var _ = Py.GIL(); iterObject.Dispose(); } }

Open Graph Description: System.AccessViolationException occurs when iteration quits in the middle of list before reaching the end. Environment Pythonnet version: 3.0.3 Python version: 3.12.0 Operating System: Windows 11 ...

X Description: System.AccessViolationException occurs when iteration quits in the middle of list before reaching the end. Environment Pythonnet version: 3.0.3 Python version: 3.12.0 Operating System: Windows 11 ...

Opengraph URL: https://github.com/pythonnet/pythonnet/pull/2280

X: @github

direct link

Domain: github.com

route-pattern/:user_id/:repository/pull/:id/checks(.:format)
route-controllerpull_requests
route-actionchecks
fetch-noncev2:1d85b3b2-1b5c-ca7f-0963-bd86806f6bff
current-catalog-service-hash87dc3bc62d9b466312751bfd5f889726f4f1337bdff4e8be7da7c93d6c00a25a
request-idD82A:3CD5B7:BB2523:1051C21:6970BB23
html-safe-nonce7f0598ac84148c110c9c1e3602cb1d6dd0aae78c27cf9326c9af6770a28b0b60
visitor-payloadeyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiJEODJBOjNDRDVCNzpCQjI1MjM6MTA1MUMyMTo2OTcwQkIyMyIsInZpc2l0b3JfaWQiOiI5MjA0MDA2ODcyODk5Njk3NDQzIiwicmVnaW9uX2VkZ2UiOiJpYWQiLCJyZWdpb25fcmVuZGVyIjoiaWFkIn0=
visitor-hmac9aa71d2616ef3f18db16cd233b8c365cf78189ec89e7be37aad24b7dd4688ac2
hovercard-subject-tagpull_request:1590757574
github-keyboard-shortcutsrepository,pull-request-list,pull-request-conversation,pull-request-files-changed,checks,copilot
google-site-verificationApib7-x98H0j5cPqHWwSMm6dNU4GmODRoqxLiDzdx9I
octolytics-urlhttps://collector.github.com/github/collect
analytics-location///pull_requests/show/checks
fb:app_id1401488693436528
apple-itunes-appapp-id=1477376905, app-argument=https://github.com/pythonnet/pythonnet/pull/2280/checks
twitter:imagehttps://avatars.githubusercontent.com/u/318651?s=400&v=4
twitter:cardsummary_large_image
og:imagehttps://avatars.githubusercontent.com/u/318651?s=400&v=4
og:image:altSystem.AccessViolationException occurs when iteration quits in the middle of list before reaching the end. Environment Pythonnet version: 3.0.3 Python version: 3.12.0 Operating System: Windows 11 ...
og:site_nameGitHub
og:typeobject
hostnamegithub.com
expected-hostnamegithub.com
None8e0be80373b724b033cdf8a7b1f78bf5fb6a5d7a2182a9a403aa30894606e390
turbo-cache-controlno-preview
go-importgithub.com/pythonnet/pythonnet git https://github.com/pythonnet/pythonnet.git
octolytics-dimension-user_id6050430
octolytics-dimension-user_loginpythonnet
octolytics-dimension-repository_id14748123
octolytics-dimension-repository_nwopythonnet/pythonnet
octolytics-dimension-repository_publictrue
octolytics-dimension-repository_is_forkfalse
octolytics-dimension-repository_network_root_id14748123
octolytics-dimension-repository_network_root_nwopythonnet/pythonnet
turbo-body-classeslogged-out env-production page-responsive full-width full-width-p-0
disable-turbofalse
browser-stats-urlhttps://api.github.com/_private/browser/stats
browser-errors-urlhttps://api.github.com/_private/browser/errors
release84d9d5bf3b01412ea10f7c2429cbfc735ccce9ce
ui-targetfull
theme-color#1e2327
color-schemelight dark

Links:

Skip to contenthttps://github.com/pythonnet/pythonnet/pull/2280/checks#start-of-content
https://github.com/
Sign in https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fpythonnet%2Fpythonnet%2Fpull%2F2280%2Fchecks
GitHub CopilotWrite better code with AIhttps://github.com/features/copilot
GitHub SparkBuild and deploy intelligent appshttps://github.com/features/spark
GitHub ModelsManage and compare promptshttps://github.com/features/models
MCP RegistryNewIntegrate external toolshttps://github.com/mcp
ActionsAutomate any workflowhttps://github.com/features/actions
CodespacesInstant dev environmentshttps://github.com/features/codespaces
IssuesPlan and track workhttps://github.com/features/issues
Code ReviewManage code changeshttps://github.com/features/code-review
GitHub Advanced SecurityFind and fix vulnerabilitieshttps://github.com/security/advanced-security
Code securitySecure your code as you buildhttps://github.com/security/advanced-security/code-security
Secret protectionStop leaks before they starthttps://github.com/security/advanced-security/secret-protection
Why GitHubhttps://github.com/why-github
Documentationhttps://docs.github.com
Bloghttps://github.blog
Changeloghttps://github.blog/changelog
Marketplacehttps://github.com/marketplace
View all featureshttps://github.com/features
Enterpriseshttps://github.com/enterprise
Small and medium teamshttps://github.com/team
Startupshttps://github.com/enterprise/startups
Nonprofitshttps://github.com/solutions/industry/nonprofits
App Modernizationhttps://github.com/solutions/use-case/app-modernization
DevSecOpshttps://github.com/solutions/use-case/devsecops
DevOpshttps://github.com/solutions/use-case/devops
CI/CDhttps://github.com/solutions/use-case/ci-cd
View all use caseshttps://github.com/solutions/use-case
Healthcarehttps://github.com/solutions/industry/healthcare
Financial serviceshttps://github.com/solutions/industry/financial-services
Manufacturinghttps://github.com/solutions/industry/manufacturing
Governmenthttps://github.com/solutions/industry/government
View all industrieshttps://github.com/solutions/industry
View all solutionshttps://github.com/solutions
AIhttps://github.com/resources/articles?topic=ai
Software Developmenthttps://github.com/resources/articles?topic=software-development
DevOpshttps://github.com/resources/articles?topic=devops
Securityhttps://github.com/resources/articles?topic=security
View all topicshttps://github.com/resources/articles
Customer storieshttps://github.com/customer-stories
Events & webinarshttps://github.com/resources/events
Ebooks & reportshttps://github.com/resources/whitepapers
Business insightshttps://github.com/solutions/executive-insights
GitHub Skillshttps://skills.github.com
Documentationhttps://docs.github.com
Customer supporthttps://support.github.com
Community forumhttps://github.com/orgs/community/discussions
Trust centerhttps://github.com/trust-center
Partnershttps://github.com/partners
GitHub SponsorsFund open source developershttps://github.com/sponsors
Security Labhttps://securitylab.github.com
Maintainer Communityhttps://maintainers.github.com
Acceleratorhttps://github.com/accelerator
Archive Programhttps://archiveprogram.github.com
Topicshttps://github.com/topics
Trendinghttps://github.com/trending
Collectionshttps://github.com/collections
Enterprise platformAI-powered developer platformhttps://github.com/enterprise
GitHub Advanced SecurityEnterprise-grade security featureshttps://github.com/security/advanced-security
Copilot for BusinessEnterprise-grade AI featureshttps://github.com/features/copilot/copilot-business
Premium SupportEnterprise-grade 24/7 supporthttps://github.com/premium-support
Pricinghttps://github.com/pricing
Search syntax tipshttps://docs.github.com/search-github/github-code-search/understanding-github-code-search-syntax
documentationhttps://docs.github.com/search-github/github-code-search/understanding-github-code-search-syntax
Sign in https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fpythonnet%2Fpythonnet%2Fpull%2F2280%2Fchecks
Sign up https://github.com/signup?ref_cta=Sign+up&ref_loc=header+logged+out&ref_page=%2F%3Cuser-name%3E%2F%3Crepo-name%3E%2Fpull_requests%2Fshow%2Fchecks&source=header-repo&source_repo=pythonnet%2Fpythonnet
Reloadhttps://github.com/pythonnet/pythonnet/pull/2280/checks
Reloadhttps://github.com/pythonnet/pythonnet/pull/2280/checks
Reloadhttps://github.com/pythonnet/pythonnet/pull/2280/checks
pythonnet https://github.com/pythonnet
pythonnethttps://github.com/pythonnet/pythonnet
Notifications https://github.com/login?return_to=%2Fpythonnet%2Fpythonnet
Fork 770 https://github.com/login?return_to=%2Fpythonnet%2Fpythonnet
Star 5.4k https://github.com/login?return_to=%2Fpythonnet%2Fpythonnet
Code https://github.com/pythonnet/pythonnet
Issues 155 https://github.com/pythonnet/pythonnet/issues
Pull requests 18 https://github.com/pythonnet/pythonnet/pulls
Discussions https://github.com/pythonnet/pythonnet/discussions
Actions https://github.com/pythonnet/pythonnet/actions
Projects 0 https://github.com/pythonnet/pythonnet/projects
Wiki https://github.com/pythonnet/pythonnet/wiki
Security Uh oh! There was an error while loading. Please reload this page. https://github.com/pythonnet/pythonnet/security
Please reload this pagehttps://github.com/pythonnet/pythonnet/pull/2280/checks
Insights https://github.com/pythonnet/pythonnet/pulse
Code https://github.com/pythonnet/pythonnet
Issues https://github.com/pythonnet/pythonnet/issues
Pull requests https://github.com/pythonnet/pythonnet/pulls
Discussions https://github.com/pythonnet/pythonnet/discussions
Actions https://github.com/pythonnet/pythonnet/actions
Projects https://github.com/pythonnet/pythonnet/projects
Wiki https://github.com/pythonnet/pythonnet/wiki
Security https://github.com/pythonnet/pythonnet/security
Insights https://github.com/pythonnet/pythonnet/pulse
Sign up for GitHub https://github.com/signup?return_to=%2Fpythonnet%2Fpythonnet%2Fissues%2Fnew%2Fchoose
terms of servicehttps://docs.github.com/terms
privacy statementhttps://docs.github.com/privacy
Sign inhttps://github.com/login?return_to=%2Fpythonnet%2Fpythonnet%2Fissues%2Fnew%2Fchoose
lostmsuhttps://github.com/lostmsu
pythonnet:masterhttps://github.com/pythonnet/pythonnet/tree/master
JakeJP:masterhttps://github.com/JakeJP/pythonnet/tree/master
Conversation 3 https://github.com/pythonnet/pythonnet/pull/2280
Commits 1 https://github.com/pythonnet/pythonnet/pull/2280/commits
Checks 0 https://github.com/pythonnet/pythonnet/pull/2280/checks
Files changed https://github.com/pythonnet/pythonnet/pull/2280/files
Please reload this pagehttps://github.com/pythonnet/pythonnet/pull/2280/checks
Please reload this pagehttps://github.com/pythonnet/pythonnet/pull/2280/checks
When IterableWrapper iterates up to the middle of list, System.AccessViolationException occurs. https://github.com/pythonnet/pythonnet/pull/2280/checks#top
Please reload this pagehttps://github.com/pythonnet/pythonnet/pull/2280/checks
https://github.com
Termshttps://docs.github.com/site-policy/github-terms/github-terms-of-service
Privacyhttps://docs.github.com/site-policy/privacy-policies/github-privacy-statement
Securityhttps://github.com/security
Statushttps://www.githubstatus.com/
Communityhttps://github.community/
Docshttps://docs.github.com/
Contacthttps://support.github.com?tags=dotcom-footer

Viewport: width=device-width


URLs of crawlers that visited me.