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

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

Модерирует : 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 323

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

V1s1ter



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
         
Обсуждаем новые возможности и баги
 
Просьба писать про Embarcadero RAD Studio XE5, XE6, XE7, XE8, 10.x (Seattle, Berlin,Tokyo)
  По вопросам скачивания - Тема в Варезнике (lite-версии тут)
  Вопросы по неюникодным версиям Delphi — шестая бумага
  Бесплатные Компоненты и утилиты для Delphi/BCB/FreePascal/Lazarus
  Коммерческие компоненты и утилиты для Delphi/BCB
  Вопросы по компонентам для Delphi, C++ Builder разных версий
  Новые языковые возможности, начиная с Delphi 2005 по XE4 — здесь, и New!здесь еще
  Англоязычный официальный форум Embarcadero — здесь
  Embarcadero Quality Central, веб интерфейс — здесь, новый Quality Portal тут
  Программирование на Delphi — викиверситет
  Другие ресурсы
   Предыдущие бумаги
 
     Вопросы ..XE4       Вопросы ..XE3    Вопросы ..XE2      
  Вопросы ..2009-XE    Вопросы ..<2009 / ч.5    Вопросы ..<2009 / ч.4      
  Вопросы ..<2009 / ч.3    Вопросы ..Delphi 2 / ч.2    Вопросы ..Delphi  

  Выключение встроенного эксперта Castalia  для XE8 (иногда помогает при вылетах и тормозах)  
  Полезные плагины(эксперты)

Всего записей: 948 | Зарегистр. 06-02-2007 | Отправлено: 15:25 11-09-2013 | Исправлено: Komandor, 15:49 31-03-2024
dred2k



Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
yura371, бд при удалении записи или обнулении поля физический размер не поменяет. Внутри физических файлов бд - страничная организация, и кол-во страниц не уменьшается, место в странице (или даже в нескольких) просто помечается как свободное. Примерно так.

Всего записей: 403 | Зарегистр. 15-02-2006 | Отправлено: 20:31 19-03-2015
Frodo_Torbins

Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
yura371
Что за БД?
А вообще это нормальное явление, когда неиспользуемая память придерживается на какое то время. Ведь чтобы правильно освободить место, придется перезаписывать весьма большой кусок памяти, а это время * количество удалений. Поэтому многие системы (не только БД) откладывают такие затратные операции на потом.

Всего записей: 2318 | Зарегистр. 24-05-2007 | Отправлено: 20:35 19-03-2015 | Исправлено: Frodo_Torbins, 20:37 19-03-2015
yura371



Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
БД SQLite.
Блин записал картинку в БД а удалить физически не могу, удаляется только указатель как я понял.

Всего записей: 20 | Зарегистр. 10-02-2013 | Отправлено: 20:38 19-03-2015
DYUMON



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

Всего записей: 84 | Зарегистр. 03-11-2009 | Отправлено: 20:51 19-03-2015
yura371



Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Спасибо через Delphi работает, но через SQLite Browser пишет:  
"cannot VACUUM from within a transaction: VACUUM;"

Всего записей: 20 | Зарегистр. 10-02-2013 | Отправлено: 21:08 19-03-2015
yura371



Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Этот код считывает BLOB поле из БД и сохраняет в файл Karta.png.
Почему после выполнения этого кода на выходе получается картинка такого же размера, как оригинал, но пустая по содержимому, т.е. заполненная нулями? Причем это только в Android, в Windows все нормально. MemStream почему то зануляет данные в Android.
 

var MemStream: TMemoryStream;
    BlobStream: TStream;
    TmpFile: string;
 
TmpFile := TPath.Combine(TPath.GetTempPath, 'Karta.png');  
MemStream := TMemoryStream.Create;
  try
      SQLConnection1.Params.Add('Database='+TPath.Combine(TPath.GetTempPath, 'Base.s3db'));
      SQLDataSet1.Active:=false;
      SQLDataSet1.CommandText:='Настройки';
      SQLDataSet1.Active:=true;
      SQLDataSet1.First;
      BlobStream:=SQLQuery1.CreateBlobStream(SQLDataSet1.FieldByName('Карта'), TBlobStreamMode.bmRead);
      BlobStream.Position:=0;
      MemStream.LoadFromStream(BlobStream);
      MemStream.SaveToFile(TmpFile);
  finally
    MemStream.Free;
    BlobStream.Free;
  end;

Всего записей: 20 | Зарегистр. 10-02-2013 | Отправлено: 12:21 21-03-2015 | Исправлено: yura371, 12:23 21-03-2015
NeoAnomaly

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

Цитата:
MemStream почему то зануляет данные в Android

Почему решил, что memstream? А сразу BlobStream.SaveToFile нельзя сделать?

Всего записей: 418 | Зарегистр. 23-03-2010 | Отправлено: 13:47 21-03-2015
yura371



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

Цитата:
Почему решил, что memstream? А сразу BlobStream.SaveToFile нельзя сделать?  

Нет такого параметра.
Решил проблему этим кодом без MemSteam:
      BlobStream.Position:=0;
      with TFileStream.Create(TmpFile, fmCreate) do
      try
        CopyFrom(BlobStream, BlobStream.Size)
      finally
        Free
      end;

Всего записей: 20 | Зарегистр. 10-02-2013 | Отправлено: 14:18 21-03-2015
xpin2013



Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
yura371
Очень правильный подход. Не забываем try - finally.

Всего записей: 291 | Зарегистр. 16-01-2014 | Отправлено: 00:41 23-03-2015
prokl1986

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
можно ли при помощи XE5, XE6, XE7 перегнать программу, написанную на Delphi 7, на Андроид
Проблема в том, что в программе используются сторонние библиотеки DLL. Консультанты по продажам говорят, что можно, но нужно еще какой-то блок докупать. Что-то я им не очень верю

Всего записей: 13 | Зарегистр. 22-03-2015 | Отправлено: 18:44 24-03-2015
Frodo_Torbins

Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
prokl1986
Интерфейс придется переделывать полностью. А если у вас, как это часто бывает, весь код в обработчиках событий, то считайте 50% проги нужно будет переписать.
Если используются сторонние DLL, то нужно подумать что они делают, возможно удастся обойтись и без них. Если это что то очень специфичное, то вам одна дорога: делать связку сервер приложений на винде + тонкий клиент на мобиле. В случае БД-шной проги это получится трехзвенка. Ну и тут целая куча разных вариантов, начиная от встроенных и заканчивая платными сторонними.

Всего записей: 2318 | Зарегистр. 24-05-2007 | Отправлено: 20:45 24-03-2015 | Исправлено: Frodo_Torbins, 20:46 24-03-2015
AlekXL



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

Цитата:
можно ли при помощи XE5, XE6, XE7 перегнать программу, написанную на Delphi 7, на Андроид
Проблема в том, что в программе используются сторонние библиотеки DLL. Консультанты по продажам говорят, что можно, но нужно еще какой-то блок докупать. Что-то я им не очень верю

судя по вашему вопросу, вам нужно нанять опытного программиста.
такого, которому можете доверять.
Frodo_Torbins
 

Цитата:
. А если у вас, как это часто бывает, весь код в обработчиках событий, то считайте 50% проги нужно будет переписать

это если программа простая. В сложной, все же меньше 50%, не пугай нуба.
 

Цитата:
Если используются сторонние DLL, то нужно подумать что они делают, возможно удастся обойтись и без них

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

Всего записей: 792 | Зарегистр. 24-04-2008 | Отправлено: 22:40 25-03-2015
nyinick



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

Цитата:
можно ли при помощи XE5, XE6, XE7 перегнать программу, написанную на Delphi 7, на Андроид

Проще переписать с нуля, максимум используя часть старого кода, который никак не взаимодействует с VCL  
Программа для Windows завязана на VCL (если на Дельфи 7 разработка велась), та, что под Андроид - на FMX. Практически многие платформозависимые части программы, в том числе используемые dll файлы, портировать для работы на Андроид не получится.

Всего записей: 251 | Зарегистр. 26-06-2006 | Отправлено: 16:11 26-03-2015
AlekXL



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

Цитата:
Практически многие платформозависимые части программы, в том числе используемые dll файлы, портировать для работы на Андроид не получится.  

у тебя хрустальный шар? Если библиотека использует CreateFile,ReadFile Windows функции, то трудно ли портировать ее под линукс(андроид)?
Портирование пользовательского интерфейса -- самая сложная часть, но в большом проекте эта часть не может быть самой главной.
 
---
у меня вопросик по стандартному TBits: нужен Enumerator элементов для него, либо контейнер с подобным функционалом..

