Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 547083
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 13, 20262026-05-13T10:56:07+00:00 2026-05-13T10:56:07+00:00

I was reading an interview with Joshua Bloch in Coders at Work, where he

  • 0

I was reading an interview with Joshua Bloch in Coders at Work, where he lamented the introduction of generics in Java 5. He doesn’t like the specific implementation largely because the variance support—Java’s wildcards—makes it unnecessarily complex.

As far as I know, C# 3 doesn’t have anything like explicit, bounded wildcards, e.g. you can’t declare a method PriceBatch that takes a collecton of Asset or any Asset subclass (void PriceBatch(Collection<? extends Asset> assets) in Java?).

Does anyone know why wildcards and bounds haven’t been added to C#? Were these features intentionally left out to make the language simpler, or is this something they just haven’t gotten around to implement yet?

EDIT: Holy smoke, comments from Eric Lippert himself! After reading his and Paul’s insightful comments, I realize that at least upper bounds are supported and that the above example can be translated to C# as:

void PriceBatch<T>(ICollection<T> assets) where T : Asset

Lower bounds, on the other hand, are apparently not supported as Eric says in his second comment, e.g. there is probably no way to directly translate this (somewhat contrived) Java code to C#:

public class Asset {}
public class Derivative extends Asset {}
public class VanillaOption extends Derivative {}

public static <T extends Asset> void copyAssets(Collection<T> src, Collection<? super T> dst) {
    for(T asset : src) dst.add(asset);
}

Collection<VanillaOption> src = new ArrayList<VanillaOption>();
[...]
Collection<Derivative> dst = new ArrayList<Derivative>();
[...]
copyAssets(src, dst);

Am I correct? If this is the case, is there a particular reason why C# has upper but not lower bounds?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-13T10:56:07+00:00Added an answer on May 13, 2026 at 10:56 am

    A complicated question.

    First let’s consider your fundamental question, “why is this illegal in C#?”

    class C<T> where T : Mammal {} // legal
    class D<T> where Giraffe : T {} // illegal
    

    That is, a generic type constraint can say “T must be any reference type that could be assigned to a variable of type Mammal”, but not “T must be any reference type, a variable of which could be assigned a Giraffe”. Why the difference?

    I don’t know. That was long before my time on the C# team. The trivial answer is “because the CLR doesn’t support it”, but the team that designed C# generics was the same team that designed CLR generics, so that’s really not much of an explanation.

    My guess would be simply that as always, to be supported a feature has to be designed, implemented, tested, documented and shipped to customers; no one ever did any of those things for this feature, and therefore it is not in the language. I don’t see a large, compelling benefit to the proposed feature; complicated features with no compelling benefits tend to be cut around here.

    However, that’s a guess. Next time I happen to chat with the guys who worked on generics — they live in England, so its not like they’re just down the hall from me, unfortunately — I’ll ask.

    As for your specific example, I think Paul is correct. You do not need lower bound constraints to make that work in C#. You could say:

    void Copy<T, U>(Collection<T> src, Collection<U> dst) where T : U 
    { 
        foreach(T item in src) dst.Add(item);
    }
    

    That is, put the constraint on T, not on U.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I am reading Coders at Work . I came across this paragraph in Donald
While reading one book named Cracking the coding interview by Gayle Laakmann , i
I was reading about this person's interview at a well-known search company. http://asserttrue.blogspot.com/2009/05/one-of-toughest-job-interview-questions.html He
Just finished reading this blog post: http://www.skorks.com/2010/03/an-interview-question-that-prints-out-its-own-source-code-in-ruby/ In it, the author argues the case
So I was reading up on indexes and their implementation, and I stumbled upon
Afer reading this topic C++ interview preparation (Matt's answer) I've got a question about
I'm reading Cracking the Coding Interview, Fourth Edition: 150 Programming Interview Questions and Solutions
Reading around, the svn:ignore command seems to work one of two ways: If the
I was reading a book on programming skills wherein the author asks the interviewee,
Reading this question I found this as (note the quotation marks) code to solve

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.