Bom, vc não está retornando o lugar, está retornando a pessoa. :-)

Mas eu não acredito que a exceção seja dentro deste método. Provavelmente
quando não acha ele retorna null e quando vc tenta fazer algo com o retorno
dá NullPointerException, não?

Não estou vendo nada errado com o método.

Até pq, se retorna o lugar e depois dá o erro, o método já foi terminado
(termina quando retorna), logo o erro é depois do método e não nele.

Abraço

Peter P. Lupo
http://craftnicely.blogspot.com - http://sites.google.com/site/pplupo
 <http://sites.google.com/site/pplupo>MPS.BR Authorized Implementation
Practitioner<http://www.softex.br/mpsbr/_profissionais/MPS.BR_certificados_de_arovacao_prova_P2-MPS.BR.pdf>-
Certified
ScrumMaster <http://www.scrumalliance.org/pages/certified_scrummaster>
 <http://www.scrumalliance.org/pages/certified_scrummaster>Oracle Certified
Associate, Java SE 5/SE
6<http://in.sun.com/training/certification/java/scja.xml> -
Java Black Belt <http://www.blackbeltfactory.com/ui#!User/pplupo>
 <http://www.blackbeltfactory.com/ui#!User/pplupo>+55 (021) 81742487



2011/4/10 Lucian Sturião <[email protected]>

