Почему некоторые отрицательные числа выводят странные символы с помощью пакета Fontenc?

Почему некоторые отрицательные числа выводят странные символы с помощью пакета Fontenc?

Этот

\documentclass[a4paper,10pt,openany]{scrbook}

\usepackage{minted}
\usepackage[T1]{fontenc} % comment-out this line to fix it

\newcommand{\ctype}[1]{\PYG{k+kt}{\texttt{#1}}}

\begin{document}

\begin{tabular}{|l|c|c|r|r|}
\hline
    Type & Bits & Bytes & Minimum & Maximum \\ \hline
    \ctype{int8\_t} & 8 & 1 & -128 & 127 \\ \hline
    \ctype{int16\_t} & 16 & 2 & -32,768 & 32,767 \\ \hline
    \ctype{int32\_t} & 32 & 4 & −2,147,483,648 & 2,147,483,647 \\ \hline
    \ctype{int64\_t} & 64 & 8 & −9,223,372,036,854,775,808 & 9,223,372,036,854,775,807 \\ \hline
\end{tabular}

\end{document}

производит это

введите описание изображения здесь

Я включаю, fontencчтобы исправить предупреждения «Шрифтовая форма * не определена», но это искажает некоторые отрицательные числа?

Почему fontencвозникает такой эффект и как это исправить?

решение1

Это расширенный комментарий:

Интересно, как возможно, что этот -знак имеет разные символы в первых двух строках и последних двух строках в OP MWE. В следующем MWE я только перепечатываю -символы (и также рассматриваю форматирование таблицыэгрегвторой пример) и работает и без \DeclareUnicodeCharacter{2212}{-}и с и без \usepackage[T1]{fontenc}:

\documentclass{article}
\usepackage[T1]{fontenc}
\usepackage{xcolor}
\usepackage{array,booktabs}
\usepackage{siunitx}

\begin{document}
    \begin{tabular}{
>{\color{purple}}r
                 S[table-format=2.0]
                 S[table-format=1.0]
                 S[table-format=-19.0]
                 S[table-format= 19.0]
                   }
\toprule
\verb+int8_t+  & 8  & 1 & -128                 & 127                 \\  
\midrule
\verb+int16_t+ & 16 & 2 & -32768               & 32767               \\  
\verb+int32_t+ & 32 & 4 & -2147483648          & 2147483647          \\  
\verb+int64_t+ & 64 & 8 & -9223372036854775808 & 9223372036854775807 \\ 
\bottomrule
    \end{tabular}
\end{document}

utf8Если это имеет значение, я использую WinEdt в качестве редактора предустановок для кодирования.

введите описание изображения здесь

решение2

Символы в последних двух строках — U+2212, что в UTF-8 является вводом, <E2><88><92>а шрифты в кодировке T1 имеют â, Ĺи Šв этих местах. Без этого fontencвы не получите вывод, но получите предупреждения о пропущенных символах.

Используйте также inputenc:

\documentclass[a4paper,10pt,openany]{scrbook}
\usepackage[T1]{fontenc}
\usepackage[utf8]{inputenc}

\usepackage{siunitx}

\DeclareUnicodeCharacter{2212}{-} % if U+2212 slips in

\newcommand{\ctype}[1]{\texttt{#1}}

\sisetup{group-separator={,}}

\begin{document}

\begin{tabular}{
  |l|
  S[table-format=2.0]|
  S[table-format=1.0]|
  S[table-format=-19.0]|
  S[table-format=19.0]|
}
\hline
Type & {Bits} & {Bytes} & {Minimum} & {Maximum} \\ \hline
\ctype{int8\_t} & 8 & 1 & -128 & 127 \\ \hline
\ctype{int16\_t} & 16 & 2 & -32768 & 32767 \\ \hline
\ctype{int32\_t} & 32 & 4 & −2147483648 & 2147483647 \\ \hline
\ctype{int64\_t} & 64 & 8 & −9223372036854775808 & 9223372036854775807 \\ \hline
\end{tabular}

\end{document}

(Я удалил, mintedпотому что определение \ctypeсодержало ошибки.)

введите описание изображения здесь

Просто для улучшения, загрузка booktabsи изменение таблицы в

\begin{tabular}{
  @{}
  l
  S[table-format=2.0]
  S[table-format=1.0]
  S[table-format=-19.0]
  S[table-format=19.0]
  @{}
}
\toprule
Type & {Bits} & {Bytes} & {Minimum} & {Maximum} \\
\midrule
\ctype{int8\_t} & 8 & 1 & -128 & 127 \\
\ctype{int16\_t} & 16 & 2 & -32768 & 32767 \\
\ctype{int32\_t} & 32 & 4 & −2147483648 & 2147483647 \\
\ctype{int64\_t} & 64 & 8 & −9223372036854775808 & 9223372036854775807 \\
\bottomrule
\end{tabular}

Я также удалил настройку group-separator, которая оставляет тонкий пробел по умолчанию:

введите описание изображения здесь

Связанный контент