GVKun编程网logo

c# – 如何在不复制元素的情况下从HashSet创建ReadOnlyCollection?(c#实现复制功能)

17

如果您想了解c#–如何在不复制元素的情况下从HashSet创建ReadOnlyCollection?的相关知识,那么本文是一篇不可错过的文章,我们将对c#实现复制功能进行全面详尽的解释,并且为您提供关

如果您想了解c# – 如何在不复制元素的情况下从HashSet创建ReadOnlyCollection?的相关知识,那么本文是一篇不可错过的文章,我们将对c#实现复制功能进行全面详尽的解释,并且为您提供关于9 HashSet HashCode 迭代器 TreeSet Colletions类 HashMap、asp.net – 使用HTML’readonly =“readonly”’与JavaScript’元素的奇怪行为.readOnly = true;’、asp.net-mvc-2 – 如何在不设置Content-Disposition标签的情况下从控制器返回图像?、c – 如何在不复制的情况下从C数组构造std :: vector或boost ::数组?的有价值的信息。

本文目录一览:

c# – 如何在不复制元素的情况下从HashSet创建ReadOnlyCollection?(c#实现复制功能)

c# – 如何在不复制元素的情况下从HashSet创建ReadOnlyCollection?(c#实现复制功能)

我有一个私人HashSet< string>这是只读属性的后备字段,它应返回只读集合,以便调用者无法修改集合.所以我试着:
public class MyClass
{
    private readonly HashSet<string> _referencedColumns;

    public ICollection<string> ReferencedColumns { 
        get { return new ReadOnlyCollection<string>(_referencedColumns); }
    }

这不能编译,因为ReadOnlyCollection接受IList< T>.这不是由HashSet< T>实现的.还有另一个包装我可以用来拯救我复制这些物品吗?为了我的目的,只需返回实现ICollection< T>的东西即可. (而不是IList< T>)由HashSet< T>实现.

解决方法

考虑将属性公开为类型IReadOnlyCollection<>相反,它将提供HashSet<>的只读视图.这是实现此方法的有效方法,因为属性getter不需要底层集合的副本.

这不会阻止某人将属性转换为HashSet<>并修改它.如果您担心这一点,请考虑在属性getter中返回_referencedColumns.ToList(),它将创建基础集的副本.

9 HashSet HashCode 迭代器 TreeSet Colletions类 HashMap

9 HashSet HashCode 迭代器 TreeSet Colletions类 HashMap


1. 当向ArrayList添加一个对象时,实际上就是将该对象放置到了ArrayList底层所维护的数组当中;当向LinkedList中添加一个对象时,实际上LinkedList内部会生成一个Node对象,该Node对象的结构为
void linkLast(E e) {
        final Node<E> l = last;
        final Node<E> newNode = new Node<>(l, e, null);
        last = newNode;
        if (l == null)
            first = newNode;
        else
            l.next = newNode;
        size++;
        modCount++;
    }
private static class Node<E> {
        E item;
        Node<E> next;
        Node<E> prev;

        Node(Node<E> prev, E element, Node<E> next) {
            this.item = element;
            this.next = next;
            this.prev = prev;
        }
    }

其中的Object类型的元素element就是我们向LinkedList中所添加的元素,然后Node又构造好了向前与向后的引用previous、next,最后将生成的这个Node对象加入到了链表当中。换句话说,LinkedList中所维护的是一个个的Node对象。

2. 关于Object类的equals方法的特点

a) 自反性:x.equals(x)应该返回true
b) 对称性:x.equals(y)为true,那么y.equals(x)也为true。
c) 传递性:x.equals(y)为 true并且y.equals(z)为true,那么x.equals(z)也应该为true。
d) 一致性:x.equals(y)的第一次调用为true,那么x.equals(y)的第二次、第三次、第n次调用也应该为true,前提条件是在比较之间没有修改x也没有修改y。

e) 对于非空引用x,x.equals(null)返回false。


3. 关于Object类的hashCode()方法的特点:


a) 在Java应用的一次执行过程当中,对于同一个对象的hashCode方法的多次调用,他们应该返回同样的值(前提是该对象的信息没有发生变化)。


