Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Указатели https://www.cyberforum.ru/ cpp-beginners/ thread623003.html
Простой пример по Указателям в Turbo c++ Можете несколько вариантов) Тока простые. а то я не смогу училке обяснить.
Структура C++
Простой пример по Структуре в Turbo c++. Можете несколько вариантов) Тока простые. а то я не смогу училке обяснить.
C++ Алгоритмы обходов дерева Всем добрый вечер. Не у кого случаем не завалялись алгоритмы для обходов дерева, если да, то поделитесь пожалуйста. Нужны обходы: Прямой или префиксный порядок (сверху вниз) Обратный или ... https://www.cyberforum.ru/ cpp-beginners/ thread623000.html C++ Запуск файла через cmd При открытие exe файла этой программы через cmd выводится "False", значит программе не удаётся открыть нужный файл. Если запускать через Visual Studio, то выводится "True". exe и csv файлы находятся... https://www.cyberforum.ru/ cpp-beginners/ thread622996.html
C++ Мониторинг файла?
Здравствуйте, возникла некоторая проблема в создание программы которая бы выполняла некоторые операции с информацией файла,но при условие того что он открыт пользователем в момент работы...
C++ Сортировка пузырьком https://www.cyberforum.ru/ cpp-beginners/ thread622991.html
Всем доброго времени суток! Я новичек в С++.У меня глупая ситуация: недавно написал код сортировки на C++, и сегодня решил потренироваться, так вот, Код с ошибками int _tmain(int argc, _TCHAR*...
C++ Структура CandyBar https://www.cyberforum.ru/ cpp-beginners/ thread622985.html
Первая задачка решилась сама собой, был не внимателен в коде :p Добавлено через 30 минут С первой задачкой разобрался, но тут с другой проблема вылезла. Тоже по функциям. Компилируется без...
C++ Будет ли итеративная функция значительно быстрее рекурсивной?
Вопрос не по коду. Вот есть у меня рекурсивная функция, глубина рекурсии достигает 10 в среднем. Эта функция вызывается огромное (порядка 2^31) число раз втечение работы программы. Если вытащить...
C++ Пример работы функции get_toke() https://www.cyberforum.ru/ cpp-beginners/ thread622935.html
Здравствуйте. Читаю книжку Бьярне Страуструпа в ней разбирается работа калькулатора. Возникает много вопросов, так как некоторые вещи, к сожалению, там не описаны. Функция для рассмотрения первичных...
C++ Лексический и синтаксический анализаторы https://www.cyberforum.ru/ cpp-beginners/ thread622911.html
здравствуйте.нужна помощь, по flex\bison, чтение драгон бука и поиска и google уже не хватает ,так что прошу помощи тут у Вас. лексер scaner.l D L H E ?{D}+ FS (f|F|l|L)...
Реализовать в виде модуля набор подпрограмм C++
Реализовать в виде модуля набор подпрограмм для работы с многочленами от одной переменной (1й степени t, 2й степени n). 1) сложение 2) вычитание 3) умножение 4) деление с остатком 5) операции...
C++ Адаптация ПО под 64-битную систему имею необходимость адаптировать прогу на С++ под 64 битную систему ( на 32 работает, но не на 64=() Подскажите плиз какие-нить источники, где можно почитать про адаптацию программ на С++ под 64 битку https://www.cyberforum.ru/ cpp-beginners/ thread622882.html
7 / 7 / 3
Регистрация: 02.07.2012
Сообщений: 120
0

Проблемы с текстом в потоках - C++ - Ответ 3262320

12.07.2012, 19:13. Показов 357. Ответов 0
Метки (Все метки)

В мэйне текстовая глобальная переменная static char Pass(20) меняется в цикле по принципу aaaaa, baaaa, caaaa и так по алфавиту. И так то оно хорошо работает, а вот если сделать два потока, которые используют Pass но при этом не изменяют, то в таком случае 4 последних буквы в слове не меняются, а первая буква либо r, либо p, либо :, при том что ":" в алфавите перебора и близко нет. Возефак??? Привожу вам свой код, без комментариев и в быдлокодерском стиле (должно работать в висуал студии):
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
#include <windows.h>
#include <conio.h>
#include <stdio.h>
#include <string.h>
#include <process.h>
#include "md5.h"
int t; struct sockaddr_in ssin; MD5 md5; static char Pass[20];
void Thread1( void* pParams ){
    SOCKET s; static char q[68];
    memset ((char *)&ssin, 0, sizeof(ssin));
    ssin.sin_family = AF_INET;
    ssin.sin_addr.s_addr=inet_addr("134.0.113.4");
    ssin.sin_port = htons(80);
while(true){
    if(t == 1){
    s=socket(AF_INET,SOCK_STREAM,IPPROTO_TCP);
    connect(s, (sockaddr *)&ssin, sizeof(ssin));
    sprintf(q,"POST /launcher/client.php HTTP/1.1"
    "\nContent-Length: 68"
    "\nConnection: Keep-Alive"
    "\nAccept-Encoding: gzip"
    "\nAccept-Language: ru-RU,en,*"
    "\nUser-Agent: Mozilla/5.0"
    "\nHost: minecraft.pvp.gs"
    "\nContent-Type: application/x-www-form-urlencoded\n\n"
    "do=CheckLogin&username=Eccentric&pass=%s         ",md5.digestString(Pass));
    send(s,q,strlen(q),0);
    recv(s,q,strlen(q),0);
    if(strstr(q,"badPass")==0){
    printf("Pass = %s\n",Pass);
    _getch();}
    printf("1 - %s\n",Pass);
    closesocket(s);
    }}}
void Thread2( void* pParams ){
    SOCKET s; static char q[68];
    memset ((char *)&ssin, 0, sizeof(ssin));
    ssin.sin_family = AF_INET;
    ssin.sin_addr.s_addr=inet_addr("134.0.113.4");
    ssin.sin_port = htons(80);
while(true){
    if(t == 2){
    s=socket(AF_INET,SOCK_STREAM,IPPROTO_TCP);
    connect(s, (sockaddr *)&ssin, sizeof(ssin));
    sprintf(q,"POST /launcher/client.php HTTP/1.1"
    "\nContent-Length: 68"
    "\nConnection: Keep-Alive"
    "\nAccept-Encoding: gzip"
    "\nAccept-Language: ru-RU,en,*"
    "\nUser-Agent: Mozilla/5.0"
    "\nHost: minecraft.pvp.gs"
    "\nContent-Type: application/x-www-form-urlencoded\n\n"
    "do=CheckLogin&username=Eccentric&pass=%s         ",md5.digestString(Pass));
    send(s,q,strlen(q),0);
    recv(s,q,strlen(q),0);
    if(strstr(q,"badPass")==0){
    printf("Pass = %s\n",Pass);
    _getch();}
    printf("2 - %s\n",Pass);
    closesocket(s);
    }}}
void main(){
    _beginthread( Thread1, 0, NULL );
    _beginthread( Thread2, 0, NULL );
    WSADATA lpWSAData;
    char *url="http://minecraft.pvp.gs/"; url+=7;
    FILE *file; char PassGet[20];
    WSAStartup(MAKEWORD(2,2),&lpWSAData);
    struct sockaddr_in ssin;
    memset ((char *)&ssin, 0, sizeof(ssin));
    ssin.sin_family = AF_INET;
    ssin.sin_addr.s_addr=inet_addr("134.0.113.4");
    ssin.sin_port = htons(80);
    char *query=(char*)malloc(68);
    file=fopen("file.txt","r");
    if(file!=0){
    fgets(PassGet,20,file); 
    printf("Loaded pass = %s\n",PassGet);}
    fclose(file);
    SOCKET s=socket(AF_INET,SOCK_STREAM,IPPROTO_TCP);
    connect(s, (sockaddr *)&ssin, sizeof(ssin));
    sprintf(query,"POST /launcher/client.php HTTP/1.1"
    "\nContent-Length: 68"
    "\nConnection: Keep-Alive"
    "\nAccept-Encoding: gzip"
    "\nAccept-Language: ru-RU,en,*"
    "\nUser-Agent: Mozilla/5.0"
    "\nHost: minecraft.pvp.gs"
    "\nContent-Type: application/x-www-form-urlencoded\n\n"
    "do=CheckLogin&username=Eccentric&pass=%s         ",md5.digestString(PassGet));
    send(s,query,strlen(query),0);
    recv(s,query,strlen(query),0);
    if(strstr(query,"badPass")==0){
    printf("Pass = %s\n",PassGet);
    _getch();}
    printf("%s\n",PassGet);
    closesocket(s);
    strcpy(Pass, PassGet);
    static char szAlphabet[256];
    strcpy(szAlphabet, "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ_0123456789"); 
    static unsigned char bAlphabet[256];int i = 0, k = 0; 
    while (true){bAlphabet[k]=(unsigned char)szAlphabet[i];if(!szAlphabet[i])break; 
    k = (unsigned char)szAlphabet[i];i++;}
    i = 1;
    while (true){__asm{ 
    pushad 
    mov edi,offset Pass
    mov ebx,offset bAlphabet 
    L1: movzx eax,byte ptr [edi] 
    xlat 
    cmp al,0 
    je L3 
    mov [edi],al
    jmp L5 
    L3: xlat
    stosb 
    jmp L1
    L5: popad}
    switch (i){
    case 1:
        t = 1;
        i++;
    break;
    case 2:
        t = 2;
        i--;
    break;
    }
    }
    /*
    s=socket(AF_INET,SOCK_STREAM,IPPROTO_TCP);
    connect(s, (sockaddr *)&ssin, sizeof(ssin));
    sprintf(query,"POST /launcher/client.php HTTP/1.1"
    "\nContent-Length: 68"
    "\nConnection: Keep-Alive"
    "\nAccept-Encoding: gzip"
    "\nAccept-Language: ru-RU,en,*"
    "\nUser-Agent: Mozilla/5.0"
    "\nHost: minecraft.pvp.gs"
    "\nContent-Type: application/x-www-form-urlencoded\n\n"
    "do=CheckLogin&username=Eccentric&pass=%s         ",md5.digestString(Pass));
    send(s,query,strlen(query),0);
    recv(s,query,strlen(query),0);
    if(strstr(query,"badPass")==0){
    printf("Pass = %s\n",Pass);
    _getch();}
    printf("%s\n",Pass);
    closesocket(s);*/
    file=fopen("file.txt","w");
    fputs(Pass,file);
    fclose(file);
    WSACleanup();
    _getch();
    }
И мд5 для заголовка:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
#ifndef MD5_H
#define MD5_H
#pragma region MD5 defines
static unsigned char PADDING[64] = {
  0x80, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
};
#define F(x, y, z) (((x) & (y)) | ((~x) & (z)))
#define G(x, y, z) (((x) & (z)) | ((y) & (~z)))
#define H(x, y, z) ((x) ^ (y) ^ (z))
#define I(x, y, z) ((y) ^ ((x) | (~z)))
#define ROTATE_LEFT(x, n) (((x) << (n)) | ((x) >> (32-(n))))
#define FF(a, b, c, d, x, s, ac) { \
  (a) += F ((b), (c), (d)) + (x) + (UINT4)(ac); \
  (a) = ROTATE_LEFT ((a), (s)); \
  (a) += (b); \
  }
