- Akku Tests und Balkonkraftwerk Speicher         
Seite 1 von 2 12 LetzteLetzte
Ergebnis 1 bis 10 von 16

Thema: nochmal Arraypointerreferenztohuwabohu

  1. #1
    HaWe
    Gast

    nochmal Arraypointerreferenztohuwabohu

    Anzeige

    Praxistest und DIY Projekte
    hallo,
    ich schleudere wieder bei Übergabe von arrays an Funktionen:

    ich habe einen array of cstrings
    Code:
    char mlist0[6][11] = {"Titel","ESC ","Ja","Nein","foo","bas"};
    und die folgende Funktion (in einer Klasse als Methode)
    Code:
    class tMenu {
     private:
       int MENULEN;
     public:
       char ** list; 
    
       void importlist ( char ** extlist ) {
            int16_t N = MENULEN;
            for(int line=0; line<N; line++) {
               strncpy( list[line], extlist[line], strlen(extlist[line]) );
            }
    }
    
    tMenu menu0(6,11);
    
    //
    ich will jetzt die Objekt-Methode aufrufen zum Initialisieren:


    menu0.importlist(mlist0); // exit status 1 no matching function for call to 'tMenu::importlist(char [6][11])'

    menu0.importlist(*mlist0); // exit status 1 no matching function for call to 'tMenu::importlist(char [11])'

    menu0.importlist(**mlist0); // exit status 1 invalid conversion from 'char' to 'char**' [-fpermissive]

    menu0.importlist(&mlist0); // exit status 1 no matching function for call to 'tMenu::importlist(char (*)[6][11])'

    menu0.importlist((char**)mlist0); // => runtime error:
    Exception ( 28 ):
    epc1=0x40206204 epc2=0x00000000 epc3=0x00000000 excvaddr=0x00000030 depc=0x00000000


    ich weiß nicht mehr, was ich jetzt sonst noch ausprobieren könnte...
    Geändert von HaWe (09.12.2018 um 15:24 Uhr)

  2. #2
    Erfahrener Benutzer Robotik Einstein
    Registriert seit
    18.03.2018
    Beiträge
    2.645
    Hier kann zumindest die Funktion zum Aufruf zugeordnet werden:
    menu0.importlist(**mlist0); // exit status 1 invalid conversion from 'char' to 'char**' [-fpermissive]

    Bloß die Parameterübergabe ist noch nicht i.O.:
    invalid conversion



  3. #3
    HaWe
    Gast
    ja, genau, trotzdem läuft dann was schief zur Laufzeit wenn ich explizit caste

    menu0.importlist( (char**)mlist0 );

  4. #4
    Erfahrener Benutzer Robotik Einstein
    Registriert seit
    18.03.2018
    Beiträge
    2.645
    Stört vielleicht, dass von "(**mlist0)" nach "void importlist ( char ** extlist )" konvertiert werden soll?
    Leider werde ich hier nicht weiter helfen können, weil ich mich damit zu wenig auskenne. Werde ich auch mal abstellen müssen...

  5. #5
    HaWe
    Gast
    vermutlich hat gestört, dass von der Form
    char list1[a][b]
    in die Form von
    char **list2
    übertragen werden sollte, daher mein Versuch des expliziten casts
    (char**) list1 // list1[a][b] ->-> **list1
    dann --> als Parameter für Funktion importlist (char ** list2)

    führt dann aber zu Laufzeitfehlern, wenn die array-Inhalte kopiert werden sollen

    Ich weiß nur absolut nicht, wie es stattdessen richtig geht
    Geändert von HaWe (09.12.2018 um 13:23 Uhr)

  6. #6
    Erfahrener Benutzer Robotik Einstein
    Registriert seit
    18.03.2018
    Beiträge
    2.645
    Hier definierst Du die Liste:

    Code:
    char mlist0[6][11]
    mit ** mlist0 erzeugst Du einen Zeiger. (mit dem ersten * auf mlist0[x] und mit dem zweiten * auf mlist[x][x])

    Was ist, wenn Du so den Aufruf machst: menu0.importlist(*mlist0);

    Und Deine Funktion so gestaltest: void importlist ( char * extlist )

    Weil, beim Kopieren verwendest Du ja nur:extlist[line] nicht: extlist[x][line]

    Aber wie gesagt, ich glaube, ich stifte nur mehr Verwirrung!

  7. #7
    Erfahrener Benutzer Robotik Einstein
    Registriert seit
    11.12.2007
    Ort
    weit weg von nahe Bonn
    Alter
    39
    Beiträge
    3.416
    deine Deklaration macht mir irgendwie Kopfschmerzen ... aber für die symmetrie ist es schon nicht ganz verkehrt

    (nicht böse gemeint, da schrillen nur ein paar alarmglocken)

    deklariere doch ein

    char* mlist[]

    und fülle es mit

    char* entry0 = "bla"
    char* entry1 = "foo"
    mlist[0] = entry0;
    mlist[1] = entry1;

    ist zwar etwas umständlich aber explizit

    und in deiner import funktion kannst du auch so etwas schreiben
    void importlist ( char * extlist[] )
    damit sollte es besser funktionieren, probiert haeb ich es aber nciht ... das Problem ist nämlich dass die strings dabei unterschiedlich lang sind was weider andere phänomene hervorrufen kann
    Es gibt 10 Sorten von Menschen: Die einen können binär zählen, die anderen
    nicht.

  8. #8
    Erfahrener Benutzer Robotik Einstein
    Registriert seit
    18.03.2018
    Beiträge
    2.645
    Ich habs jetzt mal so:

    void importlist (char ** extlist )

    und so:

    tMenu menu0(char ** mlist0);


    Nur so wird es für ein ESP-12E ohne Warnung und Fehler compiliert.

  9. #9
    HaWe
    Gast
    man kann eine
    char ** mlist;
    ja nicht initialisieren als
    {"Titel","ESC","Ja","Nein","foo","bas"}; // error !!

    Das ist aber wesentlich, sonst wird es bei der Initialisierung aller Menüpunkte aller Menüs und Untermenüs zu kompliziert.

    also brauche ich für den Original-Array
    char mlist[6][11] = {"Titel","ESC","Ja","Nein","foo","bas"};

    und den will ich jetzt an die Funktion
    tMenu::import() // (fraglich ob hier als Argument (char ** extlist) richtig ist ?!? )
    übergeben,

    denn man kann als Funktions-Argument kein
    import(char extlist[MENULEN][LINELEN])
    definieren, zumal MENULEN und LINELEN grundsätzlich in der Class variabel sind und keine Konstanten (ihre Größe wird erst bei Instanziierung des Objekts bekannt gegeben, wenn die interne list erzeugt wird)

    Code:
    public:      
         char ** list;
    
      tMenu (int16_t menulen, int16_t linelen, tMenu* pMenu) {   // constructor
         MENULEN = menulen;    
         LINELEN = linelen; 
         list = new char*[MENULEN];
            for(int i = 0; i < MENULEN; i++)
            {
              list[i] = new char[LINELEN+1];
            }
    habe ich es erst mal übergeben, kann ich die Liste von strings in der Objekt-Methode weiterverwenden:

    for(int line=0; line<MENULEN; line++) {
    strncpy( list[line], extlist[line], strlen( list[line] ) );
    ...

    Offenbar ist das für die Übergabe mit den ** falsch, aber wie geht es richtig?

    Wie übergibt man einen 2-dim array (bzw. eine Aufzählung von cstrings) per Pointer oder als Kopie an einen zweiten 2-dim array?
    Geändert von HaWe (09.12.2018 um 16:16 Uhr)

  10. #10
    Erfahrener Benutzer Robotik Einstein
    Registriert seit
    18.03.2018
    Beiträge
    2.645
    Code:
    char mlist0[6][11] = {"menu0","ESC >","Ja","Nein","foo","bas"};
    
    class tMenu{
     private:
       int MENULEN;
     public:
       char ** list; //char * list[];
    
    
       void importlist (char ** extlist ) {
            int16_t N = MENULEN;
            for(int line=0; line<N; line++) {
               strncpy( list[line], extlist[line], strlen(extlist[line]) );
            }
      }
    };
    
    
    void setup(){
    }
    
    
    void loop(){
      tMenu menu0(char ** mlist0);
    }

Seite 1 von 2 12 LetzteLetzte

Ähnliche Themen

  1. Nochmal zu den adc Ports
    Von Fenriz im Forum Robby RP6
    Antworten: 2
    Letzter Beitrag: 30.08.2008, 12:20
  2. Nochmal Uhrzeit
    Von martin66119 im Forum Basic-Programmierung (Bascom-Compiler)
    Antworten: 2
    Letzter Beitrag: 05.11.2007, 12:42
  3. nochmal : Greifarm
    Von JonasK im Forum Mechanik
    Antworten: 4
    Letzter Beitrag: 30.06.2007, 15:25
  4. Nochmal Roboterbau
    Von N00b|Linux im Forum Allgemeines zum Thema Roboter / Modellbau
    Antworten: 5
    Letzter Beitrag: 28.01.2005, 09:06
  5. Motortreiber (nochmal)
    Von Gottfreak im Forum Controller- und Roboterboards von Conrad.de
    Antworten: 10
    Letzter Beitrag: 20.03.2004, 14:12

Berechtigungen

  • Neue Themen erstellen: Nein
  • Themen beantworten: Nein
  • Anhänge hochladen: Nein
  • Beiträge bearbeiten: Nein
  •  

LiFePO4 Speicher Test