segmentation-fault

___ answer12939451 ___

Es ist schwierig, einen String in C anzufügen. Versuchen Sie Folgendes:

%Vor%

Vergessen Sie nicht, die zurückgegebene Zeichenfolge zu entfernen, wenn Sie damit fertig sind.

FYI: Es segregiert wahrscheinlich, weil die Zeichenfolge, die Sie übergeben, im schreibgeschützten Speicher gespeichert ist. Aber du hast recht, du schreibst auch vom Ende ab (das %code% schreibt, nicht das %code% eins).

    
___ qstntxt ___

Ich versuche also ein %code% an ein %code% anzuhängen.

Zum Beispiel habe ich %code% Ich habe auch %code%

Ich mache %code% Mit dieser Methode ..

%Vor%

Es gibt mir einen Segmentierungsfehler und ich verstehe, warum ich annehme. Weil %code% außerhalb der Grenzen liegt. Wie kann ich es so machen, dass es funktioniert? Ich muss auch die %code% viel löschen, wenn ich etwas wie char word [500] verwenden möchte; Wie würde ich das klarstellen, sobald es einige Zeichen angehängt hat? Wäre die %code% immer %code% ? Vielen Dank im Voraus.

    
___ qstnhdr ___ C Anhängen an char * ___ tag123c ___ C ist eine universelle Computerprogrammiersprache, die für Betriebssysteme, Bibliotheken, Spiele und andere Hochleistungsanwendungen verwendet wird. Dieses Tag sollte bei allgemeinen Fragen zur C-Sprache verwendet werden, wie in der Norm ISO 9899: 2011 definiert. Fügen Sie ggf. ein versionsspezifisches Tag wie c99 oder c90 für Fragen zu älteren Sprachstandards hinzu. C unterscheidet sich von C ++ und es sollte nicht mit dem C ++ - Tag kombiniert werden, wenn ein rationaler Grund fehlt. ___ tag123string ___ Eine Zeichenfolge ist eine endliche Abfolge von Symbolen, die üblicherweise für Text verwendet wird, manchmal jedoch auch für beliebige Daten. ___ answer12939421 ___

Wenn du vorbeikommst

%Vor%

es wird abstürzen, weil foo normalerweise in readonly Speicher gelegt wird. Selbst wenn es nicht ist, wird es wahrscheinlich etwas Schlechtes überschreiben! In diesem Fall sollte der Compiler, wenn er so ist, Sie vor der Konvertierung von const char * zu char * warnen, was ein Hinweis wäre.

    
___ answer12939440 ___

Typische C-Praxis wäre wie folgt:

%Vor%

Beim Übergeben einer Funktion hat ein Array zum Ändern der Funktion keine Ahnung, wie viel Platz es zur Kompilierzeit hat. Übliche Übung in C besteht darin, auch die Länge des Arrays zu übergeben, und die Funktion wird dieser Grenze vertrauen und scheitern, wenn sie ihre Arbeit in dem Raum, den sie hat, nicht ausführen kann. Eine weitere Option ist das Neuzuordnen und Zurückgeben des neuen Arrays. Sie müssten %code% oder %code% als Eingabe zurückgeben, aber Sie müssen sorgfältig überlegen, wie Sie in dieser Situation den Heapspeicher verwalten. Aber ohne Neuzuweisung, ja, Ihre Funktion muss irgendwie fehlschlagen, wenn sie angefügt werden soll, wenn kein Platz mehr übrig ist, liegt es an Ihnen, wie Sie scheitern können.

    
___ answer12939502 ___

Ja, die Annahme, die Sie getroffen haben, ist - fast - korrekt - der Absturz könnte darauf zurückzuführen sein, dass Sie versuchen, über die Grenzen der Zeichenfolge hinaus zu schreiben (tatsächlich ist %code% außerhalb der Grenzen, weil %code% immer noch ein ist) gültiger Ort - dort wird das abschließende NUL-Byte gespeichert. Sie können jedoch auch kein Zeichenfolgenliteral ändern, da es sich normalerweise in einem schreibgeschützten Teil des Prozessspeichers befindet. Diese beiden Aktionen führen zum Aufruf von undefiniertem Verhalten, das möglicherweise abstürzen kann. Sie können dieses Problem lösen, indem Sie die Zeichenfolge in einen dynamisch zugewiesenen Speicher kopieren und dann die Kopie ändern. Außerdem sollten Sie %code% im Argument Ihrer Funktion verwenden, weil %code% vorschlägt, dass schreibgeschützte Zeichenfolgen nicht übergeben werden können.

%Vor%

Vergessen Sie auch nicht %code% die zurückgegebene Zeichenfolge, wenn sie nicht mehr benötigt wird.

    
___ tag123char ___ char bezieht sich in der Regel auf einen Zeichentyp, der Buchstaben von Text darstellt. ___ answer12939530 ___

Sie können nicht wirklich sicher an eine beliebige Zeichenkette anhängen, weil zum einen String-Konstanten dazu neigen, im Nur-Lese-Speicher zu sein. Wenn Sie also versuchen, in sie zu schreiben, führt dies wahrscheinlich zu einem Segmentierungsfehler garantiere, dass, wenn sie dir einen Puffer übergeben haben, den du nicht über das Ende davon geschossen hast.

Insbesondere, wenn Sie das tun     char x [500];

