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ú

Temas - Uknow

#1
Parece tonta la pregunta pero no lo tengo claro, ¿qué se considera compilar un código por medio del estándar? ¿que el código sólamente incluya las librerías que se encuentran aquí ? ¿cómo sé cuándo compilo rigiéndome por el estandar? ¿cuando le agrego al compilador la opción -ansi?

y otra duda aparte, cuando escribo un código (q imprima un número y use getch() para parar) sin incluir ninguna libería, ¿por qué compila? ¿por la rtl? y si es así, ¿cómo sé cuáles funciones tiene la rtl y cuáles no? uso mingw en windows.

ah! también, ¿es posible tener un ejecutable q no cargue kernel32 ni ntdll ?

Gracias.

saludos.
#2
Buenas,

La cuestión es la siguiente: necesito utilizar un segundo monitor como extención del principal. Tengo una segunda máquina que inicia debian por red (sólo el sistema de archivo x nfs)  desde un servidor que lo proporciona; como esta máquina no la utilizo porque forma parte de un cluster quisiera extender el escritorio del servidor con el monitor conectado a la máquina secundaria a través de la red para sacarle provecho.

Es prácticamente el equivalente a MaxiVsita o ZoneScreen pero en linux. Estuve viendo Xdmx/dmx pero según leí el proyecto parece descontinuado.

¿alguien sabe cómo hacer esto? se lo agradecería infinitamente.

Saludos.  :D
#3
Siempre hay una canción que nos alegra el día cuándo estamos amargados,postean cúal es la suya.

Por mi parte es esta:
Tribalistas Ja sei namorar.

Saludos. :]
#4
Programación C/C++ / Problema con cadenas
10 Diciembre 2011, 22:08 PM
Andaba leyendo unos concursos y decidi intentar un problema.
El punto era emular algo asi:

entrada:
holaaaa muuundooo

salida:
hol3a m2und2o

Logre hacer esto:

Código (cpp) [Seleccionar]
#include <iostream>

using namespace std;

int main()
{
   char cadena[100],cadena_n[100], *aux = cadena-1;
   char veces('0'); int i(0);
   
   cout << "Cadena: ";
   cin.getline(cadena,100);
   
   while( *aux++ )
   {
          if(*aux == *(aux+1) )
          {
             veces++;
         
          if( *(aux+1) !=  *(aux+2) )
          {
                           
              cadena_n[i] = veces;            
              i++;
              veces = '0';
          }
           
             continue;
                             
          }
                 
   cadena_n[i] = *aux;
   i++;
   }
       cadena_n[i] = '\0';            
   
 
   
   cout << "\n\nCadena_n: " << cadena_n;
   cout << "\n\nCadena: " << cadena;
   
   setbuf(stdin, NULL);
   cin.get();
   return 0;
   
   
}

El problema en el code radica en que utilizo un char para contar las veces y poder meterlo en la cadena sin problemas pero como en la tabla ascii solo existe espacio del 1 al 9 despues de esos sigue monstrando el caracter correspondiente en la tabla.

Me pregunto de que forma podria lograr meter el integer en la cadena?
Se me ocurre una forma de hacerlo pero es poco practico y muy engorroso. Pense en hacer uso de atoi y itoa pero no veo de q forma implementarlo correctamente para que me de el resultado q quiero. :/
Pues d q forma se podria hacer tambien? : )

un saludo y gracias!


#5
Hola, buenas, saludines. : )

Tengo un problema que me esta tirando los pelos d la cabeza, con este codigo que no logro que funcione como debe.

Estoy intentando verificar si un proceso esta corriendo desde interfaz grafica, pero por alguna razon no me funciona, el codigo esta asi:

Código (cpp) [Seleccionar]
#include <windows.h>
#include <Tlhelp32.h>

/*  Declare Windows procedure  */
LRESULT CALLBACK WindowProcedure (HWND, UINT, WPARAM, LPARAM);

/*  Make the class name into a global variable  */
char szClassName[ ] = "WindowsApp";
int Buscar_Proceso();
void Crear_Ventana(HWND hwnd);
HINSTANCE instancia;
HWND Button2;

   
    int WINAPI WinMain (HINSTANCE hThisInstance,
                    HINSTANCE hPrevInstance,
                    LPSTR lpszArgument,
                    int nFunsterStil)

{
    HWND hwnd;               /* This is the handle for our window */
    MSG messages;            /* Here messages to the application are saved */
    WNDCLASSEX wincl;        /* Data structure for the windowclass */
    instancia = hThisInstance;   
    /* The Window structure */
    wincl.hInstance = hThisInstance;
    wincl.lpszClassName = szClassName;
    wincl.lpfnWndProc = WindowProcedure;      /* This function is called by windows */
   // wincl.style = CS_DBLCLKS;                 /* Catch double-clicks */
    wincl.cbSize = sizeof (WNDCLASSEX);

    /* Use default icon and mouse-pointer */
    wincl.hIcon = LoadIcon (NULL, IDI_APPLICATION);
    wincl.hIconSm = LoadIcon (NULL, IDI_APPLICATION);
    wincl.hCursor = LoadCursor (NULL, IDC_ARROW);
   // wincl.lpszMenuName = NULL;                 /* No menu */
    wincl.cbClsExtra = 0;                      /* No extra bytes after the window class */
    wincl.cbWndExtra = 0;                      /* structure or the window instance */
    /* Use Windows's default color as the background of the window */
    wincl.hbrBackground = (HBRUSH) COLOR_BACKGROUND;

    /* Register the window class, and if it fails quit the program */
    if (!RegisterClassEx (&wincl))
        return 0;

    /* The class is registered, let's create the program*/
    hwnd = CreateWindowEx (
           0,                   /* Extended possibilites for variation */
           szClassName,         /* Classname */
           "Windows App",       /* Title Text */
           WS_OVERLAPPEDWINDOW, /* default window */
           CW_USEDEFAULT,       /* Windows decides the position */
           CW_USEDEFAULT,       /* where the window ends up on the screen */
           544,                 /* The programs width */
           375,                 /* and height in pixels */
           HWND_DESKTOP,        /* The window is a child-window to desktop */
           NULL,                /* No menu */
           hThisInstance,       /* Program Instance handler */
           NULL                 /* No Window Creation data */
           );

    /* Make the window visible on the screen */
   
    ShowWindow (hwnd, nFunsterStil);

    /* Run the message loop. It will run until GetMessage() returns 0 */
    while ( GetMessage (&messages, NULL, 0, 0) == 1)
    {
        /* Translate virtual-key messages into character messages */
       TranslateMessage(&messages);
        /* Send message to WindowProcedure */
        DispatchMessage(&messages);
    }

    /* The program return-value is 0 - The value that PostQuitMessage() gave */
    return messages.wParam;
}


/*  This function is called by the Windows function DispatchMessage()  */

LRESULT CALLBACK WindowProcedure (HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam)
{
    switch (message)                  /* handle the messages */
    {
       
          case WM_CREATE:
           Crear_Ventana(hwnd);
           break;
         
            case WM_COMMAND:
                 
            if((HWND)lParam == Button2 )
            {
                  if(Buscar_Proceso() == 0)
                   MessageBox(0, "El proceso esta corriendo", "Proceso", 0);       
                       
            }
            break;

                     
        case WM_DESTROY:
            PostQuitMessage (0);       /* send a WM_QUIT to the message queue */
           
         
             break;
             
        default:                      /* for messages that we don't deal with */
            return DefWindowProc (hwnd, message, wParam, lParam);
    }

    return 0;
}

void Crear_Ventana(HWND hwnd)
{
     //Boton 2
Button2 = CreateWindowEx(0,"BUTTON", "Buscar P", WS_CHILD|WS_VISIBLE|WS_TABSTOP,
                         100, 300, 100, 20, hwnd, 0, instancia, NULL);
}

int Buscar_Proceso()
{
    HANDLE CProc;   
    PROCESSENTRY32 Proceso;    //Necesario para realizar la captura de procesos
    CProc=CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);   //Con esto creamos una captura de la lista de procesos y la guardamos en CProc
Process32First(CProc,&Proceso);    //Leemos el primer proceso

while(Process32Next(CProc,&Proceso))   //Mientras haya procesos para leer leemos el siguiente
{
                                           
if(!strcmp(Proceso.szExeFile,"explorer.exe") )
return 0;
}
   
    return 1;
}


Sin duda ha de ser una chorrada pero no lo veo :(
help! D:

Lo que mas rabia me da es que si lo hago desde la consola si sale!!

Código (cpp) [Seleccionar]

#include <windows.h>
#include <Tlhelp32.h>
#include <stdio.h>

HANDLE CProc;   //Para crear la captura de la lista de procesos
int Buscar_Proceso();

int main()
{
    if(Buscar_Proceso() == 0)
      MessageBox(0, "el proceso esta corriendo", "proceso", 0);

     getchar();

return 0;    //Retornamos 0 diciendo que salio bien
}

int Buscar_Proceso()
{
    PROCESSENTRY32 Proceso;    //Necesario para realizar la captura de procesos
    CProc=CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);   //Con esto creamos una captura de la lista de procesos y la guardamos en CProc
Process32First(CProc,&Proceso);    //Leemos el primer proceso

while(Process32Next(CProc,&Proceso))   //Mientras haya procesos para leer leemos el siguiente
{
                                           
if(!strcmp(Proceso.szExeFile,"explorer.exe") )
return 0;
}
   
    return 1;
}
   
   
Alguien puede ofrecerme una manito con esto? :(

Gracias de antemano!!