#define GG(a, b, c, d, x, s, ac) { \
  (a) += G ((b), (c), (d)) + (x) + (UINT4)(ac); \
  (a) = ROTATE_LEFT ((a), (s)); \
  (a) += (b); \
  }
#define HH(a, b, c, d, x, s, ac) { \
  (a) += H ((b), (c), (d)) + (x) + (UINT4)(ac); \
  (a) = ROTATE_LEFT ((a), (s)); \
  (a) += (b); \
  }
#define II(a, b, c, d, x, s, ac) { \
  (a) += I ((b), (c), (d)) + (x) + (UINT4)(ac); \
  (a) = ROTATE_LEFT ((a), (s)); \
  (a) += (b); \
  }
#pragma endregion
typedef unsigned char BYTE ;
typedef unsigned char *POINTER;
typedef unsigned short int UINT2;
typedef unsigned long int UINT4;
class MD5 {
private:
  struct __context_t {
    UINT4 state[4];
    UINT4 count[2];
    unsigned char buffer[64];
  } context ;
  #pragma region static helper functions
  static void MD5Transform( UINT4 state[4], unsigned char block[64] )
  {
    UINT4 a = state[0], b = state[1], c = state[2], d = state[3], x[16];
    Decode (x, block, 64);
    FF (a, b, c, d, x[ 0], 7, 0xd76aa478); /* 1 */
    FF (d, a, b, c, x[ 1], 12, 0xe8c7b756); /* 2 */
    FF (c, d, a, b, x[ 2], 17, 0x242070db); /* 3 */
    FF (b, c, d, a, x[ 3], 22, 0xc1bdceee); /* 4 */
    FF (a, b, c, d, x[ 4], 7, 0xf57c0faf); /* 5 */
    FF (d, a, b, c, x[ 5], 12, 0x4787c62a); /* 6 */
    FF (c, d, a, b, x[ 6], 17, 0xa8304613); /* 7 */
    FF (b, c, d, a, x[ 7], 22, 0xfd469501); /* 8 */
    FF (a, b, c, d, x[ 8], 7, 0x698098d8); /* 9 */
    FF (d, a, b, c, x[ 9], 12, 0x8b44f7af); /* 10 */
    FF (c, d, a, b, x[10], 17, 0xffff5bb1); /* 11 */
    FF (b, c, d, a, x[11], 22, 0x895cd7be); /* 12 */
    FF (a, b, c, d, x[12], 7, 0x6b901122); /* 13 */
    FF (d, a, b, c, x[13], 12, 0xfd987193); /* 14 */
    FF (c, d, a, b, x[14], 17, 0xa679438e); /* 15 */
    FF (b, c, d, a, x[15], 22, 0x49b40821); /* 16 */
    GG (a, b, c, d, x[ 1], 5, 0xf61e2562); /* 17 */
    GG (d, a, b, c, x[ 6], 9, 0xc040b340); /* 18 */
    GG (c, d, a, b, x[11], 14, 0x265e5a51); /* 19 */
    GG (b, c, d, a, x[ 0], 20, 0xe9b6c7aa); /* 20 */
    GG (a, b, c, d, x[ 5], 5, 0xd62f105d); /* 21 */
    GG (d, a, b, c, x[10], 9,  0x2441453); /* 22 */
    GG (c, d, a, b, x[15], 14, 0xd8a1e681); /* 23 */
    GG (b, c, d, a, x[ 4], 20, 0xe7d3fbc8); /* 24 */
    GG (a, b, c, d, x[ 9], 5, 0x21e1cde6); /* 25 */
    GG (d, a, b, c, x[14], 9, 0xc33707d6); /* 26 */
    GG (c, d, a, b, x[ 3], 14, 0xf4d50d87); /* 27 */
    GG (b, c, d, a, x[ 8], 20, 0x455a14ed); /* 28 */
    GG (a, b, c, d, x[13], 5, 0xa9e3e905); /* 29 */
    GG (d, a, b, c, x[ 2], 9, 0xfcefa3f8); /* 30 */
    GG (c, d, a, b, x[ 7], 14, 0x676f02d9); /* 31 */
    GG (b, c, d, a, x[12], 20, 0x8d2a4c8a); /* 32 */
    HH (a, b, c, d, x[ 5], 4, 0xfffa3942); /* 33 */
    HH (d, a, b, c, x[ 8], 11, 0x8771f681); /* 34 */
    HH (c, d, a, b, x[11], 16, 0x6d9d6122); /* 35 */
    HH (b, c, d, a, x[14], 23, 0xfde5380c); /* 36 */
    HH (a, b, c, d, x[ 1], 4, 0xa4beea44); /* 37 */
    HH (d, a, b, c, x[ 4], 11, 0x4bdecfa9); /* 38 */
    HH (c, d, a, b, x[ 7], 16, 0xf6bb4b60); /* 39 */
    HH (b, c, d, a, x[10], 23, 0xbebfbc70); /* 40 */
    HH (a, b, c, d, x[13], 4, 0x289b7ec6); /* 41 */
    HH (d, a, b, c, x[ 0], 11, 0xeaa127fa); /* 42 */
    HH (c, d, a, b, x[ 3], 16, 0xd4ef3085); /* 43 */
    HH (b, c, d, a, x[ 6], 23,  0x4881d05); /* 44 */
    HH (a, b, c, d, x[ 9], 4, 0xd9d4d039); /* 45 */
    HH (d, a, b, c, x[12], 11, 0xe6db99e5); /* 46 */
    HH (c, d, a, b, x[15], 16, 0x1fa27cf8); /* 47 */
    HH (b, c, d, a, x[ 2], 23, 0xc4ac5665); /* 48 */
    II (a, b, c, d, x[ 0], 6, 0xf4292244); /* 49 */
    II (d, a, b, c, x[ 7], 10, 0x432aff97); /* 50 */
    II (c, d, a, b, x[14], 15, 0xab9423a7); /* 51 */
    II (b, c, d, a, x[ 5], 21, 0xfc93a039); /* 52 */
    II (a, b, c, d, x[12], 6, 0x655b59c3); /* 53 */
    II (d, a, b, c, x[ 3], 10, 0x8f0ccc92); /* 54 */
    II (c, d, a, b, x[10], 15, 0xffeff47d); /* 55 */
    II (b, c, d, a, x[ 1], 21, 0x85845dd1); /* 56 */
    II (a, b, c, d, x[ 8], 6, 0x6fa87e4f); /* 57 */
    II (d, a, b, c, x[15], 10, 0xfe2ce6e0); /* 58 */
    II (c, d, a, b, x[ 6], 15, 0xa3014314); /* 59 */
    II (b, c, d, a, x[13], 21, 0x4e0811a1); /* 60 */
    II (a, b, c, d, x[ 4], 6, 0xf7537e82); /* 61 */
    II (d, a, b, c, x[11], 10, 0xbd3af235); /* 62 */
    II (c, d, a, b, x[ 2], 15, 0x2ad7d2bb); /* 63 */
    II (b, c, d, a, x[ 9], 21, 0xeb86d391); /* 64 */
    state[0] += a;
    state[1] += b;
    state[2] += c;
    state[3] += d;
    memset((POINTER)x, 0, sizeof (x));
  }
  static void Encode( unsigned char *output, UINT4 *input, unsigned int len )
  {
    unsigned int i, j;
    for (i = 0, j = 0; j < len; i++, j += 4) {
      output[j] = (unsigned char)(input[i] & 0xff);
      output[j+1] = (unsigned char)((input[i] >> 8) & 0xff);
      output[j+2] = (unsigned char)((input[i] >> 16) & 0xff);
      output[j+3] = (unsigned char)((input[i] >> 24) & 0xff);
    }
  }
  static void Decode( UINT4 *output, unsigned char *input, unsigned int len )
  { unsigned int i, j;
    for (i = 0, j = 0; j < len; i++, j += 4)
      output[i] = ((UINT4)input[j]) | (((UINT4)input[j+1]) << 8) |
      (((UINT4)input[j+2]) << 16) | (((UINT4)input[j+3]) << 24);
  }
  #pragma endregion
public:
  MD5(){
    Init() ;}
  void Init()
  {
    context.count[0] = context.count[1] = 0;
    context.state[0] = 0x67452301;
    context.state[1] = 0xefcdab89;
    context.state[2] = 0x98badcfe;
    context.state[3] = 0x10325476;
  }
  void Update(
    unsigned char *input,
    unsigned int inputLen ){
    unsigned int i, index, partLen;
    index = (unsigned int)((context.count[0] >> 3) & 0x3F);
    if ((context.count[0] += ((UINT4)inputLen << 3))
      < ((UINT4)inputLen << 3))
      context.count[1]++;
    context.count[1] += ((UINT4)inputLen >> 29);
    partLen = 64 - index;
    if (inputLen >= partLen) {
      memcpy((POINTER)&context.buffer[index], (POINTER)input, partLen);
      MD5Transform (context.state, context.buffer);
      for (i = partLen; i + 63 < inputLen; i += 64)
        MD5Transform (context.state, &input[i]);
      index = 0;
    }
    else
      i = 0;
    memcpy((POINTER)&context.buffer[index], (POINTER)&input[i], inputLen-i);}
  void Final(){
    unsigned char bits[8];
    unsigned int index, padLen;
    Encode( bits, context.count, 8 );
    index = (unsigned int)((context.count[0] >> 3) & 0x3f);
    padLen = (index < 56) ? (56 - index) : (120 - index);
    Update( PADDING, padLen );
    Update( bits, 8 );
    Encode( digestRaw, context.state, 16);
    memset((POINTER)&context, 0, sizeof (context));
    writeToString() ;}
  void writeToString(){
    int pos ;
    for( pos = 0 ; pos < 16 ; pos++ )
      sprintf( digestChars+(pos*2), "%02x", digestRaw[pos] ) ;}
public:
  BYTE digestRaw[ 16 ] ;
  char digestChars[ 33 ] ;
  char* digestFile( char *filename ){
    Init() ;
    FILE *file;
    int len;
    unsigned char buffer[1024] ;
    if( (file = fopen (filename, "rb")) == NULL )
      printf( "%s can't be opened\n", filename ) ;
    else{
      while( len = fread( buffer, 1, 1024, file ) )
        Update( buffer, len ) ;
      Final();
      fclose( file );}
    return digestChars ;}
  char* digestMemory( BYTE *memchunk, int len ){
    Init() ;
    Update( memchunk, len ) ;
    Final() ;
    return digestChars ;}
  char* digestString( char *string ){
    Init() ;
    Update( (unsigned char*)string, strlen(string) ) ;
    Final() ;
    return digestChars ;}
} ;
#endif
Уточнение к вопросу: Pass работает, если есть только один поток.

