- 01
- 02
- 03
- 04
- 05
- 06
- 07
- 08
- 09
- 10
this.startAdLoading = function(callback) {
this.adCallback = callback;
Array.prototype.remove = function(from, to) {
var rest = this.slice((to || from) + 1 || this.length);
this.length = from < 0 ? this.length + from : from;
return this.push.apply(this, rest);
};
...
}
wvxvw 12.08.2013 17:08 # +1
Ох, слона то я и не заметил. Это использование вышеприведенного метода.
Lowezar 12.08.2013 19:52 # 0
wvxvw 12.08.2013 20:07 # +2
загрузи рекламу и получи бонус-функцию в прототипе массива!
Прям как в лоттерее.
> что по мнению автора
Ну там как бы как раз единственное место, где нормально.
а || б => а если а == ложь иначе б. Т.е. если параметр to не передали, то использовать from.
Но такие выкрутасы явно не соответствуют уровню окружающего кода, предполагаю, что автор не смог правильно сформулировать запрос к гуглу и выловил какой-то результат, который сам не понял, а использовал, как получилось.
wvxvw 12.08.2013 20:23 # +1
О, нашел источник вдохновения. Надо сказать, что на стопке-переборе варианты тоже не ахти, там предлагают восновном в цикле splice() вызывать.
Lowezar 12.08.2013 23:57 # 0
Так и тянутся руки пропущенный пробел вставить:)
А как ещё? Я бы в зависимости от ожидаемого размера массива и количества вырезанных элементов тоже либо сплайсом резал бы по 1, либо делал отдельный массив из того, что должно остаться. Разве что цикл был бы один.
wvxvw 12.08.2013 23:59 # 0
Lowezar 13.08.2013 00:34 # 0
Ещё вариант придумывается с Array.filter(), но тут точно хреновая идея из-за колбэка на каждый элемент. А что ещё?
wvxvw 13.08.2013 01:58 # 0
Да простит меня Тарас, ссылку не нашел.
Lowezar 13.08.2013 09:40 # 0
Второй ещё надо проверить (лень сейчас :) ) будет ли он реально быстрее сплайса - обычно скриптовая реализация проигрывает нативным функциям, даже при чуть меньшей сложности.
wvxvw 13.08.2013 12:15 # 0
В случае выше память выделяется гарантировано всего один раз.
Lowezar 13.08.2013 14:27 # 0
сплайсом 1 мс + 408 Кб
копированием элементов справа (вашу реализацию взял) 45 мс + 3,6 Мб.
3.14159265 13.08.2013 14:28 # 0
wvxvw 13.08.2013 14:30 # 0
wvxvw 13.08.2013 14:46 # +1
Мда... ну это только говорит о том, насколько сам по себе ж.скрипт херово реализован, т.как более правильный алгоритм не может работать достаточно хорошо по сравнению с говноалгоритмом только потому, что говноалгоритм использует вызовы штатных функций...
3.14159265 13.08.2013 15:21 # +1
Вот потому и живут аномальные на первый взгляд вещи, типа тримов регулярками.
anonimb84a2f6fd141 13.08.2013 17:04 # 0
wvxvw 13.08.2013 17:29 # 0
Ну вот кому нафиг нужен ~? Я просто ни разу не видел случая требовавшего применения. В то же время в практически любой программе на ж.скрипте нужно делать замены в строках. Почему бы не использовать что-то типа "строка" ~ /регулярка/? Было бы в 100 раз удобнее. Ксор? - тоже офигенно полезная функция, да и вообще, все они, особенно в виду того, что все числа - флоаты...
roman-kashitsyn 13.08.2013 17:33 # +1
wvxvw 13.08.2013 18:03 # 0
Все ту же криптографию можно сделать и обычной математикой, а особенно принимая во внимание тормозную сущность ж.скрипта / отстутсвие типов данных необходимых для криптографии - от того, что есть эти функции, что нету их - ничего не зависит.
bormand 13.08.2013 18:35 # +3
Ага, нук запилите мне xor или not обычной математикой. Только чур без цикла. А то оно и так то лагает как говно, а побитовым циклом будет лагать минимум в 60 раз больше ;)
wvxvw 13.08.2013 19:04 # 0
1. Никому не нужно.
2. Даже если нужно, то не из чего.
3. Даже если делать из того, что есть, то циклы в ксоре - будет самой меньшей проблемой. Всю длинную математику нужно будет далать на строках, от того, что там цикл в ксоре будет вообще ничего не изменится.
anonimb84a2f6fd141 13.08.2013 18:41 # 0
Для криптографии "типы данных" важны только там, где нужен определенный размер регистра - это или циклический сдвиг, или сложение с переполнением (реализуется через один if).
wvxvw 13.08.2013 19:05 # 0
bormand 13.08.2013 19:10 # +1
Нету, но тем не менее 32 бита целой части они вполне обеспечивают. Иначе вся эта порнокриптография тупо не работала бы.
3.14159265 13.08.2013 19:16 # +1
И по 4 бита применяем к 64-разрядному. Ах забыл, без циклов? Тогда анроллинг.
bormand 13.08.2013 19:20 # 0
Эндов, оров и сдвигов то тоже нет в драфте жабоскрипта от wvxvw ;) Разбивать делением, клеить умножением? :)
3.14159265 13.08.2013 19:21 # 0
Бля ;) Но массивы же есть?
Вот будем складывать в импровизированную шестнадцатеричную систему.
Короче что и требовалось доказать - полная жопа, когда нет битовых операций...
bormand 13.08.2013 19:23 # +1
Есть. Короче тогда хранить переменные в строках в хекс виде. А массивы для операций описывать примерно так:
3.14159265 13.08.2013 19:25 # 0
Хотя вот с аппендом строк сомнительно. Может так
xor_table = {
'0':{ '0':'0', .... 'F':'F'}
...
'F':{ '0':'F',....'F':'0'}
};
bormand 13.08.2013 19:27 # 0
Вполне.
anonimb84a2f6fd141 13.08.2013 19:24 # 0
Что вы несете-то?
http://crypto-js.googlecode.com/svn/branches/4.x/src/sha1.js
bormand 13.08.2013 19:25 # +2
Это не мы несем. Это wvxvw несет вот тут:
http://govnokod.ru/13597#comment191527
И вот тут: "все ту же криптографию можно сделать и обычной математикой".
wvxvw 13.08.2013 19:37 # 0
bormand 13.08.2013 20:17 # 0
Ну это я понял. И счел эту фразу призывающей к их удалению ;)
anonimb84a2f6fd141 13.08.2013 19:11 # 0
bormand 13.08.2013 19:11 # 0
64 наверное все-таки. В 32 битный флоат 32 битное целое не влезет.
Lure Of Chaos 14.08.2013 12:38 # 0
bormand 14.08.2013 18:24 # 0
От MITM'а хватило бы банального HTTPS. А шифрование на клиенте как бы убирает излишнее доверие к серверу - никто кроме отправителя и получателя не знает, что именно было в сообщениях, даже сервер, через которых их передали.
Но мы то знаем, что сервер может подсунуть кривой жабаскрипт, который сольет сообщение куда надо ;)
Lure Of Chaos 14.08.2013 18:41 # 0
исходники же все равно доступны, пусть даже если обфусцированы
bormand 14.08.2013 18:46 # +1
Т.е. я каждый раз, перед тем как туда что-то ввести должен перечитывать исходники? :)
Одно дело, когда я собрал на своей машине клиента из исходников. В этом случае я уверен, что в нем ничего не поменяется (если, конечно, мою машину не поимели), и могу спокойно юзать его до следующего обновления.
Совсем другое дело, когда исходник берется с сервера и этот сервер может в любой момент подсунуть мне новую версию...
P.S. Паранойя она такая ;)
3.14159265 15.08.2013 13:24 # +3
Это кстати очень большая проблема (Столлман и об этом предупреждал). Потому ненавижу автообновляющийся софт.
Видится такой радикальный выход - ты апррувишь скрипт, и браузер юзает копию из кеша как 304.
Как только видишь что сайт предлагает обновить - оно лочит и показывает дифф. Хотя и такой подход - не панацея. Всё-равно заебешься читать мегабайты обфусцированного js.
Тут проблема что js может натворить много делов, но он привязан к серверной стороне (там поменяли что-то, надо обновить скрипт), которую мы не можем контролировать.
bormand 15.08.2013 19:13 # 0
Проще уж тогда делать шифровалки расширением браузера. Его можно прочитать перед установкой или вообще не обновлять, если не хочется... Хотя с политикой фаерфокса я задолбаюсь править номера версий каждый месяц.
P.S. Может быть есть уже какой-нибудь PGPFox?
Vindicar 16.08.2013 20:03 # 0
eth0 14.08.2013 19:06 # 0
Это если сертификаты правильно настроены, не самодельные и ещё какие-то оговорки.
bormand 14.08.2013 19:13 # 0
Ну да. Но без HTTPS все это "шифрование в браузере" никакого смысла не имеет. Активным MITM'ом присунут переделанный скрипт да и все. А во всяких халявных вайфаях и интернет-кафе активный MITM устроить совсем несложно.
P.S. Кстати самодельные и самоподписанные тоже можно юзать, с оговорками. Только придется один разок по побочному каналу сверить отпечатки. Например по телефону позвонить владельцу сервера.
bormand 14.08.2013 19:40 # 0
0) Шифрование на сервере без HTTPS. Любой пассивный наблюдатель на канале видит сообщения. Админ сервера втихомолку сливает всю переписку PRISM'е.
1) Шифрование на сервере с HTTPS. Пассивные наблюдатели в обломе, админ продолжает читать переписку. Активный MITM может попытаться подсунуть свой сертификат.
2) Веб-шифровалка без HTTPS. Активный MITM или админ сервера (если он рисковый парень, или его кто-то прижал к стенке) могут присунуть свой скрипт. Пассивные наблюдатели в обломе.
3) Веб-шифровалка с HTTPS. Аналогично предыдущему, но активный MITM не может подсунуть скрипт, не подсунув свой сертификат.
4) "Толстый" клиент не имеющий ничего общего с браузером, аля PGP. Подвержен только терморектальному криптоанализу ;)
P.S. Здесь не рассматривается способ получения публичного ключа получателя. Это совсем другая история ;) Машины отправителя и получателя считаются не скомпрометированными.
P.P.S. Все что я хотел этим сказать - то, что юзать вебсервис для передачи конфиденциальной инфы можно только в случае необъяснимого доверия и любви к админу сервиса ;) Чего истинный параноик, которому действительно нужно передавать конфиденциальную инфу, себе никогда не позволит. И то, что веб-криптовалки без HTTPS это всего лишь иллюзия безопасности.
anonimb84a2f6fd141 14.08.2013 21:47 # +2
Это именно так, т.к. каждый раз не полезешь проверять, что за js на самом деле выполняется в браузере. Поэтому, идея js crypto, по большому счету - хуйня.
eth0 15.08.2013 21:14 # 0
В моей практике был случай по поводу локального говнофорума. На вбуллетине клиентский код делал md5 от пароля, пароль "жертвы" был хитрый, просто так не сбрутфорсить. В итоге было предложено соломоново решение - по идшнику пользователя форум отдавал модифицированную версию скрипта, который не делал ничего.
В тираж не пошло, поскольку нашёлся другой путь. Никто бы и не заметил подмены.
bormand 15.08.2013 21:46 # +1
Ну да, в том то и суть, что скрипт может быть изменен очень хитрым образом, который в случае обнаружения можно списать на банальную ошибку/опечатку.
Например, если не хочется палиться, можно немного попортить генератор простых чисел. Скажем, чтобы он вместо 2^256 вариантов выдавал всего 2^32. На глаз это заметить практически невозможно, а ключи, сгенеренные таким алгоритмом подбираются за считанные часы вместо дохреналионов лет ;)
anonimb84a2f6fd141 13.08.2013 20:08 # 0
bormand 13.08.2013 20:16 # +2
Емнип, всего лишь потому, что тогда java было модным словом, и авторы решили поюзать его в названии своего скрипта ;)
anonimb84a2f6fd141 13.08.2013 20:47 # 0
Lure Of Chaos 14.08.2013 12:42 # 0
вначале он был LiveScript
wvxvw 13.08.2013 21:15 # 0
Копировали тупо с Си, там где действительно много работы с памятью / эти операции часто бывают нужны. В языках, которые предназначены для прикалачивания кнопок к формам делать специальные короткие имена со специальным синтаксисом для таких операций - просто бред.
anonimb84a2f6fd141 13.08.2013 21:40 # +1
Почему никто не вспомнит классику - почему в яве == для обьектов сравнивает ссылки (операция в подавляющем большинстве случаев нахуй не нужная), а равенство обьектов вызывается по .equals()? Почему бы не сделать наоборот, как в питоне?
bormand 13.08.2013 21:46 # +1
Синтаксический сахар, транслирующий a == b в a.equals(b)?
Х.з. на самом деле, надо авторов жабы спросить :) Скорее всего не стали делать по той же причине, по которой не перегружаются операторы - предсказуемость их работы. В яве всегда понятно, как работает каждый оператор. и программист на это никак не может повлиять. А тут == бы работало по-разному в зависимости от типов.
anonimb84a2f6fd141 13.08.2013 21:50 # 0
bormand 13.08.2013 21:57 # 0
3.14159265 14.08.2013 19:28 # 0
Да там вообще всё говёно и перегруженное сравнение не спасет. Я уже где-то писал про длинный пост, про ==,=== и eq. И судя по тому как сделан equals, == мог бы стать NPE-опасным.
anonimb84a2f6fd141 15.08.2013 21:17 # 0
MAPTOBCKuu_nemyx 26.04.2024 20:26 # 0
wvxvw 13.08.2013 21:49 # 0
bormand 13.08.2013 21:55 # 0
Слово throws такое длинное? :) Имхо там список исключений занимает намноооого больше, чем это throws.
Причем даже мне, как крестовику со стажем, extends и implements нравятся больше, чем сишное двоеточие перед предками класса.
> чтобы не писать паблик / приват
Ну оно только в описании членов мешает. А метод он и без того длинный, чтобы public/private занимали пренебрежимо малую его часть.
> как оно используется в Смолтоке
return что-ли?
wvxvw 13.08.2013 22:06 # 0
>return что-ли?
Ну, практически, там это обозначает возвращаемое значение.
bormand 13.08.2013 22:23 # +1
Ага. Давайте заменим if на =>, while на |<= и получим очередной аналог J, в котором черт ногу сломит :)
Наэкономится на этом, на самом деле, не так и много. Ну вот сколько у вас в функции return'ов, даже если вы не сектант-одноретурнопоклонник? А implements и extends вообще 1 раз на класс. static'ов в кошерном коде не так много, чтобы задумываться об этом коротком слове.
public, private и т.п. да, еще имело бы смысл. Например паблик +, приват -.
wvxvw 13.08.2013 22:32 # 0
Получится J? А чем плохо? У него вполне логичный и простой синтаксис. Простой в смысле количества синтаксических правил / возможностей интерпретации одной и той же фразы. Я более чем уверен, что если взять непредвзятых подопытных недопрограммистов, и дать одному выучить J, а другому, например, C, то уровень понимания языка приобретенный за одно и то же время у первого будет гораздо выше.
bormand 13.08.2013 22:48 # +1
Естественно пабликов. Но сколько процентов кода занимают эти паблики? Мне кажется, что не более 5, если конечно код - не тупой враппер или сгенеренный эклипсом класс с пачкой полей и геттерами-сеттерами для них. Замерять лень.
Но, имхо, словоблудие в яве лечить надо совсем не заменой слов на мусор. А все-таки чем-то более высокоуровневым, и позволяющим писать меньше слов. Чтобы никому даже в голову не приходило экономить нажатия клавиш, меняя их на всякую херню ;)
> например, C
А что в синтаксисе си такого сложного? Ну кроме долбанутого описания указателей на функции, и незнания приоритетов, которое вполне парируется скобками. Все подводные камни си и крестов они дальше, на уровне семантики.
wvxvw 14.08.2013 02:37 # 0
И на момент знакомства у знакомящихся было больше багажа знаний, которые лучше подходили под более сложную грамматику. Так и получилось, что изначально использовать ее было легче.
Ну и тут можно двояко оценить ситуацию: можно подходить с позиций, что а если не пытаться улучшить, или развить, то более эффективным решением будет задействовать имеющиеся знания / предыдущий опыт. Но если развивать, то более сложная грамматика - это плохая база, потому что сложности в ней не обладают большей выразительностью.
Есть много куда более выразительных и одновременно простых языков, но тем не менее в силу привычки изучающим тяжело их освоить не потому что они объективно тяжелые, а потому, что для того, чтобы добиться этой самой выразительности или универсальности авторам нужно было пожертвовать традициями.
bormand 13.08.2013 22:55 # +1
Другой вопрос - пригодится ли ему потом это понимание J где-нибудь, если он не математик...
3.14159265 14.08.2013 19:18 # 0
А по мне наоборот вот много где крестосимволы неочевидны, а двоеточие при наследовании как раз няшное.
Но раздражает, сцуко, другое - непоследовательность. Ну если так любите всё делать словами - так сделайте уж, And, Xor и Or. Там 10 символов не жалко, а тут 2 зажали.
bormand 14.08.2013 19:24 # 0
Кстати в крестах они есть и словами ;)
3.14159265 13.08.2013 18:11 # 0
Там всё: и нативное, и самописное, работает одинаково тормознуто?
anonimb84a2f6fd141 13.08.2013 18:39 # 0
Нативное работает быстро, а нативного достаточно (криптография, распаковка gzip, парсеры xml, json). В lua, если с этим придется столкнуться, проще повеситься, т.к. бинарные операции на динамических языках медленнее на порядки. Вот в wireshakr поддержки питона под виндой какого-то хуя нету, есть только lua, в котором даже oop через жопу.
3.14159265 13.08.2013 18:41 # 0
Имелось ввиду библиотечное.
А если совсем уж нативное, то бишь сишное, то как тогда с портируемостью?
anonimb84a2f6fd141 13.08.2013 18:43 # 0
3.14159265 13.08.2013 18:56 # 0
Из коробки, но не в песочнице.
Lua (да и практически любой другой язык) умеет вызывать нативный код. В итоге сравниваем языки, а нативные реализации.
Вот в жабе нативного мало, gzip, парсеры итп - написаны на самом языке. И в итоге они сольют питонским. Это не мешает подключить мне JNI.
anonimb84a2f6fd141 13.08.2013 19:12 # 0
3.14159265 13.08.2013 19:18 # 0
Тут противоречие. Если zlib есть под данную платформу, то lua тоже может его использовать (не из коробки).
Если же нет, то и питону оно не светит.
Вот в чем загвоздка.
Тут вопрос даже не распространенности, а принципа. Я не говорю что это плохо, но сишные ноги торчат.
anonimb84a2f6fd141 13.08.2013 20:05 # 0
Да и само по себе, там, где у меня в питоне есть os.path или urlparse, в lua будут пользоваться регекспами, которые читаются, как говно.
Сишные ноги торчат у всех динамических языков, т.е. это уже срач статика vs динамика будет :)
Мне лично эти ноги очень мешают. Зная яву, я могу понять почти 100% программ на яве. Зная питон, мне рано или поздно придется или учить сишку, или зависеть от сишников, а в опенсорсе нет ничего хуже, чем зависеть от человека, который тебе ничего не должен.
Плюс ограничения для сишных модулей (нельзя указать, что обьект имплементирует, скажем, list - в питоне это можно сделать только через наследование, интефейсов как таковых нету, ололо, а сишные модули ничего наследовать не могут).
3.14159265 14.08.2013 19:23 # +1
Вот у меня иногда такое ощущение что под этим акком пишут два разных питониста.
Один - адекватный любитель опенсорса, другой - агрессивный вендошколяр твердящий про секту Штульмана.
anonimb84a2f6fd141 14.08.2013 21:59 # 0
И да, Штульман - красноглазый ебанат с мозолетоксикозом. Вся вендовраждебная хуйня идет от него, трухвальц сравнительно адекватен. И в этом отношении прыщеблядки сами виноваты, пропагандируя вендекапец. Зарекомендовали себя как ебанаты? Теперь не плачьте.
Может, это два разных опенсорса - один допиленный до юзабельного уровня, второй - ебаный пиздец? :)
3.14159265 15.08.2013 13:09 # 0
Потому
>Я и не говорю что это плохо
ибо тут спорно. Практическая (должно работать быстро) часть видимо взяла гору над религиозной (всё на питоне).
>Вся вендовраждебная хуйня идет от него
Будто это что-то плохое.
Да и всегда оказывается что он был прав, поскольку основывается на логике. Просто в России с тем фактом что винду никто не покупает разница - невелика. А насчет утечек личных данных большинству похер. Сноуден, сноуден - это и так все знали. Посрались и успокоились - никто ж свои акки на фейсбуках с гуглами не стал тереть. И айфоны никто не выбрасывает. А между тем Столлман давно говорил за это.
Торвальдс вот проебал тивоизацию с GPL 2.
roman-kashitsyn 15.08.2013 13:14 # +3
anonimb84a2f6fd141 15.08.2013 18:39 # 0
Все так ссут кипятком от швабодного, типа оно априори лучше нешвабодного, на самом деле разница есть если a) ты достаточно квалифицирован в этой области, б) если для изменения есть достаточный интерес (скажем, за это денег заплатят, а не просто "надоело, что эта функция делает не то, что мне хотелось бы"). В остальном случае ты обычный пользователь, и не надо себе льстить. Просто так ввязываться в это болото, наслушавшись, пропаганды, что "изменить код может каждый" - это как добровольно пойти в армию на 2 года по той же причине :)
roman-kashitsyn 15.08.2013 18:47 # +1
Опыт общения с опенсорсными проектами (и коммитов патчей в них) тоже есть, все люди, которые попадались, крайне адекватны и дружелюбны. Порог вхождения часто велИк, но меня это как-то мало волновало. Challenge же и возможность повысить свой уровень.
Ну а сишку знать нужно любому уважающему себя программисту. Не так уж она и страшна, есть в ней что-то притягательное.
bormand 15.08.2013 18:51 # +1
У проприетарщиков аналогичный отказ от ответственности ты подписываешь соглашаясь с эулой ;) Ну хотя да, согласен, они реже портят API и т.п., чтобы не подмочить себе репутацию.
anonimb84a2f6fd141 15.08.2013 19:13 # +1
anonimb84a2f6fd141 15.08.2013 18:15 # 0
Это только, если питон используется как интерфейс управления каким-то сишным модулем и больше ничего на нем не делают.
>Практическая (должно работать быстро) часть видимо взяла гору над религиозной (всё на питоне).
Лол, ты наверно питон никогда не видел. Работа с двоичными данными на чистом питоне (парсеры, битовые операции), если не найдется сишной функции, сразу просаживает скорость в разы. Так что альтернативы какбэ не было. PyPy не запускал.
То есть это здорово разбавляет радость от питона. Может быть, меня обманули, когда учили питону и не учили C. А может быть, надо заниматься тем, где сишные потроха знать не надо, скажем, веб девелопментом, и не ебать себе мозги?
WGH 16.08.2013 14:03 # 0
Ещё Cython попробуй.
anonimb84a2f6fd141 16.08.2013 17:09 # 0
bormand 16.08.2013 17:19 # 0
Ну это ведь уже не так страшно, как написание кода на самом си? :) Правда питон в цитоне насколько помню сильно уж кастрированный.
anonimb84a2f6fd141 16.08.2013 20:05 # 0
anonimb84a2f6fd141 15.08.2013 18:15 # 0
Логика "js может за мной следить - давай-ка я от него откажусь" уёбашна. Это как лечить насморк отрубанием головы - чтобы предложить, много ума не надо, и ясно, что никто этим пользоваться не будет.
>Сноуден, сноуден - это и так все знали.
Дай бог, людей будет проще уговорить пользоваться какой-нибудь криптоприблудой. А может, и писечку Серёженьки когда-нибудь из анусов повыдергивают, когда человек получает смартфон, шлющий неизвестно что неизвестно куда.
А насчет Сноудена, проблема просто в том, что вся мощь IT-шного мира сосредоточена в одной стране, ведущей войны, которая таки может заставить секретным соглашением дать возможность в реальном времени видеть все поведение пациента в сети. Сама идея - когда одна страна де-факто контролирует интернет - порочна, какой бы эта страна не была. Может, люди осознают это и начнут выбирать менее удобные / популярные, но более приватные аналоги. Так что Сноуден пришелся вполне кстати. Разбирающиеся люди-то знали и раньше, просто убедить большинство у них возможностей не было, сейчас шансов стало больше.
bormand 15.08.2013 19:07 # 0
Стоит различать скрытие инфы от правительств и спецслужб, и скрытие инфы от хакера Васи. Скрывать инфу от Васи полезно каждому человеку, чтобы не оказаться в неприятной ситуации. Скрывать инфу от служб стоит только если ты занимаешься чем-то незаконным, или представляешь для них какую-то угрозу. В противном случае ты им просто нахуй не нужен, как Неуловимый Джо.
Поэтому Сноуден - плохой пример. На его опыте ты большинство не убедишь. А тех, кого можно в чем-то убедить на примере Сноудена убедждать ни в чем не надо, они сами прекрасно понимают ситуацию ;)
Чтобы влиять на большинство нужен человек, похожий на них. И ситуация, более-менее напоминающая их поведение в сети. Например какая-нибудь Маша из Нижнего Тагила, которая выложила во вконтакте свой телефон, и этим воспользовались злоумышленники, сняв деньги с ее банковского счета.
wvxvw 15.08.2013 19:18 # +1
bormand 15.08.2013 19:27 # 0
Что это тотальное скрытие инфы даст обычному человеку кроме неудобств? Представьте, что я представитель того самого большинства и объясните мне ;)
Вот если некий малолетний долбоеб узнает мой телефон - он будет мне названивать с угрозами и т.п.. Эта проблема понятна обывателю, поэтому он скорее всего постарается телефон куда попало не светить.
А если спецлужбы видят мой телефон, скрытый в профиле в контакте, то для чего они им воспользуются, если я обычный законопослушный гражданин? А что сделает разведка СШП с моими сообщениями на фейсбуке? :) Да им просто нет смысла их читать.
Поэтому большинству людей на эту ситуацию с "прослушкой" (особенно американской) насрать с высокой башни ;)
anonimb84a2f6fd141 15.08.2013 21:13 # 0
wvxvw 15.08.2013 19:28 # 0
bormand 15.08.2013 19:30 # 0
А стал бы он, если бы я был тотальным анонимусом, и никогда никуда этой инфой не светил? :) Как раз это навело бы еще больше подозрений.
P.S. Какую инфу я могу выдать сотруднику спецслужб, да такую, что она ему пригодилась в суде? Приведите пример, пожалуйста.
bormand 15.08.2013 19:39 # 0
Вернее так. Какую инфу я могу случайно раскрыть на тех же одноклазниках\втентакле, чтобы она оказалась полезной сотрудникам спецслужб, и чтобы у меня был повод оспаривать каналы получения этой инфы в суде, если бы я ее никуда не выкладывал.
"Сегодня я ебал пони".
"Сегодня взорвали магазин, было весело! Фото во вложении".
"Пойдем свергнем Пу?"
Что-то в таком духе? :)
wvxvw 15.08.2013 20:36 # +1
Суд обязан вас защищать, если он разрешил разгласить вашу информацию. Например, по ошибке / не обдуманно нанеся вам вред. Если это сделает кто угодно, без разрешения суда, то никто никто вас защащать легально не будет обязан, только если по доброй воле.
wvxvw 15.08.2013 20:55 # 0
bormand 15.08.2013 21:57 # 0
С каких пор хрень написанная на сайтах считается показаниями? Для дачи показаний существуют вполне определенные процедуры, подразумевающие ответственность за ложь.
wvxvw 15.08.2013 22:05 # 0
bormand 15.08.2013 22:08 # 0
Если уж они там настолько спелись, то им и этой записи во вконтакте не надо. И без нее найдут повод посадить Васю (или кого-то еще, кто подвернется под руку).
P.S. Ну и вообще, за такие слова в паблике меня этот самый Вася мог засудить за клевету. Поэтому я бы так писать не стал. Т.е. подразумевается, что эта фраза проскочила в приватной беседе с кем-то?
wvxvw 15.08.2013 23:30 # 0
LispGovno 16.08.2013 07:08 # 0
bormand 15.08.2013 22:17 # 0
Но проблема то здесь таится совсем не в том, что некий мент сумел прочитать мою переписку о Васе. А в том, что сфабриковали обыск, подсунув нужные предметы. И имхо проще и дешевле найти другой повод для обыска, чем читать переписку всех Васиных друзей.
P.S. Разговор ушел немного в другую тему, но я всего лишь хочу сказать о том, что глупо думать, что народ будет задумываться о конфиденциальности глядя на пример Сноудена. Народу нужно показывать пример того самого Васи. Которого посадили из-за записи о нем в контакте. Такая новость действительно поднимет волну в народе. А Сноуден? А что Сноуден. Он с обывателем имеет мало общего, поговорят немного да забудут.
anonimb84a2f6fd141 15.08.2013 23:26 # 0
3.14159265 16.08.2013 14:08 # 0
Педофил Коновалов, подойдет?
eth0 15.08.2013 21:16 # 0
Порочная практика, не согласен категорически.
bormand 15.08.2013 22:03 # 0
Ну тут же смотря какая инфа. Я же не говорю сливать все подряд без разбора.
Я пытался выразить то, что для большинства людей разглашение инфы Васе-хакеру или Пете-школоло гораздо опаснее, чем всем эти спецслужбам вместе взятые.
Поэтому да, людям надо думать о конфиденциальности. Но в первую очередь не с точки зрения защиты от спецслужб (если они, конечно, не Сноуден с Навальным), а с точки зрения защиты от нехороших людей. Это для них на порядки актуальней.
P.S. Ну естественно, есть вероятность, что какой-нибудь Миша-мент окажется кем-то имеющим доступ к моей инфе, и поюзает ее в своих грязных целях ;)
LispGovno 13.08.2013 19:24 # 0
А зачем это сделано?
wvxvw 13.08.2013 19:36 # +1
Кроме того, это позволяет, например, сделать: array.length = 100500, и не потратить память при этом.
Но это делает их тормозными / традиционный подход для работы с массивмаи часто оказывается непригодным.
Вобщем, недальновидная попытка упростить жизнь, которая в последствии отрезала путь к развитию.
3.14159265 13.08.2013 19:39 # +1
Не надо из массивов на гигабайт удолять элементы. Не надо вообще выделять огромный непрерывный кусок памяти.
Надо развиваться в другую сторону - использовать структуры c меньшей алгоритмической сложностью, те же rope.
Практически во всех ЯВУ языках массивы оборачивают более высокими абстракциями.
LispGovno 14.08.2013 01:34 # 0
Ничего про их балансировку (Чтоб от log n не уходили к n) никогда не слышал.
bormand 13.08.2013 20:15 # +1
А потом, емнип, на этой хуйне не работают foreach и map :)
anonimb84a2f6fd141 13.08.2013 20:48 # 0
bormand 13.08.2013 20:59 # +1
Но в жс всегда все кверху жопой ;( И foreach неюзабелен чуть менее чем полностью. А ради обхода городят всякие костыли типа _.each() в underscore.
anonimb84a2f6fd141 13.08.2013 21:11 # 0
bormand 13.08.2013 21:24 # +1
В жабаскрипте - увы, foreach изначально ущербен. Он возвращает только ключи, а значения потом приходится выдирать из "массива" самому. В итоге алгоритмы обходящие "массив" хоть и остаются в теории O(n) (если верить, что там хорошая хешмапа, и считать что у нее O(1) на выборке), но константа-то растет... тормозят то они больше...
А трабла с обходом массива, емнип, заключается в том, что форич оббежит не только элементы массива, но и унаследованную херню из прототипа. Куда очень любят добавлять свои методы всякие либы.
И вот так куда не копни в жс - везде костыли и сомнительные ходы проектировщика. Хуже крестов, честное слово ;(
anonimb84a2f6fd141 15.08.2013 18:28 # 0
3.14159265 15.08.2013 16:03 # 0
'a' in {'a':1,'b':2,'c':3}
проверяет вхождение элемента в структуру
>>Хуже крестов, честное слово ;(
Ну уж нет. Он минималистичен. Там правил во всем языке меньше чем контрисключений из исключений из правил в крестах.
anonimb84a2f6fd141 15.08.2013 17:44 # 0
проверяет вхождение элемента в структуру
Эт че?
LispGovno 14.08.2013 01:33 # 0
А что там сделано? Создаются элементы за пределом, если вышло?
bormand 14.08.2013 07:25 # 0
3.14159265 13.08.2013 14:28 # +1
Да на ГК много чего не хватает. Как-то обходимся.
Lowezar 12.08.2013 23:50 # 0
Ну вопрос был больше про "что делает || ?" Я привык видеть на выхлопе этих операторов true/false (ну или 1/0, соответствующие константам TRUE/FALSE).
Насколько понял из вашей реакции, || - не совсем logic or. Он возвращает либо false, либо то, что посчитал не-false? Так понятнее.
...Собственно, чего я спрашиваю, консоль же под рукой. :) Поэкспериментировал - || и && возвращают то значение, которое последним "посмотрели". Удобно, наверное... Но как-то руки не поворачиваются такое писать. :) Может просто с непривычки, какая-то логика в этом есть...
bormand 13.08.2013 06:22 # +2
anonimb84a2f6fd141 13.08.2013 20:49 # 0
anonimb84a2f6fd141 13.08.2013 20:53 # +1