[ C / C++ ] — начинающим: задаем вопросы (архивная - 2015)

Discussion in 'С/С++, C#, Rust, Swift, Go, Java, Perl, Ruby' started by _Great_, 26 May 2007.

Thread Status:
Not open for further replies.
  1. zeppe1in

    zeppe1in Elder - Старейшина

    Joined:
    12 Jul 2006
    Messages:
    343
    Likes Received:
    66
    Reputations:
    18
    думаю сделать класс,
    в котором будет char переменной длины от 1 до 10. и я буду создавать массив из этого класса. тоесть будет много new char[1-10]. это нормально? или может есть другие варианты.
    и потом как лучше будет заполнять этот char? меня смущает memcpy(..1)
     
  2. rudvil

    rudvil Elder - Старейшина

    Joined:
    25 Aug 2008
    Messages:
    200
    Likes Received:
    29
    Reputations:
    0
    ptr - Указатель на блок памяти созданный с помощью "malloc"
     
  3. Ra$cal

    Ra$cal Elder - Старейшина

    Joined:
    16 Aug 2006
    Messages:
    670
    Likes Received:
    185
    Reputations:
    78
    zeppe1in
    зачем? постановку задачи то пиши. а то реверсить чужое мышление - задача весьма нетривиальная. не то что программы писать.
     
  4. zeppe1in

    zeppe1in Elder - Старейшина

    Joined:
    12 Jul 2006
    Messages:
    343
    Likes Received:
    66
    Reputations:
    18
    ну вообще дизасмлю ИЛ код. вот собственно подумал сделать класс где будет хранится опкод, тип опкода, ну и всё такое, что бы дальше мне удобно было работать со всем этим.

    Или наверно лучше сделать,просто массив, а в нём адрес опкода, его размер, и тип.
     
    #4664 zeppe1in, 21 Jan 2010
    Last edited: 21 Jan 2010
  5. Hiro Protagonist

    Joined:
    26 Aug 2009
    Messages:
    132
    Likes Received:
    24
    Reputations:
    -2
    2zeppe1in
    если все делаешь на классах то и опкод храни как класс
    если нет -> то массив структур. Придерживайся единообразия )
     
  6. zeppe1in

    zeppe1in Elder - Старейшина

    Joined:
    12 Jul 2006
    Messages:
    343
    Likes Received:
    66
    Reputations:
    18
    вся проблема в том, что только изучаю с++, и поэтому делаю как получится).
    я думаю что с массивом структур(адрес,размер) будет лучше чем выделять память для каждого опкода.
    пс:вот теперь думаю, может массив в класс засунуть.)
     
  7. cupper

    cupper Elder - Старейшина

    Joined:
    6 Jun 2007
    Messages:
    369
    Likes Received:
    92
    Reputations:
    5
    ясен хрен что во времена C не было оператора new. Но оно работает. И для увеличения и для уменьшения.
     
  8. Hiro Protagonist

    Joined:
    26 Aug 2009
    Messages:
    132
    Likes Received:
    24
    Reputations:
    -2
    На сколько я помню в msvc нет отдельного менеджера кучи для new и он лишь обертка над malloc. За остальные имплиментации рунтайма не скажу. Так что все там будет работать по крайней мере в msvc )
    PS А ну да забыл, так лучше не делать ибо плохой стиль ))
     
  9. cupper

    cupper Elder - Старейшина

    Joined:
    6 Jun 2007
    Messages:
    369
    Likes Received:
    92
    Reputations:
    5
    это стиль С где все ручками, конечно все кричат надо юзать обертки, но не кто не отменял корешки. Мне просто лень в моей задаче юзать векторы и т.д.
     
  10. rudvil

    rudvil Elder - Старейшина

    Joined:
    25 Aug 2008
    Messages:
    200
    Likes Received:
    29
    Reputations:
    0
    Лень юзать по простому? ^^
     
  11. Hiro Protagonist

    Joined:
    26 Aug 2009
    Messages:
    132
    Likes Received:
    24
    Reputations:
    -2
    2cupper
    может оказаться, что код не переносим между компиляторами, но если тебе на это класть, то пофиг. Если же хз, то лучше придерживаться стандарта ) того или иного )
     
  12. Ra$cal

    Ra$cal Elder - Старейшина

    Joined:
    16 Aug 2006
    Messages:
    670
    Likes Received:
    185
    Reputations:
    78
    смысл юзать с++, если планируешь говнокодить? юзай делфи, там меньше заморочек при работе с памятью.
     
  13. SHARA

    SHARA Elder - Старейшина

    Joined:
    26 May 2007
    Messages:
    69
    Likes Received:
    7
    Reputations:
    0
    Я что затупил не могу ошибку найти

    ПАСИБА ОШИБКУ ПОНЯЛ))))))
    пОЛ ДНЯ ТУПИЛ
     
    #4673 SHARA, 23 Jan 2010
    Last edited: 23 Jan 2010
  14. rudvil

    rudvil Elder - Старейшина

    Joined:
    25 Aug 2008
    Messages:
    200
    Likes Received:
    29
    Reputations:
    0
    Code:
    #include<iostream>
    using namespace std;
    class sample
    {
    int a;
    int b;
    public:
    void put_value(int i, int j);
    void show_value();
    };
    void sample::put_value(int i, int j)
    {
    a=i;
    b=j;
    }
    void sample::show_value()
    {
    cout<<"Закрытый член данных a: "<<a<<endl;
    cout<<"Закрытый член данных b: "<<b<<endl;
    }
    int main()
    {
    setlocale(LC_ALL, "Russian");
    sample ob1, ob2;
    ob1.put_value(10,18);
    ob2.put_value(1,12);
    cout << "Значение первого обьекта до присваивания: ";
    ob1.show_value();
    cout << endl;
    cout << "Значение второго обьекта до присваивания: ";
    ob2.show_value();
    cout << endl;
    ob2=ob1;
    cout<<"Значение первого обьекта до присваивания: ";
    ob1.show_value();
    cout << endl;
    cout << "Значение второго обьекта до присваивания: ";
    cout << endl;
    ob2.show_value();
    return 0;
    }
     
  15. almazz

    almazz New Member

    Joined:
    29 Mar 2009
    Messages:
    22
    Likes Received:
    4
    Reputations:
    -1
    как выключить отладку приложений в VS2008?Крошится hddlife.exe и постоянно выходит "Вы не желаете отладить приложение?"
     
  16. POS_troi

    POS_troi Elder - Старейшина

    Joined:
    1 Dec 2006
    Messages:
    1,569
    Likes Received:
    466
    Reputations:
    108
    http://technet.microsoft.com/ru-ru/library/aa995708%28EXCHG.80%29.aspx
     
    1 person likes this.
  17. almazz

    almazz New Member

    Joined:
    29 Mar 2009
    Messages:
    22
    Likes Received:
    4
    Reputations:
    -1
    правильнее http://msdn.microsoft.com/ru-ru/library/k8kf6y2a.aspx
     
  18. Keltos

    Keltos Banned

    Joined:
    8 Jul 2009
    Messages:
    1,558
    Likes Received:
    920
    Reputations:
    520
    Написал я простенькую програмку на С++, отправил своему другу, он не может открыть, пишет типо не удалось запустить....
     
  19. Chubakur

    Chubakur Member

    Joined:
    6 Apr 2009
    Messages:
    48
    Likes Received:
    12
    Reputations:
    0
    Keltos, на С++ Builder писал? Если да, то:
    Project->Options->Packages, и поставь(или наоборот сними) галочку напротив, Build With Runtime Libraries. После этого перекомпилируй.
     
    #4679 Chubakur, 25 Jan 2010
    Last edited: 25 Jan 2010
  20. +casper+

    +casper+ Banned

    Joined:
    27 Jun 2009
    Messages:
    158
    Likes Received:
    34
    Reputations:
    0
    вопрос: ошибка компилирования в Dev C++
    код:
    Code:
    /**************************************************  *****************************
    
                           Satanic Socks Server v0.66.170506
                                      Powered by drmist\STNC
    
    Compilation:
      Win32: Visual C++
      Unix:  gcc -lpthread sss.c -o sss
                
    v0.66.170506
    + IPv4
    + Domain names
    + Connect method
    + Login:Password authorization
    
    (c) 2006 www.security-teams.net crew
    
    **************************************************  *****************************/
    
    //#define UNIX 1
    #define WIN32 1
    /#define AUTH_ON 1
    #define PORT 3003
    #define BUFF_SIZE 1024
    
    #ifdef AUTH_ON
     
      const char AuthLogin[] = "login";
      const char AuthPass[] = "pass";
      #define SOCKS5_METHOD 0x02      
    #else
    
      #define SOCKS5_METHOD 0x00        
    #endif
    
    #ifdef UNIX
    
    #include "sys/types.h"
    #include "sys/socket.h"
    #include "netinet/in.h"
    #include "netdb.h"
    
    typedef int SOCKET;
    typedef int bool;
    typedef int __stdcall;
    
    #define SOCKET_ERROR -1
    #define INVALID_SOCKET -1
    
    #define false 0
    #define true 1
    
    #define SD_BOTH SHUT_RDWR
    
    #define _malloc malloc
    #define closesocket close
    
    void create_thread(void* func, void* param)
    {
      int ThrId;
      pthread_create(&ThrId, 0, func, param);
    }
    
    #endif
    
    #ifdef WIN32
    
    #include "winsock2.h"
    
    #pragma comment(linker, "/SUBSYSTEM:WINDOWS")
    #pragma comment(linker, "/ENTRY:main /ALIGN:0x200 /BASE:0x400000")
    #pragma comment(linker, "/MERGE:.rdata=.text /SECTION:.text, EWR")
    
    typedef UINT in_addr_t;
    
    #define strcmp lstrcmp
    #define free GlobalFree
    
    void create_thread(void* func, void* param)
    {
      CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)func, param, 0, NULL);
    }
      
    char* _malloc(int BuffSize)
    {
      return (char*)GlobalAlloc(GMEM_FIXED, BuffSize);
    }
        
    void bzero(void* lpBuff, int BuffSize)
    {
      _asm
      {
        xor eax, eax
        mov ecx, BuffSize
        mov edi, lpBuff
        cld
        rep stosb
      }
    }
                                  
    #endif
    
    #define SOCKS_VERSION 0x05
    #define SOCKS_SUCCESS 0x00
    #define SOCKS_FAILURE 0x01
    #define SOCKS_CONNECTION_REFUSED 0x05
    #define SOCKS_CMD_NOT_SUPPORTED 0x07
    
    typedef struct
    {
    
      char* _ConnectStruct;
      SOCKET From;
      SOCKET To;
      char Buff[BUFF_SIZE];
      char* Error;
    
    } SOCKSPIPE;
    
    typedef SOCKSPIPE* LPSOCKSPIPE;
    
    typedef struct _CONNECTSTRUCT
    {
    
      SOCKSPIPE FromStruct;
      SOCKSPIPE ToStruct;
      char Error;
    
    } CONNECTSTRUCT;
    
    typedef CONNECTSTRUCT* LPCONNECTSTRUCT;
    
    LPCONNECTSTRUCT CreateConnectStruct(SOCKET From, SOCKET To)
    {
      LPCONNECTSTRUCT Result = (LPCONNECTSTRUCT)_malloc(sizeof(CONNECTSTRUCT));
    
      Result->FromStruct._ConnectStruct = (char*)Result;
      Result->FromStruct.From = From;
      Result->FromStruct.To = To;
      Result->FromStruct.Error = &(Result->Error);
    
      Result->ToStruct._ConnectStruct = (char*)Result;
      Result->ToStruct.From = To;
      Result->ToStruct.To = From;
      Result->ToStruct.Error = &(Result->Error);
    
      Result->Error = 0x00;
    
      return Result;
    }
    
    bool swrite(SOCKET s, char* Buff, int buff_size)
    {
      int bytes;
    
      while(buff_size > 0)
      {
        bytes = send(s, Buff, buff_size, 0);
    
        if((bytes == 0)||(bytes == SOCKET_ERROR))
          return false;
        buff_size -= bytes;
        Buff += bytes;
      }
    
      return true;
    }
    
    bool sread(SOCKET s, char* Buff, int buff_size)
    {
      int bytes;
    
      while(buff_size > 0)
      {
        bytes = recv(s, Buff, buff_size, 0);
    
        if((bytes == 0)||(bytes == SOCKET_ERROR))
          return false;
    
        buff_size -= bytes;
        Buff += bytes;
      }
    
      return true;
    }
    
    __stdcall SocksPipe(LPSOCKSPIPE PipeStruct)
    {
      int bytes;
    
      do
      {
        bytes = recv(PipeStruct->From, PipeStruct->Buff, BUFF_SIZE, 0);
    
        if((bytes == 0) || (bytes == SOCKET_ERROR))
          break;
    
        if(*(PipeStruct->Error) & 0x01)
        {
          *(PipeStruct->Error) |= 0x02;
          return 0;
        }
    
        if(!swrite(PipeStruct->To, PipeStruct->Buff, bytes))
        {
          *(PipeStruct->Error) |= 0x02;
          return 0;
        }
      }
      while(!(*(PipeStruct->Error) & 0x01));
    
      if(*(PipeStruct->Error) & 0x01)
        *(PipeStruct->Error) |= 0x02;
      else
      {
        *(PipeStruct->Error) |= 0x01;
        shutdown(PipeStruct->From, SD_BOTH);
        shutdown(PipeStruct->To, SD_BOTH);
        closesocket(PipeStruct->From);
        closesocket(PipeStruct->To);
    
        while(!(*(PipeStruct->Error) & 0x02))
        {
        #ifdef UNIX
          sleep(1);
        #endif
        #ifdef WIN32
          Sleep(1000);
        #endif
        }
    
        free(PipeStruct->_ConnectStruct);
      }
    
      return 0;
    }
    
    bool Socks5SendCode(SOCKET s, char Code, char* TempBuff, char* ip, char* port)
    {
      *(int*)TempBuff = 0x1000000 | (Code << 8) | SOCKS_VERSION;
      *(int*)(TempBuff + 4) = *(int*)ip;
      *(short*)(TempBuff + 8) = *(short*)port;
    
      return swrite(s, TempBuff, 10);
    }
    
    SOCKET Socks5ServConnect(SOCKET s, char* TempBuff, char* ip, u_short port)
    {
      struct sockaddr_in saddr;
      SOCKET Redir = socket(AF_INET, SOCK_STREAM, 0);
    
      if(Redir == INVALID_SOCKET)
        Socks5SendCode(s, SOCKS_FAILURE, TempBuff, ip, (char*)&port);
      else
      {
        bzero(&saddr, sizeof(struct sockaddr_in));
        saddr.sin_family = AF_INET;
        saddr.sin_addr.s_addr = *(in_addr_t*)ip;
        saddr.sin_port = port;
    
        if(connect(Redir, (struct sockaddr*)&saddr, sizeof(struct sockaddr_in)) == -1)
        {
          Socks5SendCode(s, SOCKS_CONNECTION_REFUSED, TempBuff, ip, (char*)&port);
          closesocket(Redir);
          Redir = INVALID_SOCKET;
        }
      }
      return Redir;
    }
    
    bool Socks5CmdIsSupported(SOCKET s, char cmd, char* TempBuff, char* ip, char* port)
    {
      if(cmd != 0x01) // 0x02 - bind; 0x03 - udp associate
      {
        Socks5SendCode(s, SOCKS_CMD_NOT_SUPPORTED, TempBuff, ip, port);
        return false;
      }
    
      return true;
    }
    
    bool Socks5GetCmd(SOCKET s, char* TempBuff, char* cmd, char* ip, char* port)
    {
      struct hostent* hp;
      char DnLen;
      char AddrType;
      char Tmp[5];
    
      if(!sread(s, TempBuff, 4))
        return false;
    
      if((TempBuff[0] != SOCKS_VERSION)||(TempBuff[2] != 0x00))
        return false;
    
      *cmd = TempBuff[1];
      AddrType = TempBuff[3];
    
      switch(AddrType)
      {
        case 0x01: // ip v4
          if(!sread(s, ip, 4))
            return false;
          break;
    
        case 0x03: // domain name
    
          if(!sread(s, &DnLen, 1))
            return false;
          if(DnLen == 0)
            return false;
          if(!sread(s, TempBuff, DnLen))
            return false;
          TempBuff[DnLen] = 0x00;
    
          hp = gethostbyname(TempBuff);
    
          if(((int)hp == -1)||((int)hp == 0))
          {
            if(!sread(s, port, 2))
              return false;
    
            *(int*)(&Tmp) = 0x03000405;
            *(char*)(&Tmp + 4) = DnLen;
    
            if(swrite(s, Tmp, 5))
              if(swrite(s, TempBuff, DnLen))
                swrite(s, port, 2);
    
            return false;
          }
          else
            *(int*)ip = *(int*)hp->h_addr;
    
          break;
    
        case 0x04:  // ip v6, not supported
          *(int*)(&Tmp) = 0x04000805;
    
          if(sread(s, TempBuff, 16))
            if(sread(s, port, 2))
              if(swrite(s, Tmp, 4))
                if(swrite(s, TempBuff, 16))
                  swrite(s, port, 2);
    
          return false;
    
        default:
          return false;
      }
    
      return sread(s, port, 2);
    }
    
    #ifdef AUTH_ON
    
      bool Socks5Auth(SOCKET s, char* TempBuff)
      {
        char Login[256];
        char LoginLen;
        char PassLen;
        char Status = '\xFF';
    
        if(!sread(s, TempBuff, 2))
          return false;
    
        LoginLen = TempBuff[1];
    
        if((TempBuff[0] != 0x01)||(LoginLen == 0))
          return false;
    
        if(!sread(s, Login, LoginLen+1))
          return false;
    
        PassLen = Login[LoginLen];
    
        if(!PassLen)
          return false;
    
        Login[LoginLen] = 0x00;
    
        if(!sread(s, TempBuff, PassLen))
          return false;
    
        TempBuff[PassLen] = 0x00;
    
        if((strcmp(AuthLogin, Login) == 0)&&(strcmp(AuthPass, TempBuff) == 0))
          Status = 0x00;
    
        *(short*)TempBuff = (Status << 8) | 0x01;
    
        if(!swrite(s, TempBuff, 2))
          return false;
    
        return (Status == 0x00);
      }
    
    #endif
    
    bool Socks5Accept(SOCKET s, char* TempBuff)
    {
      char MethodsCount;
      char Cmd = '\xFF';
    
      if(!sread(s, TempBuff, 2))
        return false;
    
      MethodsCount = TempBuff[1];
    
      if((TempBuff[0] != SOCKS_VERSION)||(MethodsCount == 0))
        return false;
    
      if(!sread(s, TempBuff, MethodsCount))
        return false;
    
      do
      {
        MethodsCount--;
    
        if(TempBuff[MethodsCount] == SOCKS5_METHOD)
        {
          Cmd = TempBuff[MethodsCount];
          break;
        }
      }
      while(MethodsCount > 0);
    
      *(short*)TempBuff = (Cmd << 8) | SOCKS_VERSION;
    
      if(!swrite(s, TempBuff, 2))
        return false;
    
    #ifdef AUTH_ON
    
      return (Cmd == 0xFF) ? false : Socks5Auth(s, TempBuff);
    #else
    
      return (Cmd != 0xFF);
    #endif
    
    }
    
    __stdcall AcceptThread(SOCKET s)
    {
      SOCKET Redir;
      LPCONNECTSTRUCT ConnectStruct;
      char TempBuff[256];
      char cmd;
      char ip[4];
      u_short port;
    
      if(Socks5Accept(s, TempBuff))
        if(Socks5GetCmd(s, TempBuff, &cmd, ip, (char*)&port))
          if(Socks5CmdIsSupported(s, cmd, TempBuff, ip, (char*)&port))
          {
            Redir = Socks5ServConnect(s, TempBuff, ip, port);
    
            if(Redir != INVALID_SOCKET)
            {
              if(Socks5SendCode(s, SOCKS_SUCCESS, TempBuff, ip, (char*)&port))
              {
                ConnectStruct = CreateConnectStruct(s, Redir);
                create_thread(&SocksPipe, &(ConnectStruct->ToStruct));
                SocksPipe(&(ConnectStruct->FromStruct));
                return 0;
              }
              closesocket(Redir);
            }
          }
    
      closesocket(s);
      return 0;
    }
    
    
    int main(int argc, char* argv[])
    {
      SOCKET s, accepted;
      struct sockaddr_in saddr;
      int saddr_size = sizeof(struct sockaddr_in);
    
    #ifdef WIN32
    
      WSADATA WSA;
      if(WSAStartup(MAKEWORD(2, 2), &WSA) != 0)
        return 0;
    
    #endif
    
      s = socket(AF_INET, SOCK_STREAM, 0);
    
      if(s != INVALID_SOCKET)
      {
        bzero(&saddr, sizeof(struct sockaddr_in));
    
        saddr.sin_family = AF_INET;
        saddr.sin_port = htons(PORT);
    
        if(bind(s, (struct sockaddr*)&saddr, sizeof(struct sockaddr_in)) != SOCKET_ERROR)
          if(listen(s, 0) != SOCKET_ERROR)
            for(;;)
            {
              accepted = accept(s, (struct sockaddr*)&saddr, &saddr_size);
    
              if(accepted != INVALID_SOCKET)
                create_thread(&AcceptThread, (void*)accepted);
            }
    
        closesocket(s);
      }
    
    #ifdef WIN32
    
      WSACleanup();
      ExitProcess(0);
    
    #endif
    
      return 0;
    }
     
Thread Status:
Not open for further replies.