|
1 / 1 / 2
Регистрация: 18.12.2018
Сообщений: 149
|
|||||||||||
Что быстрее Цикл или коллекция17.04.2019, 08:56. Показов 2220. Ответов 24
Метки нет (Все метки)
Доброе утро!) Ребят подскажите, кто в курсе какой вариант алгоритма будет работать быстрее
Вариант с перебором 2-м циклом одной и тойже коллекции с проверкой внутри
0
|
|||||||||||
| 17.04.2019, 08:56 | |
|
Ответы с готовыми решениями:
24
Оптимизация кода, структуры базы, или что еще можно сделать что бы быстрее работало!?
Что быстрее - метод или свойство? |
|
Фрилансер
805 / 312 / 148
Регистрация: 13.02.2019
Сообщений: 1,071
|
||
| 17.04.2019, 09:50 | ||
|
Добавлено через 47 секунд PS. а for еще быстрее работает
1
|
||
|
1 / 1 / 2
Регистрация: 18.12.2018
Сообщений: 149
|
||||||
| 17.04.2019, 09:57 [ТС] | ||||||
|
asn31337, Оу ,спасибо. Я понимал что LINQ помедленнее, но чтоб настолько...... Это мне теперь что и конструкцию
0
|
||||||
|
171 / 106 / 51
Регистрация: 27.11.2015
Сообщений: 1,269
|
||||||
| 17.04.2019, 09:57 | ||||||
|
Stas9700, В большинстве случаев LINQ будет немного медленнее, потому что он вводит накладные расходы. Не используйте LINQ, если для вас важна производительность.LINQ используется для более удобного чтения и поддержки кода.
Вы всегда можете замерить производительность, воспользовавшись классом Stopwatch, но не забывайте, что важно на каком железе тестите, к примеру если у вас топ машина, но у пользователя эти данные могут сильно отличаться ввиду старой машины
1
|
||||||
|
1 / 1 / 2
Регистрация: 18.12.2018
Сообщений: 149
|
|
| 17.04.2019, 10:05 [ТС] | |
|
ShmelVG, У меня скорее не то чтобы потребность сделать все молниеносно, просто приложение работает с БД и файлами Excel. И когда я начал использовать доп. библиотеки, вместо подхода "написал запрос и результат циклом переписал в коллекцию", просто офигел от того насколько дольше все работает. То есть функция написанная руками выбирает 3к записей из базы (в каждой 28 столбцов) быстрее чем entity framework просто 3 записи (если это конечно первое подключение к БД). И вот из за таких моментов, я стараюсь в вещах где можно сделать без примочек, делать самомму чтоб общая скорость не так сильно падала)
0
|
|
|
Фрилансер
805 / 312 / 148
Регистрация: 13.02.2019
Сообщений: 1,071
|
||
| 17.04.2019, 10:06 | ||
|
0
|
||
|
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
|
|
| 17.04.2019, 10:06 | |
|
0
|
|
|
1 / 1 / 2
Регистрация: 18.12.2018
Сообщений: 149
|
|
| 17.04.2019, 10:07 [ТС] | |
|
kolorotur, А как тогда делать?
0
|
|
|
|
|
| 17.04.2019, 10:09 | |
|
причем тут Linq он незначительные расходы накладывает главное понимания как работает сама функция
в 1 варианте 2 цикла, а во 2 варианте 3 цикла 3 цикла будит дольше выполнятся чем 2 foreach и for не думаю что большая разница будит при одинаковых условиях
0
|
|
|
171 / 106 / 51
Регистрация: 27.11.2015
Сообщений: 1,269
|
|
| 17.04.2019, 10:10 | |
|
Stas9700, для большей производительности можете использовать ADO.NET вместо EF
0
|
|
|
Фрилансер
805 / 312 / 148
Регистрация: 13.02.2019
Сообщений: 1,071
|
||
| 17.04.2019, 10:12 | ||
|
0
|
||
|
1 / 1 / 2
Регистрация: 18.12.2018
Сообщений: 149
|
|
| 17.04.2019, 10:17 [ТС] | |
|
ShmelVG, ShmelVG, Согласен, на прошлом проекте его и юзал. Но разве ADO.NET не сложнее в реализации базовых операций и отслеживания изменений в элементах его коллекции типа DtSet, если я правильно помню?
0
|
|
|
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
|
|||||||
| 17.04.2019, 10:18 | |||||||
|
Например, через Join:
0
|
|||||||
|
171 / 106 / 51
Регистрация: 27.11.2015
Сообщений: 1,269
|
|
| 17.04.2019, 10:25 | |
|
Stas9700, EF - по большому счету удобство для программиста, хотя они его активно развивают) Всё зависит от самого приложения в целом, если у вас огромная БД и частые запросы, стоит подумать на счёт ado, конечно же в ущерб удобству)
0
|
|
|
Фрилансер
805 / 312 / 148
Регистрация: 13.02.2019
Сообщений: 1,071
|
|
| 17.04.2019, 10:28 | |
|
0
|
|
|
1 / 1 / 2
Регистрация: 18.12.2018
Сообщений: 149
|
|
| 17.04.2019, 10:28 [ТС] | |
|
asn31337, ну вот собственно я все чтение из файла в коллекцию закинул в отдельный поток и меня устраивает. насчет Oledb что то читал в связке с эксель, но маловато поэтому лучше пока не буду трогать))
0
|
|
|
Фрилансер
805 / 312 / 148
Регистрация: 13.02.2019
Сообщений: 1,071
|
||
| 17.04.2019, 10:30 | ||
|
0
|
||
|
1 / 1 / 2
Регистрация: 18.12.2018
Сообщений: 149
|
|
| 17.04.2019, 10:44 [ТС] | |
|
ShmelVG, БД пока нулевая ахахах, все делается с нуля. Теоретически записей будет много и одновременно как бы нет. Условно клиентов много, но каждый клиент занимать места в БД будет не прям так дофига. Да и сроки на разработки поджимают, поэтому важнее скорость разработки. Над скоростью работы меня больше собственные тараканы в голове заставляют париться)
Добавлено через 11 минут kolorotur, Так а вот тут хотелось бы по подробнее... Какой результат будет после объедения? что-то типа: Родитель | Ребенок 1 | 2 | 3 | 1 3 | 2 И дальше вы проходитесь по получившемуся набору и записываете ссылки друг на друга? Или как то я не так понял...
0
|
|
|
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
|
||
| 17.04.2019, 10:47 | ||
|
Вкратце: будут выбраны пары элементов, у которых совпадают значения ID и ParentID, а потом будет привязка главной записи к дочерней и дочерней к главной.
0
|
||
| 17.04.2019, 10:47 | |
|
Помогаю со студенческими работами здесь
20
Что быстрее умножение или деление? Поиск элемента в массиве или ключа в хеше - что быстрее Что будет быстрее и рентабельние использовать XML или Sqlite? Обращение через индекс Dictionary или IndexOf, что быстрее / производительнее? Что быстрее switch(enum) или if else? Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Настройки VS Code
Loafer 13.04.2026
{
"cmake. configureOnOpen": false,
"diffEditor. ignoreTrimWhitespace": true,
"editor. fontSize": 18,
"editor. guides. bracketPairs": "active",
"extensions. ignoreRecommendations":. . .
|
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2.
Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива.
Было так:. . .
|
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: реализовать контроль корректности заполнения дат назначения. . .
|
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html
Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
|
|
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
|
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях.
Задача: при копировании документа очищать определенные реквизиты и табличную. . .
|
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git
main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели
8ATzM_2aurI
|
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2.
Задача: запретить редактирование документа, если он открыт у другого пользователя.
/ / . . .
|