Menú

Mostrar Mensajes

Esta sección te permite ver todos los mensajes escritos por este usuario. Ten en cuenta que sólo puedes ver los mensajes escritos en zonas a las que tienes acceso en este momento.

Mostrar Mensajes Menú

Mensajes - cyberserver

#31
Oie. pero en que SO probaste tu codigo?

Me manda este error:
Citarjava.util.NoSuchElementException

Sera que es por que utilizo Windows 7 ?

Mira esta es la implementacion de tu codigo.
Código (java) [Seleccionar]

import javax.swing.*;
import java.io.*;
import java.util.*;

public class PID {

    public static void main (String[] args){
    Comprobador Obj=new Comprobador();
    try{
    int Pid=Obj.obtenerPID("firefox.exe");
    JOptionPane.showMessageDialog(null,"PID es "+ Pid);
    }catch(Exception e){
    JOptionPane.showMessageDialog(null,e);
    }
   
}
}
class Comprobador{
public int obtenerPID(String programa) throws Exception
   {
            Process p = Runtime.getRuntime().exec("cmd /c tasklist /nh");
            InputStream is = p.getInputStream();
            BufferedReader br = new BufferedReader (new InputStreamReader(is));
            String tareaR = br.readLine();
           
            while(tareaR!=null)
            {
                StringTokenizer st = new StringTokenizer(tareaR," ");
                String nombre = st.nextToken();
                if(nombre.compareToIgnoreCase(programa)==0)
                  return Integer.parseInt(st.nextToken());
                tareaR = br.readLine();
            }   
       return -1;
   }
}
#32
Hola de nuevo.!  ;D ;D ;D

Oie creo que tambien se puede con esta exprecion
Citar^(\d+\,)+\d+$

Solo le quite lo de ?:



Oie perdon que vuleva a preguntar pero por mas que le intento no me salen las expreciones, ayer estuve asta las 2 de la mañana queriendo hacer otra exprecion y no puede!!  :(

Lo que quiero que haga es que Valide solo los numeros de Toda la serie,

Citar10,20,40,70,10,80

Como puedo hacerle,
Pienso que es basandome de la exprecion
Citar^(\d+\,)+\d+$

Pero en el espacio donde se comprueba la coma (\,) podria colocar una exprecion que omitiera o brincara la coma, para al momento de Agruparla en programacion
Comprovador.group(1) no apareciera.

Muchas gracias por su ayuda.!


#33
aii caray mil gracias en verdad me hisiste un gran favor
#34
Java / Como puedo Editar mis Propias Excepciones
24 Diciembre 2010, 01:14 AM
Hola...!!!!

Quisiera saber como puedo Editar mis propias Excepciones en mis metodos???

:huh: :huh: Me pregunto  :huh: :huh: cuando existe una error en al uitlizacion de un metodo y devuelve una Exception Exsacta.

¿como se edito en la Clase esa Exception o Existe un metodo dentro de la Clase que Clasifica los Errores o como funciona???

¿Como sabe que es una Exception y que no es solo el retorno de una variable de un metodo?

¿Como sabe o entiende el try{}catch(Exception){} que es una Exception?


Cualquier informacion, sera bien resibida!!!! :)


#35
Hola amigos.

Quisiera abrir una pregunta acerca del manejor de errores teniendo ingenieria de software.!

La pregunta es quiza muy tonta pero me gustaria saber cual es la mejor manera para Avisar al Usuario de un error sin comprometer el Resultado Devuelto por el metodo o agregando mensajes ENORMES que quiten una bonita interface Y/o estetica de la aplicacion.

Por ejemplo en el siguiente metodo de Java, como podria avisar de un Error sin tener que colocar un Mensaje enorme que diga del error.

public int Suma(int a,int b){
     try{
        return a+b;
     }catch(Exception Error){
       JOptionPane.showMessengerDialog(null,"El error es " + Error);
       return null;
     }
}


Pensando en Java:
Esto del manejo de errores y la mejor forma para tratarlos no lo hago solo por estetica.! si no por buen funcionamiento de la aplicacion. ya que si queremos exportar una Clase a nivel web (JSP) no es funcional JOptionPane. y no quiero comprometer el resultado devuelto por el metodo por mostrar un tipo de Error.

como podria avisar de un Error sin usar un Mensage?
#36
Hola amigos. para los que les interese les comparto una clase muy sencilla para la conexión a una Base de Datos Oracle con Oracle Data Provider,(Ado.net)

Manual para Usar la Clase (BasDatODP)

Esta Clase usa a Oracle Data Provider, que es un componente que utiliza el estar de ADO.net
TODAS LAS ESPECIFICACIONES DE PARAMETROS Y DE RETORNO DE METODOS ESTAN DESCRITAS EN CLASE BasDatODP COMO COMENTARIOS.
Esta clase es exclusivamente para usarce en la conexión de Base De Datos de Oracle 10g con C#,
Para su uso es necesario contar con:
•   C# Instalado.
•   Oracle instalado en el equipo.
•   En caso de que no se cuente con oracle es necesario instalar Las librerias de OracleDataProvider, las cuales puedes descargar de la pagina oficial de Oracle.

La clase Esta Formada por los constructores:
EXISTE SOBRECARGA DE CONSTRUCTORES

Citar1.- CONSTRUCTOR BASDARODP() -> Permite la multiple instancia de la clase sin repetir la entrada de parametros de conexión
2.- CONSTRUCTOR BasDatODP(String Equipox,String Usuariox,String Passwordx) -> Entrada de los parametros de conexión
   
1.   BasDatODP()
@param VACIO - los parametros son vacios,para evitar la Redundancia si es que se decea Reinstanciar la clase BasDatODP
2.   BasDatODP(String Equipox,String Usuariox,String Passwordx)
@param Equipo  String - Nombre del Equipo Host para la conexión
@param Usuario String - Usuario para la conexión
@param Passwor String - Password para la conexión





Y por los Metodos
Metodo Conectar
CitarEXISTE SOBRECARGA DE METODOS
1.- Metodo Conectar() -> Permite realizar la conexión, si se cargaron los parametros anteriormente en el constructor
       
2.- Metodo Conectar(String Equipo, String Usuario, String Password)
->Permite realizar la conexión, si se omitio la Carga de parametros en el constructor

•   public Boolean Conectar()
REALIZA LA conexión CON LA BASE DE DATOS
@return true - La conexión se Realizo Correctamente
@return false - Error en la conexión

•   public Boolean Conectar(String Equipo, String Usuario, String Password)
REALIZA LA conexión CON LA BASE DE DATOS
@param Equipo  String - Nombre del Equipo Host para la conexión
@param Usuario String - Usuario para la conexión
@param Password String - Password para la conexión
@return true - La conexión se Realizo Correctamente
@return false - Error en la conexión

•   public OracleConnection ExportarConeccion()
IMPORTANTE SI SE DECEA IMPLEMENTAR EN ALGUNA OTRA TAREA EL OBJETO ORACLEDATAPROVIDER
@return OracleConnection - Objeto OracleConeccion importante si se quiere implementar en alguna otra tarea de OracleDataProvide

•   public Boolean EstadoDeConeccion()
MUESTRA EL ESTADO EN QUE SE ENCUENTRA LA conexión DE LA BASE DE DATOS
@return true - Estado conectado
@return false - Estado Desconectado

•   public Boolean Desconectar()
DESCONECTA DE LA BASE DE DATOS
@return true - Se Desconecto Correctamente
@return false - No se Desconecto o Existe un Error

•   public OracleDataReader Consulta(String Query)
CONSULTA DONDE SE RETORNE UN VALOR (SELECT,FUNCIONES.ETC)
@return OracleDataReader - Datos de Lectura de la Consulta




•   public Boolean EjecutarQuery(String Query)
LINEA QUERY DONDE NO SE RETORN UN VALOR (INSERT,DELETE,UPDATE)
@return True  - El Query se ejecuto Correctamente
@return False - El Query no se ejecuto

•   public DataTable ConsultarEnDataGrid(String Query)
CARGA UNA CONSULTA QUE RETORNE UN VALOR (SELECT,FUNCION,ETC) A UNA DATAGRID
@return DataTable  - Datos de Tabla, Para ser igualados con dataGridView.DataSource



El codigo de la clase es el siguente:
Código (csharp) [Seleccionar]

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using Oracle.DataAccess.Client;

namespace OracleDateProvider_Prueba
{
   class BasDatODP
   {
       private static OracleConnection conexión;

       /*
        *Constructores BasDatODP
        * EXISTE SOBRECARGA DE CONSTRUCTORES
        *
        * 1.- CONSTRUCTOR BASDARODP() -> Permite la multiple instancia de la clase sin repetir
        *                                la entrada de parametros de conexión
        * 2.- CONSTRUCTOR BasDatODP(String Equipox,String Usuariox,String Passwordx) ->
        *                              Entrada de los parametros de conexión
        */

