Этот
\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
, которая оставляет тонкий пробел по умолчанию: