Jump to content

[Resolvido] Retornar String


Recommended Posts

Posted

Boas!

Eu estou com dificuldades em retornar uma string e usar o seu valor, eu estive a ver algumas coisas na net e fiz isto,.

char* pedirNome(){

 char nome[9];
 printf("Nome: ");
 fgets(nome,9,stdin);
 return nome;
}
int main(int argc, char** argv) {
 char *nome[9];
 nome=pedirNome();
 printf("Nome: %s",*nome);
}
Posted

tu no pedir nome estas a retornar uma variavel que e' destruida apos sair da funcao. Tens que alocar memora e returnar.

Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Posted

Eu ainda não dei apontadores por isso ainda não percebo muito bem, é algo assim

char* pedirNome(){

   char *nome[9];
   nome=(char*)malloc(sizeof(9));
   printf("Nome: ");
   fgets(nome,9,stdin);
   return nome;
}
Posted

seria mais algo assim:

char *pedirNome()
{
 char *nome = malloc(sizeof(char)*9);//o sizeof e' desnecessario, ja' que o char tem 1 byte
 scanf("%s",nome);
 return nome;
}

Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Posted

char *pedirNome()
{
 char *nome = malloc(sizeof(char)*9);//o sizeof e' desnecessario, ja' que o char tem 1 byte
 scanf("%s",nome);
 return nome;
}

Cuidado com heap overrun.

char *pedirNome()
{
 char *nome = malloc(sizeof(char)*9);//o sizeof e' desnecessario, ja' que o char tem 1 byte
 scanf("%8s",nome);
 return nome;
}

"[Os jovens da actual geração]não lêem porque não envolve um telecomando que dê para mirar e atirar, não falam porque a trapalhice é rainha e o calão é rei" autor: thoga31

Life is a genetically transmitted disease, induced by sex, with death rate of 100%.

Posted

na realidade, seria melhor assim :

void pedirNome(char * buffer, int buffer_size){
 printf("Nome: ");
 fgets(buffer,buffer_size,stdin);
}

int main(int argc, char** argv) {
 char nome[9]; // <------------------------------ cuidado, tinhas uma array de ponteiros !!!
 pedirNome(nome, 9);
 printf("Nome: %s",nome);
}

quantidade de malloc's e free's : 0 !!!

urra, ganhei 😄

IRC : sim, é algo que ainda existe >> #p@p
Posted (edited)

lol..

tens char * buffer, porque passas depois um array de char nome, que é a mesma coisa que passar o endereço de memoria nome[0] certo?

Edited by AJBM
Posted

Outra pergunta se eu tiver uma string numa estrutura de dados posso fazer isto Estrutura.string=outrastring; certo? é que eu faço uma atribuição desta e da me erro de tipos imcompativeis

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
×
×
  • Create New...

Important Information

By using this site you accept our Terms of Use and Privacy Policy. We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.