       /*
        *Constructor BasDatODP
        * @param VACIO - los parametros son vacios,para evitar la Redundancia si es que se decea
        * Reinstancias la clase BasDatODP
        */
       public BasDatODP() {
           conexión = new OracleConnection();
       }

       /*
        *Constructor BasDatODP(String Equipox,String Usuariox,String Passwordx)
        *@param Equipo  String - Nombre del Equipo Host para la conexión
        *@param Usuario String - Usuario para la conexión
        *@param Passwor String - Password para la conexión
        *
        */
       public BasDatODP(String Equipo, String Usuario, String Password){
           conexión = new OracleConnection();
           conexión.ConnectionString = "Data Source=" + Equipo
                                           + ";User Id=" + Usuario
                                           + ";Password=" + Password
                                           + ";";
       }

       /*
        *Metodo Conectar
        * EXISTE SOBRECARGA DE METODOS
        *
        * 1.- Metodo Conectar() -> Permite realizar la conexión, si se cargaron los parametros
        *                       anteriormente en el constructor
        *
        * 2.- Metodo Conectar(String Equipo, String Usuario, String Password) ->
        *            Permite realizar la conexión, si se omitio la Carga de parametros en el constructor
        */
       
       /*
        *Metodo Conectar()
        *REALIZA LA conexión CON LA BASE DE DATOS
        *@return true - La conexión se Realizo Correctamente
        *@return false - Error en la conexión
        */
       public Boolean Conectar()
       {
           try
           {
               conexión.Open();
               return true;
           }
           catch (Exception error)
           {
               return false;
           }
       }


       /*
        *Metodo Conectar(String Equipox, String Usuariox, String Passwordx)
        *REALIZA LA conexión CON LA BASE DE DATOS
        *@param Equipo  String - Nombre del Equipo Host para la conexión
        *@param Usuario String - Usuario para la conexión
        *@param Password String - Password para la conexión
        *@return true - La conexión se Realizo Correctamente
        *@return false - Error en la conexión
        */
       public Boolean Conectar(String Equipo, String Usuario, String Password)
       {
           try
           {
               conexión.ConnectionString = "Data Source=" + Equipo
                                           + ";User Id=" + Usuario
                                           + ";Password=" + Password
                                           + ";";
               conexión.Open();
               return true;
           }
           catch (Exception error)
           {
               return false;
           }
      }

       /*
        *Metodo ExportarConeccion()
        *IMPORTANTE SI SE DECEA IMPLEMENTAR EN ALGUNA OTRA TAREA EL OBJETO ORACLEDATAPROVIDER
        *@return OracleConnection - Objeto OracleConeccion importante si se quiere implementar en alguna otra
        *                        tarea de OracleDataProvide
        */
       public OracleConnection ExportarConeccion()
       {
           return conexión;
       }

       /*
        *Metodo EstadoDeConeccion()
        *MUESTRA EL ESTADO EN QUE SE ENCUENTRA LA conexión DE LA BASE DE DATOS
        *@return true - Estado conectado
        *@return false - Estado Desconectado
        */
       public Boolean EstadoDeConeccion()
       {
           try
           {
               String Estado=conexión.State.ToString();
               if (Estado.Equals("Open"))
               {
                   return true;
               }
               else
               {
                   return false;
               }

           }
           catch (Exception error)
           {
               return false;
           }
           
         
       }

       /*
        *Metodo Desconectar()
        *DESCONECTA DE LA BASE DE DATOS
        *@return true - Se Desconecto Correctamente
        *@return false - No se Desconecto o Existe un Error
        */
       public Boolean Desconectar() {
           try
           {
               conexión.Close();
               conexión.Dispose();
               return true;
           }
           catch (Exception error) {
               return false;
           }
       }

       /*
        *Metodo Consulta(String Query)
        *CONSULTA DONDE SE RETORNE UN VALOR (SELECT,FUNCIONES.ETC)
        *@return OracleDataReader - Datos de Lectura de la Consulta
        */
       public OracleDataReader Consulta(String Query)
       {
           try
           {
               OracleCommand HacerConsulta = new OracleCommand();
               HacerConsulta.Connection = conexión;
               HacerConsulta.CommandText = Query;
               HacerConsulta.CommandType = CommandType.Text;

               OracleDataReader DatosLectura = HacerConsulta.ExecuteReader();
               if (!DatosLectura.Read())
               {
                   return null;
               }
               return DatosLectura;
           }
           catch (Exception Error)
           {
               return null;
           }
       }