b) 对于两个对象来说,如果使用equals方法比较返回true,那么这两个对象的hashCode值一定是相同的


c) 对于两个对象来说,如果使用equals方法比较返回false,那么这两个对象hashCode值不要求一定不同(可以相同,可以不同),但是如果不同则可以提高应用的性能。


d) 对于Object类来说,不同的Object对象的hashCode值是不同的(Object类的hashCode值表示的是对象的地址)。

4. 当使用HashSet时,hashCode()方法就会得到调用,判断已经存储在集合中的对象的hash code值是否与增加的对象的hash code值一致;如果不一致,直接加进去;如果一致,再进行equals方法的比较,equals方法如果返回true,表示对象已经加进去了,就不会再增加新的对象,否则加进去。

HashSet set = new HashSet();
		
//		set.add(new People("zhangsan"));
//		set.add(new People("lisi"));
//		set.add(new People("zhangsan"));
		
//		People p1 = new People("zhangsan");
//		
//		set.add(p1);
//		set.add(p1);
		
		String s1 = new String("a");
		String s2 = new String("a");
		
		System.out.println("hash code: " + (s1.hashCode() == s2.hashCode()));
		
		set.add(s1);
		set.add(s2);
		
		System.out.println(set)

String的HashCode方法:

/**
     * Returns a hash code for this string. The hash code for a
     * {@code String} object is computed as
     * <blockquote><pre>
     * s[0]*31^(n-1) + s[1]*31^(n-2) + ... + s[n-1]  String类型的HasCode计算法
     * </pre></blockquote>
     * using {@code int} arithmetic, where {@code s[i]} is the
     * <i>i</i>th character of the string, {@code n} is the length of
     * the string, and {@code ^} indicates exponentiation.
     * (The hash value of the empty string is zero.)
     *
     * @return  a hash code value for this object.
     */
    public int hashCode() {
        int h = hash;
        if (h == 0 && value.length > 0) {
            char val[] = value;

            for (int i = 0; i < value.length; i++) {
                h = 31 * h + val[i];
            }
            hash = h;
        }
        return h;
    }



5. 如果我们重写一个类的equals方法,那么也要重写hashCode方法,反之亦然。

重写HashCode是为了在集合中应用。

Eclipse 自动重写HashCode()和equals();Source->Generate....

迭代器:(类似于GIS里面的cursor)

通常希望循环通过类集中的元素。例如,可能会希望显示每一个元素。到目前为止,处理这个问题的最简单方法是使用iterator,iterator是一个或者实现Iterator或者实现ListIterator接口的对象。Iterator可以完成循环通过类集,从而获得或删除元素。ListIterator扩展Iterator,允许双向遍历列表,并可以修改单元.


在通过迭代函数访问类集之前,必须得到一个迭代函数。每一个Collection类都提供一个iterator()函数,该函数返回一个对类集头的迭代函数。通过使用这个迭代函数对象,可以访问类集中的每一个元素,一次一个元素。通常,使用迭代函数循环通过类集的内容,步骤如下
–1. 通过调用类集的iterator( )方法获得对类集头的迭代函数。
–2. 建立一个调用hasNext( )方法的循环,只要hasNext( )返回true,就进行循环迭代。
–3. 在循环内部,通过调用next( )方法来得到每一个元素

public static void main(String[] args)
	{
		HashSet hash = new HashSet();
		hash.add("I");
		hash.add(" Miss ");
		hash.add(" You ");
		hash.add(" WangBingJia");
		Iterator iterator = hash.iterator();
		while (iterator.hasNext())
		{
			System.out.println(iterator.next().toString());
		}
	}
TreeSet 有顺序的集合,使用前通常需要定义 Comparator,即实现Comparator接口中Compare方法

public class TreeSetTest
{
	
	public static void main(String[] args)
	{
		Compare compare=new Compare();
		TreeSet ts=new TreeSet(compare);
		ts.add((new Student(10)));
		ts.add(new Student(20));
		System.out.println(ts);
		
	}
	

}
class Compare implements Comparator
{

