답변:
Java는 연관 배열을 지원하지 않지만을 사용하여 쉽게 달성 할 수 있습니다 Map
. 예 :
Map<String, String> map = new HashMap<String, String>();
map.put("name", "demo");
map.put("fname", "fdemo");
// etc
map.get("name"); // returns "demo"
예를 들어 훨씬 더 정확한 것은 (문자열을 필요에 맞는 객체로 바꿀 수 있기 때문에) 다음과 같이 선언하는 것입니다.
List<Map<String, String>> data = new ArrayList<>();
data.add(0, map);
data.get(0).get("name");
ArrayList
로 인해 (예상치 못한?) 성능 차이 거의 모든 경우를한다. 그러나 그것은 또 다른 토론입니다.
HashMap
의도적으로 동작을 벤치마킹 및 사용 사례에 대한 더 나은 부하 요인을 찾을 수없는 것은 확실합니다. 초기 크기를 지정하는 유일한 이유는 맵이 매우 크다는 것을 미리 알고 있기 때문입니다. HashMap
비어있는 경우 (많은) 메모리를 낭비하지 않지만 큰 맵을 만들려는 경우 크기를 미리 지정하여 여러 배열 크기를 저장할 수 있습니다.
Java에는 PHP와 같은 연관 배열이 없습니다.
맵 사용과 같이 수행중인 작업에 대한 다양한 솔루션이 있지만 정보를 찾는 방법에 따라 다릅니다. 모든 정보를 보유하고 클래스의 인스턴스를에 저장하는 클래스를 쉽게 작성할 수 있습니다 ArrayList
.
public class Foo{
public String name, fname;
public Foo(String name, String fname){
this.name = name;
this.fname = fname;
}
}
그리고...
List<Foo> foos = new ArrayList<Foo>();
foos.add(new Foo("demo","fdemo"));
foos.add(new Foo("test","fname"));
그래서 당신은 그들처럼 액세스 할 수 있습니다 ...
foos.get(0).name;
=> "demo"
지도를 통해이 작업을 수행 할 수 있습니다. 같은 것
Map<String, String>[] arr = new HashMap<String, String>[2]();
arr[0].put("name", "demo");
그러나 Java를 사용하기 시작하면 데이터를 나타내는 클래스 / 모델을 만들면 최선의 선택이 될 것입니다. 난 그럴거야
class Person{
String name;
String fname;
}
List<Person> people = new ArrayList<Person>();
Person p = new Person();
p.name = "demo";
p.fname = "fdemo";
people.add(p);
Java에는 연관 배열과 같은 것이 없습니다. 가장 가까운 상대는 Map
입니다.이 형식은 강력하게 입력되지만 구문 / API는 적습니다.
이것은 귀하의 예를 기반으로 얻을 수있는 가장 가까운 것입니다.
Map<Integer, Map<String, String>> arr =
org.apache.commons.collections.map.LazyMap.decorate(
new HashMap(), new InstantiateFactory(HashMap.class));
//$arr[0]['name'] = 'demo';
arr.get(0).put("name", "demo");
System.out.println(arr.get(0).get("name"));
System.out.println(arr.get(1).get("name")); //yields null
LazyMap.decorate
과 InstantiateFactory
물건을위한?
글쎄, 나는 또한 연관 배열을 찾고 있었고 최상의 솔루션으로 맵 목록을 찾았습니다.
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class testHashes {
public static void main(String args[]){
Map<String,String> myMap1 = new HashMap<String, String>();
List<Map<String , String>> myMap = new ArrayList<Map<String,String>>();
myMap1.put("URL", "Val0");
myMap1.put("CRC", "Vla1");
myMap1.put("SIZE", "Vla2");
myMap1.put("PROGRESS", "Vla2");
myMap.add(0,myMap1);
myMap.add(1,myMap1);
for (Map<String, String> map : myMap) {
System.out.println(map.get("URL"));
}
//System.out.println(myMap);
}
}
HashMap<Integer, HashMap<String, String>> hash;
Java에는 연관 배열이 없으므로 얻을 수있는 가장 가까운 것은 Map 인터페이스입니다.
해당 페이지의 샘플은 다음과 같습니다.
import java.util.*;
public class Freq {
public static void main(String[] args) {
Map<String, Integer> m = new HashMap<String, Integer>();
// Initialize frequency table from command line
for (String a : args) {
Integer freq = m.get(a);
m.put(a, (freq == null) ? 1 : freq + 1);
}
System.out.println(m.size() + " distinct words:");
System.out.println(m);
}
}
함께 실행하는 경우 :
java Freq if it is to be it is up to me to delegate
당신은 얻을 것이다:
8 distinct words:
{to=3, delegate=1, be=1, it=2, up=1, if=1, me=1, is=2}
PHP와 같은 Java의 연관 배열 :
SlotMap hmap = new SlotHashMap();
String key = "k01";
String value = "123456";
// Add key value
hmap.put( key, value );
// check if key exists key value
if ( hmap.containsKey(key)) {
//.....
}
// loop over hmap
Set mapkeys = hmap.keySet();
for ( Iterator iterator = mapkeys.iterator(); iterator.hasNext();) {
String key = (String) iterator.next();
String value = hmap.get(key);
}
자세한 내용은 클래스 SoftHashMap을 참조하십시오. https://shiro.apache.org/static/1.2.2/apidocs/org/apache/shiro/util/SoftHashMap.html
ArrayList 사용 <Map <String, String>>
다음은 코드 샘플입니다.
ArrayList<Map<String, String>> products = new ArrayList<Map<String, String>>();
while (iterator.hasNext()) {
Map<String, String> product = new HashMap<String, String>();
Element currentProduct = iterator.next();
product.put("id",currentProduct.get("id"));
product.put("name" , currentProduct.get("name") );
products.add(product );
}
System.out.println("products : " + products);
출력 :
제품 : [{id = 0001, name = prod1}, {id = 0002, name = prod2}]
실제로 Java는 사전이라고하는 연관 배열을 지원합니다!
그것에 대해 더 많이 생각하면서, 나는이 문제를 다루는보다 일반적인 목적으로 튜플을 버리고 싶습니다. 튜플은 Java 네이티브가 아니지만 Javatuples 를 사용 하여 다른 언어에서와 동일한 기능을 제공합니다. 질문을 처리하는 방법의 예는 다음과 같습니다.
Map<Pair<Integer, String>, String> arr = new HashMap<Pair<Integer, String>, String>();
Pair p1 = new Pair(0, "name");
arr.put(p1, "demo");
이 접근법은 API가 제공하는 클래스와 메소드를 사용하여 트리플 및 기타 고차 그룹화로 확장 될 수 있기 때문에이 접근법을 좋아합니다.
PHP 주석 '아니요, PHP는 그것을 좋아하지 않을 것입니다.' 실제로, 매우 제한적인 (PHP의 경우) 예외 / 오류 수준을 설정하지 않는 한 (그리고 어쩌면 그렇지 않은 경우) PHP는 계속해서 gg 거립니다.
기본적으로 발생하는 것은 존재하지 않는 변수 / 범위를 벗어난 배열 요소에 대한 액세스는 할당중인 값을 '설정 해제'한다는 것입니다. 아니요, null이 아닙니다. PHP는 내가 이해 한 것으로부터 Perl / C 계보를 가지고 있습니다. 따라서 설정되지 않은 변수와 존재하지 않는 변수, 설정되었지만 NULL 인 값, 부울 False 값, 표준 언어가 갖는 다른 모든 변수가 있습니다. 그것들을 별도로 테스트하거나 기능 / 구문에 내장 된 올바른 평가를 선택해야합니다.
NullPointerException
외부지도 항목에 대한지도를 포함하지 않는 경우0
. $ arr [0] [ 'name']에서 PHP가 더 관용적이지 않습니까 (이 언어를 전혀 모릅니다)?