草庐IT

numeric_traits_integer

全部标签

java - 为什么 java.lang.Integer.valueOf 是享元模式?

为什么java.lang.Integer.valueOf是享元模式?我试图找到原因,但找不到。 最佳答案 如果我们查看valueOf的源代码,我们可以得到一个提示:Sourceofjava.lang.Integer第638-643行:publicstaticIntegervalueOf(inti){assertIntegerCache.high>=127;if(i>=IntegerCache.low&&i看起来Integer类为公共(public)值维护了一个Integer对象的缓存。不是每次有人请求valueOf时都创建一个新值,

java - 为什么 java 不将 int[] 自动装箱到 Integer[]

当我执行以下操作时,arrayList1-包含一个元素,它是一个int[].arrayList2-未编译(错误:构造函数ArrayList(List)未定义)arrayList3-包含7个元素,它们是Integer对象代码如下:int[]intArray=newint[]{2,3,4,5,6,7,8};ArrayListarrayList1=newArrayList(Arrays.asList(intArray));ArrayListarrayList2=newArrayList(Arrays.asList(intArray));Integer[]integerArray=newInt

java - Long、Integer 和 Short 比较方法的不同实现?

为什么Java库中Long、Integer和Short的静态方法compare的实现不同?对于长:publicstaticintcompare(longx,longy){return(x对于整数:publicstaticintcompare(intx,inty){return(x对于短:publicstaticintcompare(shortx,shorty){returnx-y;} 最佳答案 如果你尝试:System.out.println(Long.MIN_VALUE-Long.MAX_VALUE);或System.out.pr

c++ - std::numeric_limits<double>::min() 上的错误 C2589

当我尝试编译一些代码(不是我自己的代码)时,我得到一个C2589'(':'::'右侧的非法标记在这一行:maxPosition[0]=std::numeric_limits::min();我想这是因为已经定义了一个min()宏,但为什么编译器不从指定的命名空间中获取min()而不是宏? 最佳答案 butwhyisthecompilernottakingthemin()fromthespecifiednamespaceinsteadofthemacro?因为宏不关心您的namespace、语言语义或您的编译器。预处理首先发生。换句话说

c++ - 如何访问 integer_sequence 的第 n 个值?

这个问题在这里已经有了答案:templateparameterpacksaccessNthtypeandNthelement(5个回答)2年前关闭。我想知道如何访问std::integer_sequence的第n个值.例如给定一个类型usingfoo=std::integer_sequence;我想要类似的东西autoi=get();//i=4标准库中有什么东西可以做到这一点吗?如果不是,如果我希望它在C++14(而不是C++17)中工作,我是否需要求助于迭代解决方案? 最佳答案 据我所知,没有这样的内置方法,但您可以自己用几行简洁

c++ - 使用默认值而不是异常来 boost numeric_cast<>?

每当boost的numeric_cast转换失败,抛出异常。boost中是否有类似的模板让我指定一个默认值,或者在这种情况下捕获异常是我唯一能做的?我不太担心所有额外异常处理的性能,但我宁愿使用标准模板也不愿编写无用的包装函数。另外,根据以往的经验,我认为boost很有可能真的有我想的,只是一直没有找到。 最佳答案 numeric_cast函数只是调用boost::numeric::converter具有默认参数的模板类。其中一个参数是OverflowHandler,默认值为def_overflow_handler,但您可以指定si

C++ next float with numeric_limits/epsilon?

考虑C++中的“正常”实数TREALx(不是次正规的也不是NaN/Infinite)(TREAL=float,double,longdouble)以下是从浮点角度查找上一个和下一个x的好解决方案吗?TREALxprev=(((TREAL)(1.))-std::numeric_limits::epsilon())*x;TREALxnext=(((TREAL)(1.))+std::numeric_limits::epsilon())*x;非常感谢。 最佳答案 C99和C++11在中有nextafter、nextafterl和nextaf

C++ 在编译时获取对象类型,例如 numeric_limits<typeof<a>>::max()?

给定inta;,我知道以下返回最大值a能把持住。numeric_limits::max()但是,我想在不知道a的情况下获得相同的信息是一个int.我想做这样的事情:numeric_limits>::max()不是用这个确切的语法,但这甚至可以使用ISOC++吗?谢谢大家。AurélienVallée的type_of()最接近,但我不想在我们的代码库中添加任何额外的东西。由于我们已经使用了Boost,ÉricMalenfant对Boost.Typeof的引用让我使用了numeric_limits::max()我以前从未使用过它。再次感谢您提供如此多的消息灵通的回复。

c++ - 如何在编译时找出 integer_sequence 是否包含给定的数字?

给定:typedefstd::integer_sequenceallowed_args_t;和:templatevoidfoo(){static_assert(/*fireifargnotinallowed_args_t!*/)}我应该如何编写static_assert以使其在编译时尽可能便宜?我正在使用C++17。 最佳答案 你可能想使用:templateconstexprboolis_in(inti,std::integer_sequence){return((i==Is)||...);}typedefstd::integer_

c++ - iterator_traits SFINAE 友好性

阅读excerpt时来自cppreferenceIfIteratordoesnothavethefivemembertypesdifference_type,value_type,pointer,reference,anditerator_category,thenthistemplatehasnomembersbyanyofthosenames(std::iterator_traitsisSFINAE-friendly)我自然而然地认为这意味着每个成员类型在迭代器本身中定义时就被定义了。但是你瞧,这实际上意味着如果定义了所有五个,那么它们就被定义了。structdefined{usi