       /*
        *Metodo EjecutarQuery(String Query)
        *LINEA QUERY DONDE NO SE RETORN UN VALOR (INSERT,DELETE,UPDATE)
        *@return True  - El Query se ejecuto Correctamente
        *@return False - El Query no se ejecuto
        */
       public Boolean EjecutarQuery(String Query)
       {
           try
           {
               OracleCommand HacerConsulta = new OracleCommand();
               HacerConsulta.Connection = conexión;
               HacerConsulta.CommandText = Query;
               HacerConsulta.CommandType = CommandType.Text;
               HacerConsulta.ExecuteNonQuery();
               return true;
           }catch(Exception error)
           {
               return false;
           }
       }

       /*
        *Metodo ConsultarEnDataGrid(String Query)
        *CARGA UNA CONSULTA QUE RETORNE UN VALOR (SELECT,FUNCION,ETC) A UNA DATAGRID
        *@return DataTable  - Datos de Tabla,
        *          Para ser igualados con dataGridView.DataSource
        *
        */
       public DataTable ConsultarEnDataGrid(String Query)
       {
           try
           {
               OracleDataAdapter DaValores = new OracleDataAdapter(Query, conexión);
               DataSet DsValores = new DataSet();
               DaValores.Fill(DsValores,"Tabla");

               return DsValores.Tables["Tabla"];
           }
           catch (Exception error)
           {
               return null;
           }
           
       }

       
       
   }
}



Editado por D4N93R: Recuerda colocar el código Geshi correcto, estaba en Java y no en C#.
#37
Java / Ayuda con Exprecion Regular Serie Numerica
23 Diciembre 2010, 23:08 PM
Hola amigos, como siempre necesito su ayuda!!!

Ya me queme la cabeza y no puedo encontrar la Exprecion Regular para una serie

Citar20,30,56,78,98

Tiene que cumplir con las siguentes Caracteristicas

  • Pueden ser [0-9]*
  • No puede escribirse un solo numero, tiene que ser una serie
  • Puenden ser numeros infinitos, no tiene limite
  • Tiene que ir separados por una Coma
  • El numero final NO puede terminar con coma ni con cualquier otro signo terminal

:huh: :huh: :huh: :rolleyes: :rolleyes: Parece Sencillo pero no pude hacerlo, ya tengo dias pensandole aunque paresca tonto pero no logro completar la Exprecion Regular.

Aqui el codigo!!! ("La exprecion Regular esta mal")
Código (java) [Seleccionar]

import javax.swing.*;
import java.util.regex.Matcher;
import java.util.regex.Pattern;


public class Enumeracion {

   public static void main (String[] args) {
    String Cadena;
    ExpRegu Obj=new ExpRegu();
    for(int x=0;x<20;x++){
    Cadena=JOptionPane.showInputDialog("Cadena para Procesar");
    if(Obj.Comparacion(Cadena)){
    JOptionPane.showMessageDialog(null,"Si es Correcta la Cadena");
    }else{
    JOptionPane.showMessageDialog(null,"No es Correcta la Cadena");
    }
    }
   
}
   
   
}
class ExpRegu{
public boolean Comparacion(String Cadena)throws java.util.regex.PatternSyntaxException{
String ExprecionRegular="(^[0-9]*|^[0-9]*+[,])+([0-9]*+[,]|[,]+[0-9]*+[,])+([0-9]*$)";
       Pattern InicialExprecion = Pattern.compile(ExprecionRegular);
    Matcher Patron=InicialExprecion.matcher(Cadena);
   
   if(Patron.find()){
    return true;
   }else{
    return false;
   }
   }

}



en verdad les agradeceria infinitamente su ayuda...!
#38
Java / Re: ArrayList Bidimencionales
20 Diciembre 2010, 06:00 AM
Pues muchas gracias por su informacion.

Sclub... creo que los codigos que recomiendas no funcionan o no se si los entendi mal, mira aqui los escribi de esta manera:
Código (java) [Seleccionar]

import javax.swing.*;
import java.util.*;

public class Anidado {

    public static void main (String[] args) {
   
    ArrayList[] array = new ArrayList[5];
   
    array[0].add("Valor0.0");
    array[0].add("Valor0.1");
   
    array[1].add("Valor1.0");
    array[1].add("Valor1.1");
   
   
JOptionPane.showMessageDialog(null,"Valor " + array[0].get(1));
   
   
}
   
}


y me retorna el siguente error:
Citar
--------------------Configuration: <Default>--------------------
Exception in thread "main" java.lang.NullPointerException
    at Anidado.main(Anidado.java:10)

Process completed.