	@Override
	public int compare(Object o1, Object o2)
	{
		// TODO Auto-generated method stub
		Student s1=(Student) o1;
		Student s2=(Student) o2;
		if (s1 .socore<s2.socore)
		{
			return -1;
		}
		else if (s1 .socore==s2.socore)
		{
			return 0;
		}
		else {
			return 1;
		}
		
	}
	}
class Student
{
	 int socore;
	Student(int socore){
		this.socore=socore;
	}
	@Override
	public String toString()
	{
		// TODO Auto-generated method stub
		return Integer.toString(socore);
	}
	}

Collections类的一些静态方法

reverseOrder() 反序排列

shuffle  打乱顺序

public static void main(String[] args)
	{
		LinkedList list = new LinkedList();
		
		list.add(new Integer(-8));
		list.add(new Integer(20));
		list.add(new Integer(-20));
		list.add(new Integer(8));
		
		Comparator r = Collections.reverseOrder();
		
		Collections.sort(list, r);
		
		for(Iterator iter = list.iterator(); iter.hasNext();)
		{
			System.out.println(iter.next() + " ");
		}
		
		System.out.println();
		
		Collections.shuffle(list);
		
		for(Iterator iter = list.iterator(); iter.hasNext();)
		{
			System.out.println(iter.next() + " ");
		}
		
		System.out.println("minimum value: " + Collections.min(list));
		System.out.println("maximum value: " + Collections.max(list));
	}

6. Map(映射):实现类HashMap

Map的keySet()方法会返回key的集合,因为Map的键是不能重复的因此keySet()方法的返回类型是Set;而Map的值是可以重复的,因此values()方法的返回类型是Collection,可以容纳重复的元素。


HashMap hashMap=new HashMap();
hashMap.put("a","Bingjia");
hashMap.put("a","I");
hashMap.put("b","Bingjia");
System.out.println(hashMap);


通过hashMap的KeySet方法,实现对hashMap的遍历

Set set=hMap.keySet();
		Iterator iterator=set.iterator();
		while (iterator.hasNext())
		{
			System.out.println(hMap.get(iterator.next()));
			
		}

HashMap中储存的是一个一个Map.Entry对象,每一个Map.Entry维护了一对key和value

所以对HashMap的遍历可以遍历取出Map.Entry

hMap.put("1","I");
		hMap.put("2","Miss");
		hMap.put("3","You");
		hMap.put("4","WangBingjia");
		
		
		Set set =hMap.entrySet();
		Iterator iterator=set.iterator();
		while (iterator.hasNext())
		{
			Map.Entry entry=(Entry) iterator.next();
			System.out.println("key "+entry.getKey()+" values "+ entry.getValue());
			
		}





利用hashMap统计数字

HashMap hMap=new HashMap();
for(int i=0;i<args.length;i++)
{
if (hMap.containsKey(args[i]))
{
Object o1= hMap.get(args[i]);
Integer integer=(Integer )o1;
integer ++;
hMap.put(args[i],integer);

}
else {
hMap.put(args[i],1);
}
}
System.out.println(hMap);





asp.net – 使用HTML’readonly =“readonly”’与JavaScript’元素的奇怪行为.readOnly = true;’

asp.net – 使用HTML’readonly =“readonly”’与JavaScript’元素的奇怪行为.readOnly = true;’

一些背景

所以我在Web应用程序中完成了一些增强功能,可以自动插入数据.用户填写了一些文本框,其中的其他文本框具有自动计算的值.接收自动计算值的文本框必须是readOnly以防止用户更改,但不能禁用或不会在回发时提交.这些文本框中的每一个旁边都有一个复选框,因此用户可以有意识地检查它以使字段可写,从而允许它们覆盖插值.

浏览器:IE 7(不确定这在其他人中的行为)

问题

使用JavaScript设置文本框的readOnly属性时,文本框中的值将以以下形式提交:我可以在服务器端(ASP.NET)使用myTextBox.Text查看它,它位于Request.Form(“myTextBox”)中.

如果我在我的< asp:TextBox />上设置ReadOnly =“true”在不使用JavaScript方法的情况下,文本框中的值不能从myTextBox.Text中获取(我假设它从未进入ViewState),但它是以表格形式提交的:Request.Form(“myTextBox” “)有一个价值.

