Аналоги Zona для windows
Обновлено: 21.11.2024
В этой записи блога я расскажу о следующих темах:
Знакомство с типами DateOnly и TimeOnly
Тип DateOnly
Тип DateOnly — это структура, предназначенная для представления только даты. Другими словами, всего год, месяц и день. Вот краткий пример:
DateOnly идеально подходит для таких сценариев, как даты рождения, годовщины, даты найма и другие деловые даты, которые обычно не связаны с каким-либо конкретным временем. Другой способ думать об этом состоит в том, что DateOnly представляет полную дату (от начала дня до конца дня), как это было бы визуализировано заданным квадратом печатного настенного календаря. До сих пор вы, возможно, использовали для этой цели DateTime, вероятно, со временем, установленным на полночь ( 00:00:00.0000000 ). Хотя это все еще работает, использование DateOnly дает несколько преимуществ. К ним относятся:
- DateOnly обеспечивает лучшую безопасность типов, чем DateTime, предназначенный только для представления даты. Это важно при использовании API, так как не каждое действие, имеющее смысл для даты и времени, также имеет смысл для всей даты. Например, метод TimeZoneInfo.ConvertTime можно использовать для преобразования DateTime из одного часового пояса в другой. Передача целой даты не имеет смысла, так как можно преобразовать только один момент времени в эту дату. С DateTime эти бессмысленные операции могут происходить и частично виноваты в ошибках, которые могут сместить чей-то день рождения на день позже или на день раньше. Поскольку ни один такой API преобразования часовых поясов не будет работать с DateOnly , случайное неправильное использование исключено.
- DateTime также содержит свойство Kind типа DateTimeKind , которое может быть Local , Utc или Unspecified . Тип влияет на поведение API-интерфейсов преобразования, а также на форматирование и синтаксический анализ строк. DateOnly не имеет такого типа — фактически он всегда Unspecified .
- При сериализации DateOnly необходимо указать только год, месяц и день. Это делает ваши данные более четкими, предотвращая добавление множества нулей в конец. Это также дает понять любому пользователю вашего API, что значение представляет целую дату, а не время в полночь этой даты.
- При взаимодействии с базой данных (такой как SQL Server и другие) целые даты почти всегда сохраняются в типе данных даты. До сих пор API для хранения и извлечения таких данных были сильно привязаны к типу DateTime. При хранении время будет усечено, что может привести к потере данных. При извлечении время будет установлено на нули и будет неотличимо от даты в полночь. Наличие типа DateOnly позволяет более точно сопоставить тип с типом даты базы данных. Учтите, что еще многое предстоит сделать, чтобы различные поставщики данных поддерживали этот новый тип, но, по крайней мере, теперь это возможно.
Тип TimeOnly
Мы также получаем новый тип TimeOnly, представляющий собой структуру, предназначенную для представления только времени суток. Если DateOnly — это половина DateTime, то TimeOnly — другая половина. Вот краткий пример:
TimeOnly идеально подходит для таких сценариев, как повторяющееся время встреч, ежедневное время будильника или время открытия и закрытия компании каждый день недели. Поскольку TimeOnly не связан с какой-либо конкретной датой, его лучше всего представить в виде круглых аналоговых часов, которые можно повесить на стену (хотя это и 24-часовые, а не 12-часовые часы). До сих пор существовало два распространенных способа представления таких значений: либо с использованием типа TimeSpan, либо с использованием типа DateTime. Хотя эти подходы все еще работают, использование TimeOnly дает несколько преимуществ, в том числе:
- TimeSpan в первую очередь предназначен для прошедшего времени, которое вы измеряете секундомером. Его верхний диапазон составляет более 29 000 лет, а его значения также могут быть отрицательными, что указывает на движение назад во времени. И наоборот, TimeOnly предназначен для значения времени суток, поэтому его диапазон составляет от 00:00:00.0000000 до 23:59:59.9999999 и всегда положителен. Когда TimeSpan используется в качестве времени суток, существует риск того, что им можно будет манипулировать так, что оно выйдет за пределы допустимого диапазона. С TimeOnly такого риска нет.
- Использование DateTime для значения времени суток требует назначения произвольной даты. Обычно выбирается дата DateTime.MinValue ( 0001-01-01 ), но это иногда приводит к исключениям вне диапазона во время манипуляции, если время вычитается. Выбор какой-либо другой произвольной даты по-прежнему требует помнить о том, чтобы позже игнорировать ее, что может быть проблемой во время сериализации.
- TimeOnly — это тип истинного времени суток, поэтому он обеспечивает более высокую безопасность типов для таких значений по сравнению с DateTime или TimeSpan , точно так же, как использование DateOnly обеспечивает лучшую безопасность типов для значений даты, чем DateTime . ли>
- Общая операция со значениями времени суток — добавление или вычитание некоторого периода прошедшего времени. В отличие от TimeSpan значение TimeOnly будет правильно обрабатывать такие операции при пересечении полуночи. Например, смена сотрудника может начинаться в 18:00 и длиться 8 часов, заканчиваясь в 02:00. TimeOnly позаботится об этом во время операции сложения, и у него также есть метод InBetween, который можно легко использовать, чтобы определить, находится ли какое-либо заданное время в пределах рабочей смены.
Почему они называются «Только»?
Называть вещи всегда сложно, и это не исключение. Было рассмотрено и подробно обсуждено несколько различных имен, но в конечном итоге мы остановились на DateOnly и TimeOnly, потому что они соответствовали нескольким различным ограничениям:
А как насчет Noda Time?
Кроме того, была предложена поддержка замены DateOnly и TimeOnly на их эквивалентные типы Noda Time ( LocalDate и LocalTime ).
API преобразования часовых поясов
Сначала немного предыстории и истории. Вообще говоря, в вычислениях используются два набора данных о часовых поясах:
- Набор часовых поясов, созданный Microsoft и поставляемый с Windows.
- Идентификатор примера: "Восточное стандартное время Австралии"
- Идентификатор примера: "Австралия/Сидней"
Под всеми я подразумеваю не только Linux и macOS, но также Java, Python, Perl, Ruby, Go, JavaScript и многие другие.
Краткий пример:
Кроме того, в этом выпуске мы добавили несколько новых методов в класс TimeZoneInfo с именами TryConvertIanaIdToWindowsId и TryConvertWindowsIdToIanaId для сценариев, когда вам все еще нужно вручную преобразовать одну форму часового пояса в другую.
Некоторые примеры использования:
Мы также добавили в TimeZoneInfo свойство экземпляра под названием HasIanaId , которое возвращает значение true, если свойство Id является идентификатором часового пояса IANA. Это должно помочь вам определить, необходимо ли преобразование, в зависимости от ваших потребностей. Например, возможно, вы используете объекты TimeZoneInfo, загруженные из сочетания идентификаторов Windows или IANA, а затем вам нужен идентификатор часового пояса IANA для некоторого внешнего вызова API. Вы можете определить вспомогательный метод следующим образом:
Или наоборот, возможно, вам нужен идентификатор часового пояса Windows. Например, для функции AT TIME ZONE SQL Server в настоящее время требуется идентификатор часового пояса Windows — даже при использовании SQL Server в Linux. Вы можете определить вспомогательный метод следующим образом:
Отображаемые названия часовых поясов в Linux и macOS
Еще одна распространенная операция с часовыми поясами — получение их списка, обычно для того, чтобы попросить конечного пользователя выбрать один из них. Метод TimeZoneInfo.GetSystemTimeZones всегда хорошо служил для этой цели в Windows. Он возвращает доступную только для чтения коллекцию объектов TimeZoneInfo, и такой список можно создать с помощью свойств Id и DisplayName каждого объекта.
В Windows .NET заполняет отображаемые имена, используя файлы ресурсов, связанные с текущим языком отображения ОС. В Linux и macOS вместо этого используются данные глобализации ICU. Обычно это нормально, за исключением того, что необходимо убедиться, что значение DisplayName однозначно по отношению ко всему списку значений, иначе такой список становится непригодным для использования. Например, было возвращено 13 разных часовых поясов с одинаковым отображаемым названием «(UTC-07:00) Горное стандартное время», что делает практически невозможным для пользователя выбор того, который ему принадлежал — и да, есть отличия! Например, Америка/Денвер представляет собой большую часть горного времени в США, но Америка/Феникс используется в Аризоне, где не соблюдается переход на летнее время.
В этом выпуске были добавлены внутренние дополнительные алгоритмы для выбора лучших значений из ICU для использования в отображаемых именах. Теперь списки стали более удобными. Например, Америка/Денвер теперь отображается как «(UTC-07:00) Горное время (Денвер)», а Америка/Феникс отображается как «(UTC-07:00) Горное время (Феникс)». Если вы хотите увидеть, как изменилась остальная часть списка, обратитесь к разделам «До» и «После» в запросе на вытягивание GitHub.
Обратите внимание, что на данный момент список часовых поясов и их отображаемых названий в Windows практически не изменился. Тем не менее, небольшое, но связанное с этим исправление заключается в том, что ранее отображаемое имя для часового пояса UTC было жестко запрограммировано на английское «Coordinated Universal Time», что было проблемой для других языков. Теперь оно соответствует тому же языку, что и остальные отображаемые имена часовых поясов во всех операционных системах.
Улучшения TimeZoneInfo.AdjustmentRule
Однако есть некоторые сложные сценарии, которые иногда требуют доступа ко всем необработанным данным, и скрытие одной части данных внутри не имеет особого смысла. Таким образом, в этом выпуске свойство BaseUtcOffsetDelta в классе TimeZoneInfo.AdjustmentRule стало общедоступным.Для полноты картины мы также предприняли дополнительный шаг и создали перегрузку метода CreateAdjustmentRule, который принимает параметр baseUtcOffsetDelta. Мы не ожидаем, что большинству разработчиков понадобится или захочется создавать собственные часовые пояса или правила корректировки.
Два других незначительных улучшения были внесены в порядок заполнения правил корректировки из данных IANA внутри операционных систем, отличных от Windows. Они не влияют на внешнее поведение, за исключением обеспечения корректности в некоторых крайних случаях.
Если все это звучит запутанно, не волнуйтесь, вы не одиноки. К счастью, вся логика для правильного использования данных уже включена в различные методы TimeZoneInfo, такие как GetUtcOffset и ConvertTime. Как правило, нет необходимости использовать правила корректировки.
Заключение
Не забудьте оставить свой отзыв об этих новых функциях ниже. Спасибо!
Благодаря 6 входам и 4 выходам dbx ZonePRO® 640 обеспечивает гибкую маршрутизацию сигналов, мощную обработку DSP и несколько интерфейсов управления для коммерческих аудиоприложений.
Разработанные для обеспечения превосходных звуковых характеристик и гибкости системы, модели 640/641 предоставляют инструменты высочайшего качества. Даже входные и выходные разъемы были выбраны из-за их стандартного использования и надежности. Продукты ZonePRO предлагают разъемы Euroblock для симметричных сигналов и разъемы RCA для взаимодействия с бытовым оборудованием, часто используемым в коммерческих приложениях; имеется также простая шина аналогового ввода, которая позволяет передавать входные данные от одного устройства к другому для масштабирования устройства и задания. Модели 640 и 641 оснащены всеми необходимыми инструментами обработки, от обработки входного сигнала, такой как регулировка усиления и эквалайзер, доступных на всех входах, до очень сложных и специфических функций, таких как выбираемая обработка пейджингового микрофона, включая гейтирование, деэссинг, автоматическую регулировку усиления, компрессию и подавление обратной связи. . Сердцем продуктов ZonePRO является модуль маршрутизации, который, конечно же, обеспечивает выбор основного источника, а также приглушение источника для пейджинга и переопределения приоритета. Выходы также предлагают широкий спектр обработки, предназначенной для коммерческих приложений, таких как наша запатентованная функция AutoWarmth®, которая была разработана совместно с JBL для обеспечения естественного расширения низких частот на любом уровне сигнала. Каждый выход также предлагает эквалайзер, полосовые и кроссоверные фильтры, лимитер и задержку для оптимизации системы. С ZonePRO® в вашем распоряжении все инструменты, чтобы максимизировать отклик вашей системы.
Помимо обработки, продукты ZonePRO® предлагают несколько форм управления для дальнейшего расширения универсальности вашей системы. От простых в использовании зональных контроллеров настенной панели для стандартных функций конечного пользователя, таких как выбор источника и регулировка громкости, до расширенного управления системой, включая встроенные часы реального времени, которые могут обеспечивать программируемые системные изменения в течение дня или недели. Для настройки и мониторинга системы программное обеспечение ZonePRO Designer предоставляет интуитивно понятный интерфейс и мастер быстрой настройки для настройки и редактирования всех параметров системы.
ZonePRO® 640 поднимет вашу коммерческую аудиосистему на новый уровень благодаря расширенной обработке, универсальности и управлению.
До Basecamp: проекты кажутся разбросанными, вещи скользят, трудно понять, как обстоят дела, и люди испытывают стресс. После Basecamp: все организовано в одном месте, вы в курсе дел, прогресс понятен, и наступает чувство спокойствия.
Только за последнюю неделю зарегистрировалось 4000 компаний!
Одно место, а не повсюду.
Удаленная работа особенно сложна, когда данные разбросаны по электронной почте, файловым службам, диспетчерам задач, электронным таблицам, чатам, собраниям и т. д. Вещи теряются, вы не знаете, где искать информацию, а люди размещают нужную информацию. не в том месте.
Но когда все это будет собрано в Basecamp, вы увидите, где все находится, поймете, над чем все работают, и точно будете знать, куда поместить следующую вещь, о которой все должны знать. Ваша команда может получить доступ к Basecamp из любого места — в Интернете, на iOS и Android. Это современный подход — способ работы Basecamp.
Мы буквально написали книгу об удаленной работе.
Мы не просто делаем программное обеспечение для удаленной работы; мы также написали популярную и влиятельную книгу об удаленной работе. REMOTE показывает как работодателям, так и сотрудникам, как они могут работать вместе, удаленно, с любого рабочего места, в любом месте, в любое время и в любом месте. Избегайте распространенных ошибок, изучайте передовой опыт и быстро приступайте к работе.
Компании меняются к лучшему, когда работают в Basecamp.
Компании по разработке программного обеспечения, дизайнерские фирмы, фрилансеры, консультанты, архитекторы, агентства, медиа-компании, школы и некоммерческие организации по всему миру перешли на Basecamp, чтобы коренным образом улучшить рабочий процесс своих проектов.
«Я использовал Basecamp для миллиона проектов за последние полтора десятилетия. Это прекрасное программное обеспечение, которое сопротивлялось всем неправильным тенденциям и оставалось верным вещам, которые имели наибольшее значение. Настоятельно рекомендуется».
— Тоби Лютке, генеральный директор Shopify«Мы точно видим, что и когда нужно сделать. Мы стали намного эффективнее».
– Тина Ланнин, 121 Captions«У нас меньше путаницы с обязанностями и сроками выполнения задач, что повысило производительность и эффективность».
— Дейл Лавин, НАСА"Мы все больше сотрудничаем с помощью отзывов, это также помогает проявить ответственность".
– Саманта Силберберг, Quartz«Теперь, когда мы используем Basecamp, нам не нужно проводить столько времени на собраниях».
— Брэд Вандивьер, Faith Chapel Billings«Прозрачность и общение повысились».
— Джоуи Розенберг, Women Who Code«Управление временем и продуктивность. Облегчает мою работу, избавляя от необходимости постоянно спрашивать о прогрессе».
– Кайл Джерниган, церковь Crossroads«Больше совместной работы и меньше Excel!»
— Спенсер Стивенсон, 3M«Задание выполнено! Списки и напоминания помогают людям помнить, что они собирались сделать, и помогают держать их подотчетными перед командой».
– Скотт Эванс, Университет МайамиЕсть вопросы? Холлер.
Готовы начать? Привлечь:Читайте также: