(K,V) Tarkoittaa siis Key ja Value, sehän on selvää.
Kokoan leikkeitä ohjeista:
http://www.dartlang.org/language-tour/#generics
Generics
If you look at the API documentation for the basic array type, List, you'll see that the type is actuallyList<E>. The <...> notation marks List as a generic (or parameterized) type—a type that can declare formal type parameters.
For example, if you intend for a list to contain only strings, you can declare it as List<String> (read that as "List of String").
....
Generic types can save you the trouble of creating all these interfaces. Instead, you can create a single interface that takes a type parameter:
interface Cache<T> { T getByKey(String key); setByKey(String key, T value); }
In this code, T is the stand-in type. It's a placeholder that you can think of as a type that a developer will define later.
Using collection literals
Both built-in collection types are parameterized: lists and maps. Parameterized literals are just like the literals you've already seen, except that you add <type> before the opening bracket. For example:
List<String> names = <String>['Seth', 'Kathy', 'Lars']; Map<String, String> pages = <String>{ // specify value type: String 'index.html':'Homepage', // (the key type is implicitly String) 'robots.txt':'Hints for web robots', 'humans.txt':'We are people, not machines' };
NO? Näyttää siltä siis, että <> merkinnän sisällä on "tyyppi"...
..
To specify one or more types when using a constructor, put the types in angle brackets (
<...>
..
Generic collections and the types they contain
Dart generic types are reified, which is a fancy way of saying that they carry their type information around at runtime.
= = = = = = = = = = = = = = = = = = = = = = = = =
Collection<E>
HashSet<E>
Iterable<E>
Iterator<E>
List<E>
Queue<E>
Set<E>
HashMap<K, V>
LinkedHashMap<K, V>
Map<K, V> mapping a key to a value.
Completer<T>
Future<T>
SIIS: E T K V
What is this T in <T> ?
Interface Future<T>
A Future is used to obtain a value sometime in the future. Receivers of a Future obtain the value by passing a callback to then.
========================================================
What is this E in <E> ?
===========================================
Typedefs can be parameterized.
typedef int Compare<T>(T a, T b);
class SortedCollection<T> {
Compare<T> compare;
SortedCollection(this.compare);
}
main() {
SortedCollection<int> s = new SortedCollection<int>((a,b) => a - b);
print(s.compare is Compare<int>); // true
print(s.compare('a','b')); // checked mode throws exception
}
dartlang 0.08typeParameter:
identifier (extends type)?
;
typeParameters:
`<' typeParameter (`,' typeParameter)* `>'
;
A type parameter T may be suffixed with an extends clause that specifies
the upper bound for T.
A type parameter T may be suffixed with an extends clause that specifies
the upper bound for T. ....
Tässäpä hieman sulattelemista... Täydennän tekstiä vielä...
http://c.dart-examples.com/learn/variables/collections
Tämä kirjoitus tuo hieman lisävalaistusta asiaan...
.
Ei kommentteja:
Lähetä kommentti