Давайте разберемся с методами: slice( ), splice( ) и split( ) в javascript
Содержание:
- Класс StringTokenizer
- Python f-строки: особенности использования
- Split ( )
- Как обрезать строку по символу
- preg_match()
- More details about STRING_SPLIT
- Метод after() — Погружение в сон для Tkinter
- JavaScript
- Метод String.SplitString.Split method
- ОПЕРАТОРЫ УНАРного и БИНАРного разделенияUNARY and BINARY SPLIT OPERATORS
- Syntax:
- String Pool
Класс StringTokenizer
И еще несколько самых частых сценариев работы со строками. Как разбить строку на несколько частей? Для этого есть несколько способов.
Метод
Первый способ разбить строку на несколько частей — использовать метод . В него в качестве параметра нужно передать регулярное выражение: специальный шаблон строки-разделителя. Что такое регулярное выражение, вы узнаете в квесте Java Multithreading.
Пример:
Код | Результат |
---|---|
Результатом будет массив из трех строк: |
Просто, но иногда такой подход избыточен. Если разделителей много, например, «пробел», «enter», «таб», «точка», приходится конструировать достаточно сложное регулярное выражение. Его сложно читать, а значит, в него сложно вносить изменения.
Класс
В Java есть специальный класс, вся работа которого — разделять строку на подстроки.
Этот класс не использует регулярные выражения: вместо этого в него просто передается строка, состоящая из символов-разделителей. Преимущества этого подхода в том, что он не разбивает сразу всю строку на кусочки, а потихоньку идет от начала к концу.
Класс состоит из конструктора и двух методов. В конструктор нужно передать строку, которую мы разбиваем на части, и строку — набор символов, используемых для разделения.
Методы | Описание |
---|---|
Возвращает следующую подстроку | |
Проверяет, есть ли еще подстроки. |
Этот класс чем-то напоминает класс , у которого тоже были методы и .
Создать объект можно командой:
Где строка — это , которую будем делить на части. А — это строка, каждый символ которой считается символом-разделителем. Пример:
Код | Вывод на экран |
---|---|
Обратите внимание, что разделителем считается каждый символ строки, переданный второй строкой в конструктор
Python f-строки: особенности использования
Теперь, когда вы узнали все о том, почему f-строки великолепны, я уверен, что вы захотите начать их использовать. Вот несколько деталей, о которых нужно помнить, когда вы отправляетесь в этот дивный новый мир.
Кавычки
Вы можете использовать различные типы кавычек внутри выражений. Просто убедитесь, что вы не используете кавычки того же типа на внешней стороне f-строки, которые вы используете в выражении.
Этот код будет работать:
>>> f"{'Eric Idle'}" 'Eric Idle'
Этот код также будет работать:
>>> f'{"Eric Idle"}' 'Eric Idle'
Вы также можете использовать тройные кавычки:
>>> f"""Eric Idle""" 'Eric Idle'
>>> f'''Eric Idle''' 'Eric Idle'
Если вам нужно использовать одинаковый тип кавычки как внутри, так и снаружи строки, вы можете сделать это с помощью \:
>>> f"The \"comedian\" is {name}, aged {age}." 'The "comedian" is Eric Idle, aged 74.'
Словари
Говоря о кавычках, следите, когда вы работаете со словарями. Если вы собираетесь использовать одинарные кавычки для ключей словаря, то не забудьте убедиться, что вы используете двойные кавычки для f-строк, содержащих ключи.
>>> comedian = {'name': 'Eric Idle', 'age': 74} >>> f"The comedian is {comedian}, aged {comedian}." The comedian is Eric Idle, aged 74.
Пример с синтаксической ошибкой:
>>> comedian = {'name': 'Eric Idle', 'age': 74} >>> f'The comedian is {comedian}, aged {comedian}.' File "<stdin>", line 1 f'The comedian is {comedian}, aged {comedian}.' ^ SyntaxError: invalid syntax
Если вы используете тот же тип кавычки вокруг ключей словаря, что и на внешней стороне f-строки, то кавычка в начале первого ключа словаря будет интерпретироваться как конец строки.
Фигурные скобки
Чтобы в скобках появилась скобка, вы должны использовать двойные скобки:
>>> f"`74`" '{74}'
Обратите внимание, что использование тройных скобок приведет к тому, что в вашей строке будут только одиночные скобки:
>>> f"{`74`}" '{74}'
Тем не менее, вы можете получить больше фигурных скобок, если вы используете больше, чем тройные фигурные скобки:
>>> f"{{`74`}}" '`74`'
Обратный слеш
Как вы видели ранее, вы можете использовать обратные слэши в строковой части f-строки. Однако вы не можете использовать обратную косую черту для экранирования части выражения f-строки:
>>> f"{\"Eric Idle\"}" File "<stdin>", line 1 f"{\"Eric Idle\"}" ^ SyntaxError: f-string expression part cannot include a backslash
Вы можете обойти это, предварительно посчитав выражение и используя результат в f-строке:
>>> name = "Eric Idle" >>> f"{name}" 'Eric Idle'
Выражения не должны содержать комментарии, использующие символ #. Используя это вы получите синтаксическую ошибку:
>>> f"Eric is {2 * 37 #Oh my!}." File "<stdin>", line 1 f"Eric is {2 * 37 #Oh my!}." ^ SyntaxError: f-string expression part cannot include '#'
Split ( )
Методы Slice( ) и splice( ) используются для массивов. Метод split( )используется для строк. Он разделяет строку на подстроки и возвращает их в виде массива. У этого метода 2 параметра, и оба из них не обязательно указывать.
string.split(separator, limit);
- Separator: определяет, как строка будет поделена на подстроки: запятой, знаком и т.д.
- Limit: ограничивает количество подстрок заданным числом
Метод split( ) не работает напрямую с массивами. Тем не менее, сначала можно преобразовать элементы массива в строки и уже после применить метод split( ).
Давайте посмотрим, как это работает.
Сначала преобразуем массив в строку с помощью метода toString( ):
let myString = array.toString();
Затем разделим строку myString запятыми и ограничим количество подстрок до трех. Затем преобразуем строки в массив:
let newArray = myString.split(",", 3);
В виде массива вернулись первые 3 элемента
Таким образом, элементы массива myString разделены запятыми. Мы поставили ограничение в 3 подстроки, поэтому в качестве массива вернулись первые 3 элемента.
Все символы разделены на подстроки
Как обрезать строку по символу
- -> разбираемся в тезисе
- -> explode
- ->показать слева
- ->показать справа
- ->показать слева
- ->показать справа
- Скачать
PHP Обрезать строку по символу можно по разному….
Обрезать строку по символу в php -> можно понять, как -> что у нас есть в строке определенный заранее известный символ, и вот по нему и нужно обрезать строку! Будем использовать explode
Обрезать строку по символу в php -> есть вообще строка… любая и нам требуется отсчитать некое количество символов и вот поэтому количеству символов и обрезать строку!
Мы уже говорили об этой функции explode — сейчас будет использовать её для обрезки строки по символу!
Нам потребуется для иллюстрации обрезки строки по символу какая-то произвольная строка с каким-то наполнением:$string = «12345678910|10987654321»;
Для примера, возьмем символ, который расположен примерно посередине -> «|», создаем такую запись :
$new_array = explode(«|» , $string);
Если нам потребуется первая часть, то используем current: echo current($new_array);
Результат:
12345678910
Если вам потребуется вторая часть, то используем end. Здесь нужно дополнение — если символ 1, то end будет показывать второй элемент, если символ в строке повторяется несколько раз, то end покажет последнюю ячейку массива
В данном случае разделительный элемент сроки я единственном числе, поэтому нам предстанет вторая часть:
echo end($new_array);
Результат:
10987654321
Прежде чем продолжать нам потребуются какие-то условия, например, нам нужно обрезать строку по 5 символу, здесь число не важно, и нам опять…
понадобится строка :
$string = «12345678910|10987654321»;
Поскольку и дальше будем использовать это число для обрезки по символу, то присвоим это значение произвольной переменной: $num_elem = 5;
Длаее нам понадобится функция substr и вот такая конструкция:
$first = substr($string , 0, $num_elem);
Далее выводим с помощью echo
echo $first;
Результат:
12345
Можете посчитать … строка обрезана по 5 символу!И показана строка с начала!
Но, что если нам требуется обрезать строку по символу с начала и удалить эту часть оставив только часть справа…
Как мы уже сказали выше, что если нам требуется обрезать строку сначала по символу и выкинуть эту часть, отставив строку с конца..
если вы не обратили внимание на строку
то рекомендую сейчас на неё внимательность посмотреть и на первый результат тоже…
Опять брем всю ту же строку…:
$string = «12345678910|10987654321»;
Пишем такую конструкцию:
echo substr($string , 5 );
Результат:
678910|10987654321
Теперь предположим
что нам требуется обрезать строку по символу с конца и показать левую часть, выкинув обрезанную часть:
echo substr($string , 0, — 5 ); ?>
Результат:
12345678910|109876
Опять обрезаем строку справа, и эту часть обрезанной строки и покажем:
Обрезать строку по символу № 5 с конца строки — показать правую часть:
echo substr($string , — 5 ); ?>
Результат:
54321
Последняя дата редактирования : 27.02.2021 14:23
Название скрипта :Обрезать строку по символу.
Скрипт № 33.13Ссылка на скачивание : Все скрипты на
//dwweb.ru/comments_1_5/include/img/hand_no_foto.png
no
no
preg_match()
Вы редко найдете тех, кто предпочитает использовать регулярные выражения, когда есть так много отличных функций PHP. Тем не менее, вот функция, которая обрезает строку до определенного символа в PHP, исходя из заданного количества знаков от начала. В отличие от других функций, описанных выше, эта функция обрезает строку до целого слова.
/* preg-match() http://php.net/manual/en/function.preg-match.php */ function internoetics_preg_string($string, $length, $trimmarker = '...') { $strlen = strlen($string); /* mb_substr добавляет принудительный разрыв в $length, если заданное количество символов не содержит окончания слова (пробела) */ $string = trim(mb_substr($string, 0, $strlen)); if ($strlen > $length) { preg_match('/^.{1,' . ($length - strlen($trimmarker)) . '}b/su', $string, $match); $string = trim($match) . $trimmarker; } else { $string = trim($string); } return $string; } /* Применение */ echo internoetics_preg_string($string, 100, $trimmarker = '...');
Описание функции
Функция принимает три параметра: $string, $length и $trimmarker (многоточие или другие символы, которые добавляются в конце строки).
Строка 7
$strlen = strlen($string);
Первое, что мы делаем, это проверяем длину PHP обрезанной строки после символа. Если строка короче, чем $length, то мы возвращаем эту строку.
Строка 9
$string = trim(mb_substr($string, 0, $strlen));
Функция mb_substr() прерывает строку в $length, если это количество символов не содержит окончания слова (пробела). Если мы передали строку длиною 500 символов и эта строка не содержит пробелов, то будет возвращена вся строка (так как функция preg_match не нашла окончания слова). На данный момент мы обрезаем строку таким образом, и возвращаем ее полностью.
Строки 10, 11, и 12
Если длина нашей строки превышает максимальную длину, определенную в качестве параметра функции, мы выполняем регулярное выражение функции preg_match(), чтобы вернуть часть строки до символа с номером $length, который определяется как конец слова (‘/^.{1,$length}b/s’). Знак периода означает любой символ, кроме символа новой строки (n). Фигурная скобка определяет диапазон, который задает, сколько символов должен PHP обрезать в строке. Таким образом {1,$length} означает от 1 до символа $length. Наконец, b означает, что шаблон будет соответствовать окончанию слова. Мы можем производить поиск только слов целиком по шаблону, который мы предоставили. И в конце s задает поиск всех пробелов.
Так как мы не хотим, чтобы возвращаемая строка превышала длину $length, максимальное количество символов в функции preg_match должно быть равно максимальной длине минус длина $trimmarke.r. Мы должны учитывать это.
Затем мы возвращаем либо усеченную строку, либо исходную строку, если она меньше заданной длины усечения.
More details about STRING_SPLIT
After all the basic usage methodology of this function; we will delve into more detail. In the previous examples we always used a comma (,) as a separator for the function, however, we may need to use other symbols as a separator. The STRING_SPLIT function allows us to use other symbols as a separator, but it has one limitation about this usage. According to the MSDN; separator is a single data type and this parameter data types can be nvarchar (1), char (1), and varchar (1). Now, we will make a sample about it. The following SELECT statement will run without error. As well as we will use at (@) instead of a comma (,).
1 |
DECLARE@STRINGLISTASVARCHAR(1000)=’apple,banana,lemon,kiwi,orange,coconut’ DECLARE@SEPERATORVARCHAR(1)=’,’ select*fromSTRING_SPLIT(@STRINGLIST,@SEPERATOR) |
However, the following SELECT statement will return an error because of the data type declaration.
1 |
DECLARE@STRINGLISTASVARCHAR(1000)=’apple@+@banana@+@lemon@+@kiwi@+@orange@+@coconut’ DECLARE@SEPERATORVARCHAR(3)=’@+@’ select*fromSTRING_SPLIT(@STRINGLIST,@SEPERATOR) |
“Procedure expects parameter ‘separator’ of type ‘nchar(1)/nvarchar(1)’”. The definition of error is very clear and it indicates a problem that is related to the data type of separator. After this sample, a question can appear in your mind. Can we assign NULL value to separator? We will test and learn.
1 |
DECLARE@STRINGLISTASVARCHAR(1000)=’apple,banana,lemon,kiwi,orange,coconut’ DECLARE@SEPERATORVARCHAR(1)=NULL select*fromSTRING_SPLIT(@STRINGLIST,@SEPERATOR) |
We cannot assign NULL value to separator as a value.
In addition, when we use this function for numerical values, the result set will be in string data types. When we execute the following query, we can see all details and result in set table data type.
1 |
DROPTABLEIFEXISTSTempStringSplit SELECTVALUEINTOTempStringSplitFROMstring_split(‘1,2,3′,’,’)ASStrSplit SELECTTABLE_NAME,COLUMN_NAME,COLUMN_DEFAULT,DATA_TYPE,CHARACTER_MAXIMUM_LENGTH FROMINFORMATION_SCHEMA.COLUMNS whereTABLE_NAME=’TempStringSplit’ DROPTABLEIFEXISTSTempStringSplit |
Now we will analyze the following query execution plan with ApexSQL Plan.
1 |
DROPTABLEIFEXISTSTempNumerical GO CREATETABLETempNumerical (NumberIdINT) INSERTINTONumerical VALUES(1),(2),(3),(5) GO SELECT*FROMNumerical INNERJOINstring_split(‘1,2,3′,’,’)ASStrSplit ONNumerical.NumberId=StrSplit.value |
In the select operator, you are seeing a warning sign and now find out the details about this warning.
The reason for this warning is that we tried to join integer data type to varchar data type, so this type of usage causes implicit conversion. Implicit conversions affect the performance query.
Метод after() — Погружение в сон для Tkinter
tkinter является частью стандартной библиотеки Python. В случае, если вы используете заранее установленную версию Python на Linux или Mac, он может быть вам недоступен. При получении ошибки стоит самостоятельно добавить его в систему. В том случае, если вы ранее установили Python сами, должен быть доступен.
Начнем с разбора примера, где используется . Запустите следующий код и посмотрите, что произойдет при неправильном добавлении вызова в Python:
Python
import tkinter
import time
class MyApp:
def __init__(self, parent):
self.root = parent
self.root.geometry(«400×400″)
self.frame = tkinter.Frame(parent)
self.frame.pack()
b = tkinter.Button(text=»click me», command=self.delayed)
b.pack()
def delayed(self):
time.sleep(3)
if __name__ == «__main__»:
root = tkinter.Tk()
app = MyApp(root)
root.mainloop()
1 15 |
importtkinter importtime classMyApp def__init__(self,parent) self.root=parent self.root.geometry(«400×400») self.frame=tkinter.Frame(parent) self.frame.pack() b=tkinter.Button(text=»click me»,command=self.delayed) b.pack() defdelayed(self) if__name__==»__main__» root=tkinter.Tk() app=MyApp(root) root.mainloop() |
После запуска кода нажмите кнопку в GUI. Кнопка не будет реагировать три секунды, ожидая завершения . Если в приложении есть другие кнопки, на них тоже нельзя будет нажать. Закрыть приложение во время сна нельзя, так как оно не будет откликаться на событие закрытия.
Для должного погружения в сон потребуется использовать :
Python
import tkinter
class MyApp:
def __init__(self, parent):
self.root = parent
self.root.geometry(«400×400»)
self.frame = tkinter.Frame(parent)
self.frame.pack()
self.root.after(3000, self.delayed)
def delayed(self):
print(‘Я задержался’)
if __name__ == «__main__»:
root = tkinter.Tk()
app = MyApp(root)
root.mainloop()
1 10 |
importtkinter classMyApp def__init__(self,parent) self.root=parent self.root.geometry(«400×400») self.frame=tkinter.Frame(parent) self.frame.pack() defdelayed(self) print(‘Я задержался’) if__name__==»__main__» root=tkinter.Tk() app=MyApp(root) root.mainloop() |
Здесь создается приложение, высота которого 400 пикселей, и ширина также 400 пикселей. На нем нет виджетов. Оно только показывает фрейм. Затем вызывается , где является отсылкой к объекту . принимает два аргумента:
- Количество миллисекунд для сна;
- Метод который вызовется после завершения сна.
В данном случае приложение выведет строку в стандартный поток вывода (stdout) через 3 секунды. Можно рассматривать как Tkinter-версию того же , только он добавляет способность вызова функции после завершения сна.
Данную функциональность можно использовать для улучшения работы пользователя. Добавив в Python вызов , можно ускорить процесс загрузки приложения, после чего начать какой-то длительный процесс. В таком случае пользователю не придется ждать открытия приложения.
JavaScript
JS Array
concat()
constructor
copyWithin()
entries()
every()
fill()
filter()
find()
findIndex()
forEach()
from()
includes()
indexOf()
isArray()
join()
keys()
length
lastIndexOf()
map()
pop()
prototype
push()
reduce()
reduceRight()
reverse()
shift()
slice()
some()
sort()
splice()
toString()
unshift()
valueOf()
JS Boolean
constructor
prototype
toString()
valueOf()
JS Classes
constructor()
extends
static
super
JS Date
constructor
getDate()
getDay()
getFullYear()
getHours()
getMilliseconds()
getMinutes()
getMonth()
getSeconds()
getTime()
getTimezoneOffset()
getUTCDate()
getUTCDay()
getUTCFullYear()
getUTCHours()
getUTCMilliseconds()
getUTCMinutes()
getUTCMonth()
getUTCSeconds()
now()
parse()
prototype
setDate()
setFullYear()
setHours()
setMilliseconds()
setMinutes()
setMonth()
setSeconds()
setTime()
setUTCDate()
setUTCFullYear()
setUTCHours()
setUTCMilliseconds()
setUTCMinutes()
setUTCMonth()
setUTCSeconds()
toDateString()
toISOString()
toJSON()
toLocaleDateString()
toLocaleTimeString()
toLocaleString()
toString()
toTimeString()
toUTCString()
UTC()
valueOf()
JS Error
name
message
JS Global
decodeURI()
decodeURIComponent()
encodeURI()
encodeURIComponent()
escape()
eval()
Infinity
isFinite()
isNaN()
NaN
Number()
parseFloat()
parseInt()
String()
undefined
unescape()
JS JSON
parse()
stringify()
JS Math
abs()
acos()
acosh()
asin()
asinh()
atan()
atan2()
atanh()
cbrt()
ceil()
clz32()
cos()
cosh()
E
exp()
expm1()
floor()
fround()
LN2
LN10
log()
log10()
log1p()
log2()
LOG2E
LOG10E
max()
min()
PI
pow()
random()
round()
sign()
sin()
sqrt()
SQRT1_2
SQRT2
tan()
tanh()
trunc()
JS Number
constructor
isFinite()
isInteger()
isNaN()
isSafeInteger()
MAX_VALUE
MIN_VALUE
NEGATIVE_INFINITY
NaN
POSITIVE_INFINITY
prototype
toExponential()
toFixed()
toLocaleString()
toPrecision()
toString()
valueOf()
JS OperatorsJS RegExp
constructor
compile()
exec()
g
global
i
ignoreCase
lastIndex
m
multiline
n+
n*
n?
n{X}
n{X,Y}
n{X,}
n$
^n
?=n
?!n
source
test()
toString()
(x|y)
.
\w
\W
\d
\D
\s
\S
\b
\B
\0
\n
\f
\r
\t
\v
\xxx
\xdd
\uxxxx
JS Statements
break
class
continue
debugger
do…while
for
for…in
for…of
function
if…else
return
switch
throw
try…catch
var
while
JS String
charAt()
charCodeAt()
concat()
constructor
endsWith()
fromCharCode()
includes()
indexOf()
lastIndexOf()
length
localeCompare()
match()
prototype
repeat()
replace()
search()
slice()
split()
startsWith()
substr()
substring()
toLocaleLowerCase()
toLocaleUpperCase()
toLowerCase()
toString()
toUpperCase()
trim()
valueOf()
Метод String.SplitString.Split method
String.Split предоставляет несколько перегрузок, которые позволяют разбить строку на группу подстрок, основанных на одном или нескольких указанных символах-разделителях.String.Split provides a handful of overloads to help you break up a string into a group of substrings based on one or more delimiting characters that you specify. Вы можете ограничить общее число подстрок в окончательном результате, обрезав пробелы в подстроках или исключив пустые подстроки.You can choose to limit the total number of substrings in the final result, trim white-space characters from substrings, or exclude empty substrings.
Ниже показаны три различные перегрузки .The following examples show three different overloads of . Первый пример вызывает перегрузку без передачи знаков разделения.The first example calls the overload without passing any separator characters. Если не указать символы-разделители, будет использовать для разделения строки разделители по умолчанию, которые являются пробелами.When you don’t specify any delimiting characters, uses default delimiters, which are white-space characters, to split up the string.
Как видите, символы-точки () содержатся в двух подстроках.As you can see, the period characters () are included in two of the substrings. Если вы хотите исключить символы-точки, добавьте символ-точку как дополнительный символ разделителя.If you want to exclude the period characters, you can add the period character as an additional delimiting character. В следующем примере показано, как это сделать.The next example shows how to do this.
Точки исчезли из подстрок, однако теперь появились две дополнительные пустые подстроки.The periods are gone from the substrings, but now two extra empty substrings have been included. Пустые подстроки представляют подстроку между словом и точкой после него.These empty substring represent the substring between the word and the period that follows it. Чтобы исключить из результирующего массива пустые подстроки, вызовите перегрузку и укажите для параметра .To omit empty substrings from the resulting array, you can call the overload and specify for the parameter.
ОПЕРАТОРЫ УНАРного и БИНАРного разделенияUNARY and BINARY SPLIT OPERATORS
Оператор унарного разбиения ( ) имеет более высокий приоритет, чем запятая.The unary split operator () has higher precedence than a comma. В результате, если отправить разделенный запятыми список строк в оператор унарного разбиения, то разбиение выполняется только на первую строку (перед первой запятой).As a result, if you submit a comma-separated list of strings to the unary split operator, only the first string (before the first comma) is split.
Чтобы разделить более одной строки, используйте один из следующих шаблонов:Use one of the following patterns to split more than one string:
- Использование оператора двоичного разделения ( <string[]> -Split <delimiter> )Use the binary split operator (<string[]> -split <delimiter>)
- Заключите все строки в круглые скобкиEnclose all the strings in parentheses
- Сохранить строки в переменной, а затем отправить переменную оператору SplitStore the strings in a variable then submit the variable to the split operator
Рассмотрим следующий пример.Consider the following example:
Syntax:
The syntax is very simple as this table valued built-in function takes only two parameters. First one is a string and the second one is a single character.
STRING_SPLIT (string, separator)
The following sample shows simplest usage of this function.
1 | selectvaluefromSTRING_SPLIT(‘apple,banana,lemon,kiwi,orange,coconut’,’,’) |
The following SELECT query will return an error because of the database compatibility level.
1 |
ALTERDATABASEAdventureWorks2012SETcompatibility_LEVEL=120 GO selectvalue from STRING_SPLIT(‘apple , banana , lemon , kiwi , orange ,coconut’,’,’) |
The reason for this error is that we decreased the database compatibility level under the 130 and SQL Server returns an error. Keep in mind, that if you are planning to use this function in your customer environment you have to be sure about their database compatibility level.
String Pool
Все строки, которые были заданы в коде в , во время работы программы хранятся в памяти в так называемом . — это специальный массив для хранения строк. Цель его создания — оптимизация хранения строк:
Во-первых, строки, заданные в коде, нужно все-таки где-то хранить. Код — это команды, а данные (тем более такие большие как строки) нужно хранить в памяти отдельно от кода. В коде фигурируют только ссылки на объекты-строки.
Во-вторых, все одинаковые литералы можно хранить в памяти только один раз. Так оно и работает. Когда код вашего класса загружается Java-машиной, все строковые литералы добавляются в , если их там еще нет. Если уже есть, просто используется ссылка на строку из .
Поэтому если в своем коде вы присвоите нескольким -переменным одинаковые литералы, переменные будут содержать одинаковые ссылки. В литерал будет добавлен только один раз, во всех остальных случаях будет браться ссылка на уже загруженную в строку.
Как это примерно работает:
Код | Работа с StringPool |
---|---|
Именно поэтому переменные и будут хранить одинаковые ссылки.
Метод
Ну и самое интересное: вы можете программно добавить любую строку в . Для этого нужно просто вызвать метод у -переменной.
Метод добавит строку в , если ее еще там нет, и вернет ссылку на строку из .
Код | Примечание |
---|---|
Вряд ли вы будете часто пользоваться этим методом, однако о нем любят спрашивать на собеседованиях, поэтому лучше о нем знать, чем не знать.