Tag: string

“新的String()”是不可变的吗?

我一直在研究Java String。 以下问题是基于下面的post Javastring是特殊的 java中string的不变性 不变性:现在,通过不变性来deviseString类,以便公共池中的值可以在其他地方/variables中重用。 如果String创build为 String a = "Hello World!"; 不过,如果我创buildString就好 String b = new String("Hello World!"); 为什么这个不变呢? (或者是?)。 由于这有一个专用的堆内存,我应该能够修改这个不影响任何其他variables。 那么在devise上,为什么String作为一个整体被认为是不可变的? 或者我的上述假设是错误的? 我想问的第二件事是关于常见的string池 。 如果我创build一个string对象 String c = ""; 是在池中创build的空条目? 有没有任何职位已经在这些? 如果是这样,有人可以分享链接?

只把string的第一个字符大写,留下别人一个人? (导轨)

我试图让Rails利用string的第一个字符,并把所有其他的字符都保留下来。 我遇到了“我来自纽约”的问题变成了“我来自纽约”。 我会用什么方法select第一个字符? 谢谢 编辑:我试图实施什么macekbuild议,但我得到一个“未定义的方法`大写'”错误。 代码工作正常,没有大写的行。 谢谢您的帮助! def fixlistname! self.title = self.title.lstrip + (title.ends_with?("…") ? "" : "…") self.title[0] = self.title[0].capitalize errors.add_to_base("Title must start with \"You know you…\"") unless self.title.starts_with? 'You know you' end 编辑2:得到它的工作。 谢谢您的帮助! 编辑3:等等,不,我没有…这是我在我的列表模型中。 def fixlistname! self.title = self.title.lstrip + (title.ends_with?("…") ? "" : "…") self.title.slice(0,1).capitalize + self.title.slice(1..-1) errors.add_to_base("Title must start with […]

为什么在C ++中分割string比Python慢​​?

我试图将一些代码从Python转换为C ++,以获得一点速度,并加强生锈的C ++技能。 昨天我惊讶地发现,从stdin的阅读线的天真实现在Python比C ++快得多(见本文 )。 今天,我终于想通过合并分隔符(类似的语义到python的split())来分割C ++中的string,现在正在经历似曾相识的过程! 我的C ++代码需要更长的时间来完成这项工作(尽pipe不像昨天的课程那样多一个数量级)。 Python代码: #!/usr/bin/env python from __future__ import print_function import time import sys count = 0 start_time = time.time() dummy = None for line in sys.stdin: dummy = line.split() count += 1 delta_sec = int(time.time() – start_time) print("Python: Saw {0} lines in {1} seconds. ".format(count, delta_sec), end='') […]

为什么在没有大括号的情况下在Ruby中使用string插值?

在Ruby中使用string插值的正确方法如下: name = "Ned Stark" puts "Hello there, #{name}" #=> "Hello there, Ned Stark" 这是我打算总是使用它的方式。 不过,我注意到Ruby的string插值有些奇怪 。 我已经注意到,string插值在Ruby中没有花括号来表示实例variables。 例如: @name = "Ned Stark" puts "Hello there, #@name" #=> "Hello there, Ned Stark" 而那个尝试与非实例variables相同的东西是行不通的。 name = "Ned Stark" puts "Hello, there, #name" #=> "Hello there, #name" 我在1.9.2和1.8.7都试过这个成功的例子。 为什么这个工作? 口译员在这里做什么?

在定义macros的Pragma

有没有其他的方式来embeddedmacros语句与其他语句的编译指示语句? 我正在试图达到像这样的东西: #define DEFINE_DELETE_OBJECT(type) \ void delete_ ## type_(int handle); \ void delete_ ## type(int handle); \ #pragma weak delete_ ## type_ = delete_ ## type 如果存在的话,我可以使用boost解决scheme(除波)。

在Java中爆炸和Implode(就像PHP一样)

我是Java新手,虽然在PHP方面有很好的经验,并且希望能够完美替代Java中的explode和implode(用PHP提供)函数。 我已经Google一样,但不满意的结果。 任何人有我的问题很好的解决scheme将不胜感激。

奇怪的string池行为

我有一个奇怪的string池行为的问题。 我正在使用==比较相等的string,以确定它们是否在游泳池中。 public class StringPoolTest { public static void main(String[] args) { new StringPoolTest().run(); } String giveLiteralString() { return "555"; } void run() { String s1 = giveLiteralString() + ""; System.out.println("555" == "555" + ""); System.out.println(giveLiteralString() == giveLiteralString() + ""); } } 输出是: true false 这对我来说是一个很大的惊喜。 有谁能解释这个吗? 我认为这是在汇编时发生的。 但是为什么在string中添加""会有所作为?

如何在node.js中执行多行string?

随着node.js的兴起,多行string在JavaScript中变得越来越必要。 Node.JS中有没有特殊的方法可以实现,即使它在浏览器中不起作用? 是否有任何计划或至less有一个function要求来做到这一点,我可以支持? 我已经知道你可以在每行的结尾使用\n\ ,这不是我想要的。

为什么在split()结果中返回空string?

['', 'segment', 'segment', ''] '/segment/segment/'.split('/')返回['', 'segment', 'segment', '']什么意思? 注意空的元素。 如果你正在分割一个恰好在位置1和string末尾的分隔符,那么它会给你带来从每一端返回的空string的额外值?

从它的编号中创buildUnicode字符

我想在Java中显示一个Unicode字符。 如果我这样做,它工作得很好: String symbol = "\u2202"; 符号等于“∂”。 这就是我想要的。 问题是我知道Unicode编号,需要从中创buildUnicode符号。 我试过(对我来说)显而易见的事情: int c = 2202; String symbol = "\\u" + c; 但在这种情况下,符号等于“\ u2202”。 这不是我想要的。 如果我知道它的Unicode号码(但只在运行时—我不能像第一个例子那样对它进行硬编码),我该如何构造符号?