> public static Pessoa procurarPessoa (String nome, ArrayList<Pessoa> lista)
> {
> Pessoa lugar = null;
>  for (int i = 0; i < lista.size(); i ++)
> {
> if (nome.equalsIgnoreCase(lista.get(i).getNome())) {
>  lugar = lista.get(i);
> break;
> }
>  }
>  return lugar;
>  }
>
> Se o nome da pessoa é joaozinho por exemplo, e eu procuro por joao, o
> método retorna o lugar do joaozinho e dá uma exception.
>
> Em 10 de abril de 2011 12:02, Peter P. Lupo <[email protected]> escreveu:
>
>  Como vc fez?
>>
>> Não é pra usar no if dentro do for, é pra usar em substituição ao for,
>> comparando os nomes diretamente e não seus caracteres.
>>
>> Abraço
>>
>>
>> Peter P. Lupo
>> http://craftnicely.blogspot.com - http://sites.google.com/site/pplupo
>>  <http://sites.google.com/site/pplupo>MPS.BR Authorized Implementation
>> Practitioner<http://www.softex.br/mpsbr/_profissionais/MPS.BR_certificados_de_arovacao_prova_P2-MPS.BR.pdf>-
>>  Certified
>> ScrumMaster <http://www.scrumalliance.org/pages/certified_scrummaster>
>>  <http://www.scrumalliance.org/pages/certified_scrummaster>Oracle
>> Certified Associate, Java SE 5/SE 
>> 6<http://in.sun.com/training/certification/java/scja.xml> -
>> Java Black Belt <http://www.blackbeltfactory.com/ui#!User/pplupo>
>>  <http://www.blackbeltfactory.com/ui#!User/pplupo>+55 (021) 81742487
>>
>>
>>
>> 2011/4/10 Lucian Sturião <[email protected]>
>>
>>> É que eu estava usando o equalsIgnoreCase (dica de outra lista) e mesmo
>>> assim deu a Exception quando o nome do objeto era maior que o nome
>>> procurado.
>>>
>>> Em 10 de abril de 2011 11:43, Peter P. Lupo <[email protected]> escreveu:
>>>
>>> Depende. Se cada caractere for instância de Character, é um objeto. Se
>>>> for simplesmente um valor tipo char, é um tipo primitivo. Assim vc tb vai
>>>> encontrar Integer/int, Double/double, Float/float, Boolean/boolean, etc...
>>>> Neste caso aí, cada caractere é um char mesmo, eu acho. Me equivoquei no
>>>> primeiro exemplo.
>>>>
>>>> Sim, comparando os tamanhos vc se livra do problema mas vc tb pode
>>>> simplesmente usar equals ou equalsIgnoreCase de String para comparar os
>>>> nomes, sem ter que implementar o for vc mesmo.
>>>>
>>>> Assim fica mais claro o que vc está querendo fazer além de vc não perder
>>>> tempo fazendo algo com bugs que já existe feito e testado.
>>>>
>>>> Abraço
>>>>
>>>> Peter P. Lupo
>>>> http://craftnicely.blogspot.com - http://sites.google.com/site/pplupo
>>>>  <http://sites.google.com/site/pplupo>MPS.BR Authorized Implementation
>>>> Practitioner<http://www.softex.br/mpsbr/_profissionais/MPS.BR_certificados_de_arovacao_prova_P2-MPS.BR.pdf>-
>>>>  Certified
>>>> ScrumMaster <http://www.scrumalliance.org/pages/certified_scrummaster>
>>>>  <http://www.scrumalliance.org/pages/certified_scrummaster>Oracle
>>>> Certified Associate, Java SE 5/SE 
>>>> 6<http://in.sun.com/training/certification/java/scja.xml> -
>>>> Java Black Belt <http://www.blackbeltfactory.com/ui#!User/pplupo>
>>>>  <http://www.blackbeltfactory.com/ui#!User/pplupo>+55 (021) 81742487
>>>>
>>>>
>>>>
>>>> 2011/4/10 Lucian Sturião <[email protected]>
>>>>
>>>>> Cada caractere também é um objeto?
>>>>> Então será que usando já uma condição pra comparar o tamanho dos nomes
>>>>> logo no começo contornaria essa exceção?
>>>>>
>>>>> Em 10 de abril de 2011 11:00, Peter P. Lupo <[email protected]>escreveu:
>>>>>
>>>>> Sim, isto deve resolver, mas há diversas soluções:
>>>>>>
>>>>>>
>>>>>>  public boolean equalsNome (String nome) {
>>>>>>  for (int i = 0; i < this.nome.length(); i++) {
>>>>>> if (this.nome.charAt(i)*.equals(*nome.charAt(i))*)* return true;
>>>>>>  }
>>>>>>  return false;
>>>>>> }
>>>>>>
>>>>>> SEMPRE que você quiser saber se dois objetos são de valores iguais,
>>>>>> chame o equals. == ou != só serve para dizer se são o mesmo objeto (se 
>>>>>> estão
>>>>>> na mesma posição de memória) e não para dizer se são iguais (podem ser 
>>>>>> dois
>>>>>> objetos distintos, mas iguais em valor). Isso é matéria e pode cair em
>>>>>> prova. Se não entendeu com esta explicação de uma linha e meia, pergunte.
>>>>>>
>>>>>> Se você implementar a sugestão do Thiago, vc pode usar o contains no
>>>>>> lugar do seu método equalsNome:
>>>>>>
>>>>>> todasPessoas.contains(pessoa)
>>>>>> ou
>>>>>> todasPessoas.contains(new Pessoa(nome))
>>>>>>
>>>>>> e já saberá se existe ou não uma pessoa com aquele nome.
>>>>>>
>>>>>> Leia o Javadoc dos métodos equals e hashCode em Object. Se vc mudar
>>>>>> um, terá que mudar o outro. Se dois objetos forem iguais segundo o 
>>>>>> equals,
>>>>>> eles devem retornar o mesmo hashCode. Vc tb tem a opção de clicar com o
>>>>>> botão direito no código de Pessoa, ir no menu source e selecionar 
>>>>>> generate
>>>>>> equals and hashcode. O Eclipse faz pra vc. Mas não deixe de ler. É 
>>>>>> matéria e
>>>>>> pode cair em prova.
>>>>>>
>>>>>> Para saber se existe uma pessoa com aquele nome na coleção:
>>>>>>
>>>>>> public boolean equalsNome (String nome) {
>>>>>>   for (Pessoa p : todasPessoas) {
>>>>>>  if (p.getNome.equals(nome)) return true;
>>>>>> }
>>>>>>  return false;
>>>>>> }
>>>>>>
>>>>>> Em String há os métodos equals e equalsIgnoreCase para vc não ter que
>>>>>> fazer este for que vc fez.
>>>>>> E seu método tem outro problema. Sempre que this.nome for mais longo
>>>>>> que nome, vc vai ter uma exceção.
>>>>>>
>>>>>>
>>>>>> Abraço
>>>>>>
>>>>>>
>>>>>> Peter P. Lupo
>>>>>> http://craftnicely.blogspot.com - http://sites.google.com/site/pplupo
>>>>>>  <http://sites.google.com/site/pplupo>MPS.BR Authorized
>>>>>> Implementation 
>>>>>> Practitioner<http://www.softex.br/mpsbr/_profissionais/MPS.BR_certificados_de_arovacao_prova_P2-MPS.BR.pdf>-
>>>>>>  Certified
>>>>>> ScrumMaster<http://www.scrumalliance.org/pages/certified_scrummaster>
>>>>>>  <http://www.scrumalliance.org/pages/certified_scrummaster>Oracle
>>>>>> Certified Associate, Java SE 5/SE 
>>>>>> 6<http://in.sun.com/training/certification/java/scja.xml> -
>>>>>> Java Black Belt <http://www.blackbeltfactory.com/ui#!User/pplupo>
>>>>>>  <http://www.blackbeltfactory.com/ui#!User/pplupo>+55 (021) 81742487
>>>>>>
>>>>>>
>>>>>>
>>>>>> 2011/4/10 Thiago Caldeira de Lima <[email protected]>
>>>>>>
>>>>>>> Vc pode usar  " ob.equals(ob2)  ", talvez precise fazer um override
>>>>>>> do método equals da classe Pessoa.
>>>>>>>
>>>>>>> public boolean equals(pessoa p){
>>>>>>>
>>>>>>> return this.nome.equals(p.nome);
>>>>>>> }
>>>>>>>
>>>>>>> isso deve resolver =]
>>>>>>>
>>>>>>> public boolean equals(Object obj) {
>>>>>>>
>>>>>>>
>>>>>>> 2011/4/10 Lucian Sturião <[email protected]>
>>>>>>>
>>>>>>>> Estou tentando fazer um programa de cadastro de pessoas em Java. No
>>>>>>>> meu programa cada pessoa teria: nome, reserva, pagamentos 1 2 e 3, e 
>>>>>>>> mais
>>>>>>>> alguns métodos/atributos.
>>>>>>>> Eu acho que consegui fazer uma Arraylist com esses objetos, não sei
>>>>>>>> se fiz certo:
>>>>>>>>
>>>>>>>> Declarei:
>>>>>>>>
>>>>>>>> ArrayList<Pessoa> todasPessoas = new ArrayList<Pessoa>();
>>>>>>>>
>>>>>>>> e depois quando adiciono a pessoa, faço:
>>>>>>>>
>>>>>>>> todasPessoas.add(new Pessoa("nome"));
>>>>>>>>
>>>>>>>> Quando quero procurar uma pessoa da arraylist, eu fiz um método que
>>>>>>>> usa um for e procura em todos objetos da arraylist pelo nome dado, 
>>>>>>>> usando o
>>>>>>>> método equalsNome (abaixo)... mas isso está me parecendo muito 
>>>>>>>> estranho, e
>>>>>>>> não está dando certo.
>>>>>>>> Fiz um método equalsNome na Classe Pessoa, pra receber um nome e
>>>>>>>> dizer se este é o nome da pessoa:
>>>>>>>>
>>>>>>>> public boolean equalsNome (String nome) {
>>>>>>>>  for (int i = 0; i < this.nome.length(); i++) {
>>>>>>>> if (this.nome.charAt(i) != nome.charAt(i)) return false;
>>>>>>>>  }
>>>>>>>>  return false;
>>>>>>>>  }
>>>>>>>>
>>>>>>>>
>>>>>>>> Alguém pode me ajudar? Procurei na Classe ArrayList na API e não
>>>>>>>> encontrei o que eu queria.
>>>>>>>> O que estou fazendo errado, e tem algum jeito de fazer isso mais
>>>>>>>> simples?
>>>>>>>>
>>>>>>>> Obrigado.
>>>>>>>>
>>>>>>>> --
>>>>>>>> You received this message because you are subscribed to the Google
>>>>>>>> Groups "Comp 2 - Geral" group.
>>>>>>>> To post to this group, send email to [email protected].
>>>>>>>> To unsubscribe from this group, send email to
>>>>>>>> [email protected].
>>>>>>>> For more options, visit this group at
>>>>>>>> http://groups.google.com/group/comp2-geral?hl=en.
>>>>>>>>
>>>>>>>
>>>>>>>  --
>>>>>>> You received this message because you are subscribed to the Google
>>>>>>> Groups "Comp 2 - Geral" group.
>>>>>>> To post to this group, send email to [email protected].
>>>>>>> To unsubscribe from this group, send email to
>>>>>>> [email protected].
>>>>>>> For more options, visit this group at
>>>>>>> http://groups.google.com/group/comp2-geral?hl=en.
>>>>>>>
>>>>>>
>>>>>>  --
>>>>>> You received this message because you are subscribed to the Google
>>>>>> Groups "Comp 2 - Geral" group.
>>>>>> To post to this group, send email to [email protected].
>>>>>> To unsubscribe from this group, send email to
>>>>>> [email protected].
>>>>>> For more options, visit this group at
>>>>>> http://groups.google.com/group/comp2-geral?hl=en.
>>>>>>
>>>>>
>>>>>  --
>>>>> You received this message because you are subscribed to the Google
>>>>> Groups "Comp 2 - Geral" group.
>>>>> To post to this group, send email to [email protected].
>>>>> To unsubscribe from this group, send email to
>>>>> [email protected].
>>>>> For more options, visit this group at
>>>>> http://groups.google.com/group/comp2-geral?hl=en.
>>>>>
>>>>
>>>>  --
>>>> You received this message because you are subscribed to the Google
>>>> Groups "Comp 2 - Geral" group.
>>>> To post to this group, send email to [email protected].
>>>> To unsubscribe from this group, send email to
>>>> [email protected].
>>>> For more options, visit this group at
>>>> http://groups.google.com/group/comp2-geral?hl=en.
>>>>
>>>
>>>  --
>>> You received this message because you are subscribed to the Google Groups
>>> "Comp 2 - Geral" group.
>>> To post to this group, send email to [email protected].
>>> To unsubscribe from this group, send email to
>>> [email protected].
>>> For more options, visit this group at
>>> http://groups.google.com/group/comp2-geral?hl=en.
>>>
>>
>>  --
>> You received this message because you are subscribed to the Google Groups
>> "Comp 2 - Geral" group.
>> To post to this group, send email to [email protected].
>> To unsubscribe from this group, send email to
>> [email protected].
>> For more options, visit this group at
>> http://groups.google.com/group/comp2-geral?hl=en.
>>
>
>  --
> You received this message because you are subscribed to the Google Groups
> "Comp 2 - Geral" group.
> To post to this group, send email to [email protected].
> To unsubscribe from this group, send email to
> [email protected].
> For more options, visit this group at
> http://groups.google.com/group/comp2-geral?hl=en.
>

-- 
You received this message because you are subscribed to the Google Groups "Comp 
2 - Geral" group.
To post to this group, send email to [email protected].
To unsubscribe from this group, send email to 
[email protected].
For more options, visit this group at 
http://groups.google.com/group/comp2-geral?hl=en.

Responder a