El error : No esta bien la declaracion del Objeto ArrayList.... por que ?
Citar
Los constructores para poder crear un Objeto de Tipo ArrayLis son los siguientes:
Wikipedia
ArrayList tiene varios constructores, dependiendo de cómo necesitemos construir el ArrayList . Los siguientes dos constructores nos ayudarán a entenderlo:
•   ArrayList() construye un ArrayList con capacidad cero por defecto, pero crecerá según le vayamos añadiendo:
ArrayList al = new ArrayList();
•   ArrayList(int initialCapacity) construye un ArrayList vacío con una capacidad inicial especificada:
ArrayList al2 = new ArrayList(5);


Tambien en el codigo que colocaste:
Código (java) [Seleccionar]

ArrayList[][] array = new ArrayList[5][5];

array[0][0].add("holaa");
....
array[4][4].add("ultimo");


Yo que sepa no existen ArrayList[][] ni la Bidimecionalidad (Matrizes), ya que unas de las Desventajas que tiene ArrayList con relacion a los Arrays normales son las siguentes :
Citar
•   Se puede establecer el límite inferior de Array, pero el límite inferior de ArrayList o List siempre es cero.
•   Array puede tener varias dimensiones, mientras que ArrayList o List siempre tienen una dimensión exactamente.
•   Un objeto Array de un tipo específico distinto de Object ofrece mejor rendimiento que ArrayList ya que los elementos de ArrayList son de tipo Object y, por lo tanto, las conversiones boxing y unboxing se producirán normalmente al almacenar o recuperar un tipo de valor. Sin embargo, List puede presentar un rendimiento similar al de una matriz del mismo tipo siempre que no se requiera ninguna reasignación, es decir, siempre que la capacidad inicial sea una aproximación acertada del tamaño máximo de la lista.


Segun entiendo la unica forma de crear una matriz o un ArrayList con mas de una dimencion es anidando ArrayList....

NOTA: Perdon se me olvido comentar que la unica razon por que pretendo utilizar ArrayList y no simplemente un Array es por la capacidad de estos objetos de crecer y remover elementos DINAMICAMENTE en tiempo de ejecucion (Utiliza Tipado Dinamico)


En cuanto a lo que dice. Sapito voy a tratar de anlizarlo... muchas Gracias :)

#39
Java / ArrayList Bidimencionales
19 Diciembre 2010, 21:50 PM
. Hola amigos.

Estoy haciendo pruebas utilisando ArrayList, pero caramba solo he podido hacer Arrays Unidimencionales.


Existe la forma de Realizar uno Bidimencional (Matriz).

encontre que acoplando los objetos, algo parecido a esto:

Código (java) [Seleccionar]

       ArrayList A1=new ArrayList();
    ArrayList A11=new ArrayList();
 
      A1.add(A11);

      A1.set(0,A11.add("Hola en 1.1"));
    A1.set(0,A11.add("Hola en 1.2"));
    A1.set(0,A11.add("Hola en 1.3"));

   


Pero como puedo referirme para poder ver los valores de un elemento de A1 y de A11 a la ves???

como si fuera
Código (java) [Seleccionar]

String  Valor = A1[0][3];


Existe alguna forma de Hacerlo al mismo tiempo sin tener que hacerlo independientemente como

Código (java) [Seleccionar]

A1.get(0);
A11.get(0);



Existe una forma mas sencilla de anidarlas los ArrayList? para no tener que declarar el segundo objeto A11 primero y luego usarlo agregandolo a A1.add

Esto lo digo pues si quiero colocar A11 dentro de Cada A1(0),A1(1).....A1(n) pues tendria que Declarar muchos objetos similares a A11, haciendo un buen de objetos que consumirian memoria...  :huh: :huh: :huh:  :rolleyes: :rolleyes:
Código (java) [Seleccionar]

       ArrayList A1=new ArrayList();
    ArrayList A11=new ArrayList();
       ArrayList A12=new ArrayList();
     
      A1.add(A11);
      A1.add(A12);

      A1.set(0,A11.add("Hola en 1.1"));
    A1.set(0,A11.add("Hola en 1.2"));
    A1.set(0,A11.add("Hola en 1.3"));

       A1.set(1,A12.add("Hola en 2.2"));
    A1.set(1,A12.add("Hola en 2.1"));
    A1.set(1,A12.add("Hola en 2.3"));
#40
Muchas Gracias. es esactamente lo que estaba buscando de verdad muchas gracias.!!!

Oie pero en el tipo de apuntador tengo que especificar siempre el tipo. escuche que se podia poner


void *apuntador = (void*)0x00ff1250;



Pero me marca error. no se si realemente se pueda..!