es gibt keine Garantie, dass strlen (x) Ihnen 500 zurückgibt. Es gibt Ihnen zurück, wie viele Zeichen es vom Start von x vorwärts zählen muss, bevor es eine Null erreicht. Es könnte Ihnen 0, 1 ... 500, 501 ... zurückgeben, abhängig davon, was in x ist.

Wirklich Ihre einzigen Optionen sind, Append mit der Größe des Puffers aufzurufen, an den Sie anhängen (damit Sie etwas passendes tun können, wenn der Puffer voll ist), oder append einen neuen Puffer bei jedem Aufruf zu reservieren, in In diesem Fall müssen Sie natürlich den Puffer wieder freigeben.

    
___ tag123segmentierungsfehler ___ Segmentierungsfehler treten auf, wenn auf Speicher zugegriffen wird, der nicht zu Ihrem Prozess gehört. Verwenden Sie dieses Tag zusammen mit einem Tag, das die Sprache angibt, und einem Tag, der das Betriebssystem angibt. Segmentierungsfehler sind typischerweise das Ergebnis einer Dereferenzierungsoperation mit Zeigervariablen (die meistens eine ungültige Adresse enthalten) oder eines Pufferüberlaufs. Die Ursache für einen ungültigen Zeigerwert kann weit von der Stelle entfernt sein, an der der Segmentierungsfehler generiert wird. ___ tag123append ___ Anzufügen ist, um am Ende von etwas beizutreten oder hinzuzufügen. ___
2
Antworten

Segmentierungsfehler verursacht durch pthread_kill

GDB sagt mir, dass pthread_kill einen Segmentierungsfehler in meinem Programm verursacht. Im Grunde verwende ich pthread_kill , um zu überprüfen, ob ein Thread lebt oder nicht seine ID gegeben hat. Ich habe im Internet gesucht und festge...
12.12.2011, 23:15
2
Antworten

node.js Segmentierungsfehler: 11

hat ein Problem beim Abrufen von node.js. Ich bin auf OSX Lion, befolgte die Installationsanweisungen für Knoten. Ich bin auf v0.5.9-pre, nach Knoten - Version, aber wenn ich versuche, auszuführen Knoten app.js Ich bekomme "Segmentation fa...
07.10.2011, 21:55
2
Antworten

Kann ein Zeiger ohne Dereferenzierung noch segfault inkrementieren oder andere (un) definierte Gemeinheiten haben?

Alle Beispiele, die ich online finden konnte, um einen Zeiger zu erhöhen, der einen segfault verursacht, beinhaltete die Dereferenzierung des Zeigers - was ist, wenn ich nur inkrementieren möchte (zum Beispiel am Ende einer for-Schleife) und ich...
08.01.2016, 15:22
1
Antwort

Warum wird das Signal segfault on * nix als 'SIGSEGV' und nicht 'SIGSEGF' abgekürzt?

Gibt es einen historischen Grund? Gibt es überhaupt irgendeinen Grund oder war es reiner Zufall? Wikipedia ist mir diesmal nicht gelungen, daher hoffe ich, dass Sie mir einige Informationen / eine Antwort geben können. :)     
27.04.2011, 19:11
1
Antwort

Nicht definierte Elemente im struct-Array

Ich erstelle eine Client / Server-Anwendung und möchte Funktionen dynamisch aufrufen. Ich habe die folgende Struktur erstellt: %Vor% Wenn der Client einen Befehl an den Server sendet, durchsucht der Server ein Array von Befehlen: %Vor% B...
20.06.2014, 17:09
1
Antwort

Segmentationsfehler im Aerospike Python-Client

Ich verwende Aerospike Python CLient, um ein Schlüssel / Wert-Paar zu setzen und zu erhalten: %Vor% Nach dem Put endet mein Programm jedoch mit SEGFAULT während des Befehls Get . Im Folgenden ist der Stack-Trace, den ich von GDB erhalte...
30.03.2016, 07:17
4
Antworten

Warum führt das Folgende zu Segmentierungsfehlern?

%Vor% Warum temp[3]='F'; wird einen Segmentierungsfehler verursachen, da temp nicht const ? ist     
20.11.2010, 03:13
2
Antworten

Derselbe Programmcode mit demselben Compiler führt zu verschiedenen Binaries

Ich habe ein Problem mit meinem Code, das einige sehr merkwürdige Symptome hat. Der Code ist auf meinem Computer mit den folgenden Versionen kompiliert: a. GCC-Version: 4.4.2 b. CMAKE-Verson: 2.8.7 c. QNX (Betriebssystem) Version:...
16.11.2012, 01:21
5
Antworten

einfachste Methode zum Debuggen von Abstürzen in nativer Bibliothek, verknüpft mit Android App?

Ich habe portiert und mehrere Low-Level-C-Bibliotheken für Android für meine Anwendung in meiner Anwendung erstellt. Ich kompilierte sie mithilfe des NDK und verknüpfte sie dann mit System.loadLibrary (). Nach einiger Zeit stürzt meine Anwendung...
28.07.2011, 15:40
1
Antwort

Hauptprogramm und gemeinsam genutzte Bibliothek initialisiert dieselbe statische Variable in __static_initialization_and_destruction_0

Weiß jemand, warum eine in dlopen () initialisierte Bibliothek eine statische Variable initialisiert, die dem Hauptprogramm gehört? Sowohl das Hauptprogramm als auch die gemeinsam genutzte Bibliothek haben eine Kopie der statischen Variable, abe...
13.04.2010, 17:57