我的问题

到底他妈发生了什么?这是设计的吗?这是一个浏览器问题吗?我找到了一个bug吗?令人讨厌的是,我必须有一些额外的JavaScript,以便在页面加载时最初禁用文本框的可写性,以使我的应用程序正常工作.

谢谢!

解决方法

这是设计的.作为ASP.NET安全功能,无论客户端发生什么,在服务器上将其设置为只读即可使其保持只读状态.如果您希望它们能够覆盖它并实际提交一个值,那么它在服务器上并不是真正的只读,只是在客户端上有条件地.您可以在选中复选框以更改服务器上的readonly属性时进行回发,也可以使用此ASP.NET代码仅在客户端上设置readonly属性:
MyControl.Attributes.Add("readOnly","readOnly")

asp.net-mvc-2 – 如何在不设置Content-Disposition标签的情况下从控制器返回图像?

asp.net-mvc-2 – 如何在不设置Content-Disposition标签的情况下从控制器返回图像?

所以我使用MVC 2来提供来自Controller Action的一些图像.一般智慧( 1,2,3)似乎是使用FileResult类型之一(FileStreamResult,FileContentResult或`FileContentResult’).

但是,所有三个具体的FileResult都使用附件设置Content-disposition响应头;文件名{YourFileNameHere} = UTF-8.最终结果是,如果用户直接查看我的图像,而不是嵌入HTML,浏览器会显示保存对话框,而不是显示图像.我希望图像只是在浏览器中显示.

我想这就是我的问题:使用MVC 2返回图像结果的合适方法是什么,图像没有标记下载?

解决方法

MVC框架使用FileResult.FileDownloadName属性来确定是以内联方式还是作为附件发送内容.如果直接实例化FileResult派生类型,请不要设置其FileDownloadName属性.或者,如果您正在使用Controller.File工厂方法,请调用不带fileDownloadName参数的重载(或者为该参数传入null).

c – 如何在不复制的情况下从C数组构造std :: vector或boost ::数组?

c – 如何在不复制的情况下从C数组构造std :: vector或boost ::数组?

给定一个char数组的指针,是否可以从中构造一个std :: vector或boost :: array,并避免内存复制?

提前致谢!

解决方法

因为向量拥有自己的分配器和存储器,所以没有办法(对于非原始元素,move_iterators构造可能会有所帮助).

所以假设目标是得到一个真正的std :: vector< char>&对于现有的存储,你永远不会成功,甚至不能使用自定义分配器¹.

如果需要字符串,可以使用boost :: string_ref(在utility / string_ref.hpp中).

否则,您可以使用1维multi_array_ref(来自Boost Multi Array)

1.使用string_ref

这绝对是最简单的:

Live On Coliru

#include <boost/utility/string_ref.hpp>
#include <iostream>

using boost::string_ref;

int main() {
    char some_arr[] = "hello world";

    string_ref no_copy(some_arr);

    std::cout << no_copy;
}

2. multi_array_ref

这是更多功能的,如果你不适合字符串界面,它会“更好”.

Live On Coliru

#include <boost/multi_array/multi_array_ref.hpp>
#include <iostream>

using ref = boost::multi_array_ref<char,1>;
using boost::extents;

int main() {
    char some_arr[] = "hello world";

    ref no_copy(some_arr,extents[sizeof(some_arr)]);

    std::cout.write(no_copy.data(),no_copy.num_elements());
}

两个例子打印

hello world

¹专门化std :: allocator< char>是太邪恶无法考虑,可能完全被标准所禁止

今天的关于c# – 如何在不复制元素的情况下从HashSet创建ReadOnlyCollection?c#实现复制功能的分享已经结束,谢谢您的关注,如果想了解更多关于9 HashSet HashCode 迭代器 TreeSet Colletions类 HashMap、asp.net – 使用HTML’readonly =“readonly”’与JavaScript’元素的奇怪行为.readOnly = true;’、asp.net-mvc-2 – 如何在不设置Content-Disposition标签的情况下从控制器返回图像?、c – 如何在不复制的情况下从C数组构造std :: vector或boost ::数组?的相关知识,请在本站进行查询。

本文标签: