Перейти из форума на сайт.

НовостиФайловые архивы
ПоискАктивные темыТоп лист
ПравилаКто в on-line?
Вход Забыли пароль? Первый раз на этом сайте? Регистрация
Компьютерный форум Ru.Board » Компьютеры » Прикладное программирование » Вопросы по программированию на C/С++

Модерирует : ShIvADeSt

 Версия для печати • ПодписатьсяДобавить в закладки
Страницы: 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 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322

Открыть новую тему     Написать ответ в эту тему

Crazy_Shrike



Member
Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
Вопросы по программированию на C/С++

 
  • Справочники, книги
  • Выбор IDE (среды программирования)
     
    Постарайтесь дать как можно больше информации о возникшей проблеме - это в конце концов в ваших же интересах чтобы вам помогли.

    Решения конкретных задач собираются и обсуждаются в теме Задачи по C/С++ .

    Прежде чем просить помощи в задании...
    Если позарез надо и вы даже готовы заплатить

    Как правильно задавать вопросы, если вы хотите получить ответ.

    Полезные ссылки:
    C++(eng)

  • Всего записей: 241 | Зарегистр. 25-03-2004 | Отправлено: 13:37 06-05-2004 | Исправлено: AZJIO, 19:45 12-05-2014
    kotlomoy



    Junior Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    kvazigorynich
    Порядок байт как раз таки не меняется. В Windows числа в памяти располагаются в порядке от младшего байта к старшему, что вы и увидели. По смещению 2 действительно лежит число 0x32317412.
    Если нужно вывести содержимое памяти побайтно, то и выводите побайтно - для этого есть тип char.

    Всего записей: 172 | Зарегистр. 06-03-2008 | Отправлено: 00:32 15-01-2012
    kvazigorynich

    Advanced Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    Ничего не понял.
     
    В файле по смещению 2 последовательность hex 12743132
    В буфере после чтения последовательность hex 12743132
    Вывод через printf происходит в обратном порядке из-за того что при переводе в __int64 память считывается как little-endian?

    Всего записей: 794 | Зарегистр. 06-09-2007 | Отправлено: 15:59 15-01-2012 | Исправлено: kvazigorynich, 16:37 15-01-2012
    kotlomoy



    Junior Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    kvazigorynich
    Да, числа в памяти лежат в little-endian

    Всего записей: 172 | Зарегистр. 06-03-2008 | Отправлено: 19:43 15-01-2012
    V0lt



    Platinum Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    Вопрос по типу size_t для индексации массивов на x64-машине.
    Всегда ли полезно использовать size_t вместо unsigned int?

    Всего записей: 10488 | Зарегистр. 05-02-2003 | Отправлено: 21:48 16-01-2012
    Eminence

    Junior Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору

    Цитата:
    Всегда ли полезно использовать size_t вместо unsigned int?

    Всегда - так эффективнее обеспечивается совместимость и переход на другую платформу

    Всего записей: 106 | Зарегистр. 26-09-2009 | Отправлено: 22:02 16-01-2012
    V0lt



    Platinum Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору

    Цитата:
    Всегда - так эффективнее обеспечивается совместимость и переход на другую платформу

    Что это значит? Другая платформа не понимает 32-битные целые?
     
    Я читал про "а вдруг нам понадобиться массив с числом элементов более 4294967296", но для моих задач это несусветный бред.

    Всего записей: 10488 | Зарегистр. 05-02-2003 | Отправлено: 22:26 16-01-2012
    Eminence

    Junior Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    Размерность - в 64-битной платформе size_t определяется как 64 разряда, в 32-битной - как 32. Если использовать unsigned int, то 64-битный компиллятор будет везде выдавать warning типа "Приведение к меньшей разрядности, возможна потеря данных". Некритично, конечно, но некрасиво

    Всего записей: 106 | Зарегистр. 26-09-2009 | Отправлено: 22:34 16-01-2012
    V0lt



    Platinum Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору

    Код:
    DWORD dwPos = 123;
    SetFilePointerEx(hFile, *(LARGE_INTEGER*)(LONGLONG)dwPos, NULL, FILE_BEGIN);
    SetFilePointerEx(hFile, *(LARGE_INTEGER*)(LONGLONG)456, NULL, FILE_BEGIN);

    Вроде ничего не напутал. Можно ли упростить вторую и третью строки?

    Всего записей: 10488 | Зарегистр. 05-02-2003 | Отправлено: 20:16 21-01-2012 | Исправлено: V0lt, 22:00 21-01-2012
    Abs62



    Gold Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    V0lt
    Привести DWORD к LARGE_INTEGER*, а потом разыменовать указатель? Боюсь, это даст не вполне ожидаемый результат.

    ----------
    0 программистов ругал сердитый шеф
    Потом уволил одного, и стало их FF

    Всего записей: 6079 | Зарегистр. 22-10-2005 | Отправлено: 21:20 21-01-2012
    V0lt



    Platinum Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    Abs62
    Мне нужно вторым параметром задавать целые числа. Но просто так не получается, функция хочет PLARGE_INTEGER.

    Всего записей: 10488 | Зарегистр. 05-02-2003 | Отправлено: 21:26 21-01-2012
    Abs62



    Gold Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    V0lt
    Значит, надо сделать LARGE_INTEGER. Так просто привести не получится, это структура.


    ----------
    0 программистов ругал сердитый шеф
    Потом уволил одного, и стало их FF

    Всего записей: 6079 | Зарегистр. 22-10-2005 | Отправлено: 21:55 21-01-2012
    V0lt



    Platinum Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору

    Цитата:
    Так просто привести не получится, это структура.

    В описании говорится, что LARGE_INTEGER можно рассматривать как струтуру (DWORD+LONG) либо как целое (LONGLONG).
    Т.е. значения LowPart и HighPart хранятся там же где и QuadPart. Или я чего-то не допонимаю.
     
    Еще вопрос
    Код:
    LARGE_INTEGER offset;
    offset.QuadPart = 0;
    SetFilePointerEx(hFile, offset, &offset, FILE_CURRENT);
    Такой код корректен?

    Всего записей: 10488 | Зарегистр. 05-02-2003 | Отправлено: 22:16 21-01-2012
    Abs62



    Gold Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    V0lt

    Цитата:
    В описании говорится, что LARGE_INTEGER можно рассматривать как струтуру (DWORD+LONG) либо как целое (LONGLONG).

    Не говорится там такого. Там говорится о том, что это union. union нельзя рассматривать как целое, это такой специфический вид структуры, все поля которой находятся по одному адресу.

    Цитата:
    Т.е. значения LowPart и HighPart хранятся там же где и QuadPart.

    Вот это верно.

    Цитата:
    Такой код корректен?

    Если компилятор поддерживает 64-разрядные целые, то да. Как уверяет Microsoft.

    ----------
    0 программистов ругал сердитый шеф
    Потом уволил одного, и стало их FF

    Всего записей: 6079 | Зарегистр. 22-10-2005 | Отправлено: 22:42 21-01-2012
    V0lt



    Platinum Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    Abs62
    Цитата:
    Там говорится о том, что это union. union нельзя рассматривать как целое, это такой специфический вид структуры, все поля которой находятся по одному адресу.

    Хоть мне это не нравиться , но спасибо за объяснение.
     

    Цитата:
    Если компилятор поддерживает 64-разрядные целые, то да. Как уверяет Microsoft.

    Я о другом, SetFilePointerEx(hFile, offset, &offset, FILE_CURRENT). Логика подсказывает, что должно работать.

    Всего записей: 10488 | Зарегистр. 05-02-2003 | Отправлено: 23:43 21-01-2012
    Abs62



    Gold Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    V0lt

    Цитата:
    Я о другом, SetFilePointerEx(hFile, offset, &offset, FILE_CURRENT). Логика подсказывает, что должно работать.

    Ну да. Параметр liDistanceToMove передаётся по значению. То бишь передаётся копия offset. А копия offset и текущее значение offset - это две разные, не зависящие друг от друга переменные. Так что никакого криминала тут нет.

    ----------
    0 программистов ругал сердитый шеф
    Потом уволил одного, и стало их FF

    Всего записей: 6079 | Зарегистр. 22-10-2005 | Отправлено: 23:59 21-01-2012
    gefixRu

    Newbie
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    я похоже не шибко опытный в таких вопросах.
    в общем, у меня есть в одном из методов такая строка:
    String ^command = "http://" + this->url + "scripts/external.connect.php?userlogin=" + this->login + "&userpsw=" + this->password + "&usercookie=" + this->usercookie;
     
    1) дело в том, что в некоторых случаях вызова метода с этой строкой конкатенация строк происходит до последней переменной экземпляра класса. то есть в данном случае получается command == "http://" + this->url и все.
     
    2) если вызвать метод из того места, где конкатенация строк проходит нормально, а потом из того места, где неправильно как я написал уже, то и во втором случае уже все работает как надо
     
    что я делаю не так?

    Всего записей: 3 | Зарегистр. 19-02-2011 | Отправлено: 21:02 25-01-2012 | Исправлено: gefixRu, 21:43 25-01-2012
    V0lt



    Platinum Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    Мне нужен целый тип на 128 бит. Есть __int128, но его не получается использовать (VS 2010, x86).
    Что посоветуете?

    Всего записей: 10488 | Зарегистр. 05-02-2003 | Отправлено: 20:32 28-01-2012
    alexeybar2008

    Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    посоветуйте как в Си (консольное приложение С собираю в VS2008) объявить динамический массив, каждая ячейка которого это 6 байт .  
     
    Он должен инициализироваться и в ходе выполнения в конец могут добавляться элементы.
     
     
    На код:
    byte_t (*defaultKeys)[6] = {
            {0xff, 0xff, 0xff, 0xff, 0xff, 0xff},
            {0x00, 0x00, 0x00, 0x00, 0x00, 0x00}};
     
    ругается:error C2078: слишком много инициализаторов
     
    Или может как-то можно byte_t[6]  объявить как отдельный тип (mykey) и  
    записать mykey *defaultKeys;  ???

    Всего записей: 225 | Зарегистр. 13-01-2009 | Отправлено: 17:10 30-01-2012 | Исправлено: alexeybar2008, 17:10 30-01-2012
    akaGM

    Platinum Member
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    alexeybar2008
    так в чём его динамичность?
     

    Цитата:
    в ходе выполнения в конец могут добавляться элементы
    так значит больше 6?
     
    попробуй так:
     
        typedef byte_t bytes6[6];
        bytes6 * defaultKeys;
     
    defaultKeys -- указатель на 6-ти байтовую последовательность, с ним можно выделять память, а defaultKeys[0],  defaultKeys[100] -- адресация этих 6-байтовых кусков

    Всего записей: 24106 | Зарегистр. 06-12-2002 | Отправлено: 17:34 30-01-2012
    Eks1987

    Newbie
    Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
    Добрый День всем, нужна помощь, собсно есть 2 файла которые нужно поместить в определенную папку на диске Ц и 1-н из файлов нужно запустить, после того как он скопируется в нужную дерикториюи все это в 1-н клик по **.bat

    Всего записей: 7 | Зарегистр. 30-01-2012 | Отправлено: 18:00 30-01-2012
    Открыть новую тему     Написать ответ в эту тему

    Страницы: 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 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322

    Компьютерный форум Ru.Board » Компьютеры » Прикладное программирование » Вопросы по программированию на C/С++


    Реклама на форуме Ru.Board.

    Powered by Ikonboard "v2.1.7b" © 2000 Ikonboard.com
    Modified by Ru.B0ard
    © Ru.B0ard 2000-2024

    BitCoin: 1NGG1chHtUvrtEqjeerQCKDMUi6S6CG4iC

    Рейтинг.ru