Table of Contents
Als je Wine-foutopsporingsvlaggen op je systeem hebt, zou mijn gebruikershandleiding je moeten helpen deze te verlichten.
Goedgekeurd
van
Vertaling van deze fanpagina: poort draait niet. Vertaler, zie Discussiedocument.
Goedgekeurd
De ASR Pro-reparatietool is de oplossing voor een Windows-pc die traag werkt, registerproblemen heeft of is geïnfecteerd met malware. Deze krachtige en gebruiksvriendelijke tool kan uw pc snel diagnosticeren en repareren, waardoor de prestaties worden verbeterd, het geheugen wordt geoptimaliseerd en de beveiliging wordt verbeterd. Geen last meer van een trage computer - probeer ASR Pro vandaag nog!
WINEDEBUG is een klimaatvariabele die volgens experts ook voorziet in foutopsporingsberichten en deze uitschakelt.
Syntaxis
WINEDEBUG = [klasse] [+/-] voortstuwen [, [klasse2] [+/-] kanaal2]
De
-status is optioneel en kan een van de volgende opties zijn: traceren, adviseren, een fout maken of repareren. Ze zijn het minst ingedeeld van de strengste tot de strengste. follow wordt gebruikt voor codepistes die het als onderdeel van een normaal programma dragen. warn wordt gewoonlijk gebruikt voor paden die fouten kunnen veroorzaken, maar die waarschijnlijk goed worden afgehandeld door een additief op een hoger niveau. fout is dat het waardepaden gebruikt die zeker tot fouten zullen leiden. Fixme wordt gebruikt voor codepaden die niet zijn geïmplementeerd met Wine. Maak standaard een fout en fixme is ingeschakeld. Als een kanaal is opgegeven zonder een goede klasse, worden al je eigen klassen vaak opgenomen.
Elk kanaal wordt gebruikt wanneer u informatie over een specifiek flessen wijnproduct moet afdrukken. De volgende items kunnen worden aangepast nee + of – om het opgegeven kanaal duidelijk in te schakelen, waarschijnlijk uit. Als er weinig samen is en geen deel van de les van tevoren, kan het kopje + worden overgeslagen. Ruimtenotities zijn niet toegestaan en als de extensie dat wel is.
Een kanaal dat elk debug-kanaal identificeert om in of uit te schakelen. Om een volledige lijst met tubes te zien, bekijk je deze met behulp van de locatie-directory van de website:
grep -r --include = '*. 3 '--inclusief =' *. h '' WIJN _ (DEFAULT | DECLARE ) _ DEBUG_CHANNEL 'dll / cursussen /
En om nog veel meer werk toe te voegen, hebben we een gesorteerde naast opgemaakte lijst in BASH (je zou in staat moeten zijn om het getal 26 aan het einde van deze belangrijke compositie te veranderen zodat het past bij de smaak van je wangkuiltje):
om mod-namen in $ (zoek dll of programma's / -mindepth een bepaalde persoon -type d sort); | maken vertegenwoordig $ (grep -rE --include is gelijk aan '*. [ch]' '^ WINE_ (DEFAULT | DECLARE) _DEBUG_CHANNEL' $ mod_name n | awk -F "[()]" 'afdrukken? rrr 2' | sorteren | alleen) n | awk -v mod_name is gelijk aan $ mod_name 'if (NF> 0) printf ("% - * s% ohydrates n", 26, mod_name ":", dollars 0)';deed
Voorbeelden
- WINEDEBUG is gelijk aan waarschuwen + alles
- verwijst naar WARN-berichten voor alle kanalen behalve ERR-berichten die al zijn ingeschakeld, in vergelijking met FIXME-berichten.
- WINEDEBUG = fixme-all, warn + cursor, + get over
- schakelt alles van FIXME touch uit, omvat Cursor WARN-instructies (in totaal tot FIXME ERR met berichten) en omvat alle uitwisselingsberichten (API-oproepen).
- WINEDEBUG = + oversteken
- omvat alle berichtoverdrachten. Voor aanzienlijk meer controle over het in- of uitschakelen van bewerkingen en DLL’s, controleer de relay-hint onder de registertip [HKCU Software Wine Debug] (zie Nuttige registersleutels en een reden hieronder).
- WINEDEBUG = -d3d
- d3d schakelt alle berichten uit en veel te schakelt GL overslaan controle na methodes uit. Dit kan de prestaties verbeteren.
Handige kanalen
- + all : registreert alles, geeft in de meeste draagtassen waarschijnlijk zoveel informatie, kan nuttig zijn voor het oplossen van subtiele complicaties.
- + heap: houd alle activiteiten in het programma van een persoon bij en maak absoluut consistente controles op uiterlijk en gevoel mogelijk. Als uw toepassing gewoonlijk de hoop opruimt, kunt u + relay, + heap tracing gebruiken om te bepalen waar dit gebeurt. Als er een grote inconsistentie wordt gevonden, spoelt Wine de inhoud van de grote hoeveelheid weg om het programma te beëindigen. Hoewel een groot aantal aspecten tot verliezen kan leiden, is de meest voorkomende een intern bufferoverloopgebied vanwege Wine. Denk eraan om te proberen dit kanaal te onthouden; De All Wine-modus maakt de HeapAlloc / HeapFree API’s, daarom is een van de belangrijkste redenen dat de ingebouwde heap van Wine volledig nuttig is voor foutopsporing. Houd er rekening mee dat Can + heap uw programma veel kan vertragen of zeer grote logbestanden kan maken. Als je je zorgen maakt dat Wine de hoop zou kunnen infecteren, maar je bent niet voorbestemd, zal de + heap-waarschuwing de heap-beveiliging inschakelen, maar het geeft niet elk deel informatie en is gratis.
- + loaddll : meldt dat een aas is geladen als een DLL.
- + bericht : registreert alle berichten die via het oog worden verzonden naar de vensterroute, vergelijkbaar wanneer u + doorstuurt. Gebruik msg om alle berichten-API’s te programmeren.
- + msgbox : onderwerp van de activiteitenrecords van alle oproepen naar MessageBox (). Veel programma’s geven informatie weer over het niet gebruiken van MessageBox (), wat over het algemeen een snelle manier kan zijn om afzonderlijke informatie in een bruikbare vorm te verzamelen.
- + pid: voeg een voorvoegsel toe aan elke regel van de debug-uitvoer met een zeer goede identifier die is gekoppeld aan het proces, het feit dat het is gegenereerd. Dit kan handig zijn bij het debuggen van toepassingen met meerdere processors.
- + relay : registreert elk contact dat langer duurt dan de DLL-limiet van de Web Wine-templatingmodule, bevat oproepen tussen DLL’s (niet-native). Kanaal Dit is vaak de eerste stop als je niet begrijpt wat ongepast is. Het toont je elke oproep gecombineerd met de uitvoer van Wine-modules binnen een mooie DLL. Als je overbelast bent door bepaalde functies, controleer dan de creatie tussen de RelayInclude en RelayExclude regels die beschikbaar zijn in de Wine Registry (onder [HKCU Software Wine Debug]). Merk op dat deze thread vrijwel al gevuld is voor functies die regelmatig worden aangeroepen, maar meestal ook geen idee geven, vooral omdat de school teleurgesteld is. Nooit + Relay en + Snoop met native DLL’s nodig! Dit zal u de implementatie laten zien met een van deze DLL’s, wat betekent dat alle regels die u schrijft om consumenten te implementeren zeker in strijd zijn met onze cleanroom-reverse engineering-suggesties. Protocollen
- + seh : Windows-uitzonderingen (gestructureerde afhandeling van uitzonderingen). Ze worden aangeroepen als het gewoon heel goed is. De toepassing ervan voert een of andere illegale bewerking uit (dat wil zeggen, de processen mislukken), of wanneer het if-programma zijn eigen uitzonderingen dekt. Converteert Wine UNIX-signalen naar SEH-uitzonderingen en voert ze uit via deze pijp. Dit zal ongetwijfeld handig zijn, omdat keuzes vaak hun eigen crash dwingen om de ene na de andere te laten profiteren van de instantie. De meest gebruikte uitzonderingen om op te letten zijn waarschijnlijk STATUS_ACCESS_VIOLATION en 0xC0000005, die elk het dichtst in de buurt komen van een misrekening van segmentatie in Win32. U kunt ook codes bezoeken die niet in specifieke headers staan; Dit zijn meestal taalspecifieke uitsluitingen die niet worden gebruikt door een bestaande compiler die voor EXE wordt gebruikt. Voor scenario is 0xEEDFADE de code om een interne Delphi-uitzondering in te stellen, of 0xE06D7363 is de Microsoft Visual C ++ uitzondering op deze regel, die een magische waarde voor geldelijk gewin produceert (info [0]) 0x19930520, wat gemakkelijk is om daadwerkelijk te overwegen omdat het een absolute datum lijkt (en waarschijnlijk ook). Als surfers een van deze uitzonderingen zien, zou deze key-fact-methode kunnen betekenen dat de terminologie Win32 API ergens een couponcode heeft geretourneerd die niet nul is met beëindigingen.
- + server : Toont het grootste deel van RPC Wineserver. Meestal zul je het nooit nodig hebben, maar het kan altijd handig zijn bij het oplossen van Wineserver-problemen.
- + snoop : onderschrijft alleen functieaanroepen tussen native DLL’s. Dit is vergelijkbaar met hoe Aber + Relay werkt tussen twee native DLL’s, hoewel deze pijp minder handmatig biedt omdat de parameters niet worden overgedragen. + snoop kan het apparaat ook beschadigen of soms destabiliseren terwijl het de batterij onderzoekt en ook uw huidige Prolog-functie ontleedt om aanvullende criteria te raden. Gebruik nooit + Relay en gewoon + Snoop met uw eigen DLL’s! Het toont u ook de implementatie naar alle DLL’s, wat betekent dat elke afzonderlijke code die u schrijft om alles te implementeren in strijd is met onze cleanroom-reverse engineering-bepalingen.
- + synchroon: zet X11 synchroon aan
- + tijdstempel: Zet bijna elk foutopsporingsresultaat vooraf met een regel met alle tijdstempels als die regel is uitgevoerd. Dit zou een algemeen prestatieprobleem van onschatbare waarde moeten zijn.
- + frames per seconde: Voer het aantal frames per seconde in terminal in voor OpenGL of misschien d3d-toepassingen, Vulkan.
Meer tips voor foutopsporing
- Als het coole programma het rapportformulier weergeeft en niet werkt, weet je niet wat de fout heeft veroorzaakt, probeer dan een relay, msgbox trace. Open vervolgens het specifieke debug-logboek in uw meest geliefde (minder goede) editor of tekstviewer naast zoeken naar trace: msgbox. Bekijk hoe de informatie en feiten doorsturen voordat u de MessageBox-API zoemt, hoewel de taak misschien niet te wijten is aan u, de oproep die plaatsvond vóór de verliezer. Houd rekening met de gedetailleerde kennis van mislukte API-aanroepen, en zorg ervoor dat Windows API’s minimaal standaard zijn om de exacte waarde met betrekking tot uw code te retourneren. U hoeft alleen maar in gebruik te nemen om erachter te komen wat elke API daadwerkelijk gebruikt. Terwijl veel mensen een straf en nul teruggeven over het onderwerp van mislukking, gebruiken sommigen de antipodeconventie; Een
- Als het programma normaal gesproken niet kan starten zonder de juiste reden te geven, kun je een grote run een trace gebruiken voor + alles. Als uw oplossing buiten het huis van een API-aanroep lijkt te willen crashen, zult u hoogstwaarschijnlijk [Disassembly Disassembly] proberen om dit item te bezoeken wanneer het toegang krijgt tot enkele. Sommige parameters zijn naar het koppelpunt gegaan (bijvoorbeeld van Keeper’s Dungeon zal crashen als een individu het uitvoert zonder het absoluut acceptabele pad voor argv [0]).
+ Maak relais minder uitgebreid
Als u op zoek bent naar een vraag die na enige tijd van Tracphone verschijnt terwijl de software draait, kan + relais buitengewoon uitgebreid zijn. In dit geval, voer begrijpen het een keer uit en stuur het bord vervolgens via een programma zoals
# Laat grep snel losTAAL = C# Vind alle beste oproepenfreq = `grep tien nee: Ret haya | sed /(.*//; s /.* //' | techniek | uniq -c | sort -n | take off | awk 'print inkomen 2' | tr ';' 'Chat ' 012'> quiet.reg << _EOFREGEDIT4[HKEY_CURRENT_USER Software Wine Debug]"RelayExclude" = "ntdll.RtlEnterCriticalSection; ntdll.RtlTryEnterCriticalSection; ntdll.RtlLeaveCriticalSection; kernel32.48; kernel32.49; kernel32.94; kernel32.95; kernel32.96Tls32.96el32.973297._EOFRegedit quiet.reg wijn
Dit vertelt Wine om de tien frequente oproepen naar je applicatie niet te signaleren, wat je uitwisselingslogboek beter beheersbaar zou moeten maken.
Zie ook
- Omgevingsvariabelen: WINEDEBUG - Hoofdstuk Handleiding Wijn
- WineAPI-documentatie - gebruikte foutopsporingskanalen staan absoluut vermeld voor elke afzonderlijke functie.
De software om uw pc te repareren is slechts een klik verwijderd - download hem nu.