Всего записей: 792 | Зарегистр. 24-04-2008 | Отправлено: 17:15 26-03-2015
NeoAnomaly

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

Цитата:
у меня вопросик по стандартному TBits: нужен Enumerator элементов для него, либо контейнер с подобным функционалом..

AlekXL, а, если не секрет, зачем тебе энумератор? Там ведь и перечислять нечего

Всего записей: 418 | Зарегистр. 23-03-2010 | Отправлено: 18:07 26-03-2015 | Исправлено: NeoAnomaly, 18:10 26-03-2015
AlekXL



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

Цитата:
AlekXL, а, если не секрет, зачем тебе энумератор? Там ведь и перечислять нечего  

догадайся, любопытный.
 
Добавлено:
короче, я вернулся пока к обычному множеству, и накропал код перечислителя элементов сета Подробнее...

Всего записей: 792 | Зарегистр. 24-04-2008 | Отправлено: 18:47 26-03-2015 | Исправлено: AlekXL, 12:44 27-03-2015
NeoAnomaly

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

Цитата:
догадайся, любопытный.  

AlekXL зачем спрашивал тогда? А после приведённого тобой кода - тем более. Либо это, ох**ть как далеко, не мой уровень, либо нафига такие трудности?

Всего записей: 418 | Зарегистр. 23-03-2010 | Отправлено: 22:20 26-03-2015 | Исправлено: NeoAnomaly, 22:52 26-03-2015
Eternal_Shield

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

Цитата:
и накропал код перечислителя элементов сета Подробнее...

Эээ, в каком месте в этом коде есть хоть какое-то перечисление?
 
Вот это:
bs:=[199];  
bt:=NextElementFrom(bs,200);  
Какой должен быть результат? Не понять.
 
 

Всего записей: 766 | Зарегистр. 18-05-2009 | Отправлено: 23:23 26-03-2015 | Исправлено: Eternal_Shield, 23:24 26-03-2015
nyinick



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

Цитата:
у тебя хрустальный шар? Если библиотека использует CreateFile,ReadFile Windows функции, то трудно ли портировать ее под линукс(андроид)?

Ну давай возьмём во внимание что dll-ки в проекте скорее всего close-source (Были бы исходники тогда вообще от dll можно избавиться и это не было бы проблемой). А если либа без сыра то мне интересно посмотреть как банальные используемые CreateFile,ReadFile в закрытой либо ты будешь эмулировать под Android ) полноценный wine под андроидом ещё не скоро изобретут.

Всего записей: 251 | Зарегистр. 26-06-2006 | Отправлено: 23:38 26-03-2015
AlekXL



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

Цитата:
AlekXL зачем спрашивал тогда?

право же, не от всех стоит ждать ответа.
 
Eternal_Shield

Цитата:
Вот это:
bs:=[199];  
bt:=NextElementFrom(bs,200);  
Какой должен быть результат? Не понять

-1.
я немного исправил код в сообщении выше.
 
nyinick

Цитата:
Ну давай возьмём во внимание что dll-ки в проекте скорее всего close-source (Были бы исходники тогда вообще от dll можно избавиться и это не было бы проблемой).

не обязательно . Много хороших либ под LGPL: 7za , Seman, и туча других...  
И не всегда нужно исбавляться. Иногда нужно -- расшарить.
 
 Delphi профессионал вообще станет использовать нестандартные либы без исходников с великой неохотой.
 
 

Цитата:
А если либа без сыра то мне интересно посмотреть как банальные используемые CreateFile,ReadFile в закрытой либо ты будешь эмулировать под Android  

если либа "без сыра", и у нее уникальный функционал, то вопрос о портировании не ставился бы скорей всего.
 

Цитата:
полноценный wine под андроидом ещё не скоро изобретут.
изобретут. Да и не нужен полноценный.

Всего записей: 792 | Зарегистр. 24-04-2008 | Отправлено: 00:00 27-03-2015 | Исправлено: AlekXL, 00:00 27-03-2015
Открыть новую тему     Написать ответ в эту тему

Страницы: 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 323

Компьютерный форум Ru.Board » Компьютеры » Прикладное программирование » Embarcadero RAD Studio


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

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

BitCoin: 1NGG1chHtUvrtEqjeerQCKDMUi6S6CG4iC

Рейтинг.ru