Вернуться к обсуждению:
Проблемы с текстом в потоках C++
0

Помощь в написании контрольных, курсовых и дипломных работ здесь.

Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
12.07.2012, 19:13
Готовые ответы и решения:

Проблемы с текстом
Считываю данные и xml файла. Проблема в том, что все тексты представляются в виде...

Проблемы с текстом (новичок)
Как перевести текст на новую строку создаю стринг файл, и туда вложил целый текст, теперь хочу...

Проблемы с многострочным текстом и вертикальной полосой прокрутки
Добрый вечер! Подскажите пожалуйста как запрограммировать текст (EDIT) чтобы он переходил на другую...

Проблемы с русским текстом при работе с FM20.dll.
При работе с FM20.dll возникла проблема: кирилический текст в ComboBox и TextBox вводится в виде...

0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
12.07.2012, 19:13

Проблемы с русским текстом при получении его из полей
Добрый день. Имеется следующая проблема: Если русский текст указан напрямую в коде разметки, то...

Нужна кнопка в виде шарика с текстом, и анимированный шарик с текстом.
где найти готовый? дополню: шарик с текстом у меня есть, но это просто плоский текст на сферическом...

Циклы в потоках
Использую многопоточность.Необходимо включить в тело потока 2-3 цикла,не навредит ли это работе...

О воздушных потоках
Добрый день. Уже который день, не даёт покоя вопрос отвода тепла от наиболее горячих элементов ПК....

0
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2021, vBulletin Solutions, Inc.